SHELL := /bin/sh
# Sane defaults, which are typically overridden on the command line.
-SRCROOT=/tmp
-OBJROOT=$(SRCROOT)
+MINIMAL=NO
+WINDOWS=NO
+SRCROOT=$(shell pwd)
+OBJROOT=$(SRCROOT)/build
+DSTROOT=$(OBJROOT)
SYMROOT=$(OBJROOT)
-DSTROOT=/tmp/build
APPLE_INTERNAL_DIR=/AppleInternal
+TZDATA=$(lastword $(wildcard /usr/local/share/tz/tzdata*.tar.gz))
RC_ARCHS=
-
-#################################
-# Environment variables
-#################################
-
-# $(RC_ARCHS:%=-arch %) is a substitution reference. It denotes, in this case,
-# for every value <val> in RC_ARCHS, replace it with "-arch <val>". Substitution
-# references have the form $(var:a=b). We can insert the strip and prebinding commands
-# into CFLAGS (and CXXFLAGS). This controls a lot of the external variables so we don't
-# need to directly modify the ICU files (like for CFLAGS, etc).
-
-ENV= APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
- CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -fno-exceptions" \
- CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -fno-exceptions" \
- RC_ARCHS="$(RC_ARCHS)" \
- DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
-
-ENV_CONFIGURE= APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
- CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" -g -Os -fno-exceptions" \
- CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" -g -Os -fno-exceptions" \
- RC_ARCHS="$(RC_ARCHS)" \
- DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
-
-ENV_DEBUG = APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
- CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -O0 -g -fno-exceptions" \
- CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -O0 -g -fno-exceptions" \
- RC_ARCHS="$(RC_ARCHS)" \
- DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
+DISABLE_DRAFT=NO
+
+ifeq "$(DISABLE_DRAFT)" "YES"
+ DRAFT_FLAG=--disable-draft
+else
+ DRAFT_FLAG=
+endif
+
+ifeq "$(MINIMAL)" "YES"
+ THUMB_FLAG = -mthumb
+else
+ THUMB_FLAG =
+endif
+
+ifndef RC_ProjectSourceVersion
+ifdef RC_PROJECTSOURCEVERSION
+ RC_ProjectSourceVersion=$(RC_PROJECTSOURCEVERSION)
+endif
+endif
+
+ifneq "$(RC_ProjectSourceVersion)" ""
+ ifeq "$(WINDOWS)" "YES"
+ ICU_BUILD := $(shell echo $(RC_ProjectSourceVersion) | sed -r -e 's/[0-9]+.([0-9]+)(.[0-9]+)?/\1/')
+ else
+ ICU_BUILD := $(shell echo $(RC_ProjectSourceVersion) | sed -E -e 's/[0-9]+.([0-9]+)(.[0-9]+)?/\1/')
+ endif
+else
+ ICU_BUILD := 0
+endif
+
+# Disallow $(SRCROOT) == $(OBJROOT)
+ifeq ($(OBJROOT), $(SRCROOT))
+$(error SRCROOT same as OBJROOT)
+endif
#################################
# Headers
EXTRA_HDRS =
# EXTRA_HDRS = ./extra/ustdio/ ./layout/
-HDR_MAKE_SUBDIR = ./common/ ./i18n/ $(EXTRA_HDRS)
+ifeq "$(MINIMAL)" "YES"
+ HDR_MAKE_SUBDIR = ./common/ ./i18n/ $(EXTRA_HDRS)
+else ifeq "$(WINDOWS)" "YES"
+ HDR_MAKE_SUBDIR = ./common/ ./i18n/ $(EXTRA_HDRS)
+else
+ HDR_MAKE_SUBDIR = ./common/ ./i18n/ ./io/ $(EXTRA_HDRS)
+endif
+ifeq "$(WINDOWS)" "YES"
+ HDR_PREFIX=$(APPLE_INTERNAL_DIR)
+ PRIVATE_HDR_PREFIX=$(APPLE_INTERNAL_DIR)
+else
+ HDR_PREFIX=/usr
+ PRIVATE_HDR_PREFIX=/usr/local
+endif
#################################
# Install
INSTALL = /usr/bin/install
COMMON_OBJ = ./common/*.o
I18N_OBJ = ./i18n/*.o
+IO_OBJ = ./io/*.o
STUB_DATA_OBJ = ./stubdata/*.o
+#COMMON_SRC = $(OBJROOT)/common/*.c
+#I18N_SRC = $(OBJROOT)/i18n/*.c
+#IO_SRC = $(OBJROOT)/io/*.c
+#STUB_DATA_SRC = $(OBJROOT)/stubdata/*.c
EXTRA_LIBS =
#EXTRA_LIBS =./extra/ ./layout/ ./tools/ctestfw/ ./tools/toolutil/
#DATA_OBJ = ./data/out/build/*.o
+ifeq "$(MINIMAL)" "YES"
+ DYLIB_OBJS=$(COMMON_OBJ) $(I18N_OBJ) $(STUB_DATA_OBJ)
+else ifeq "$(WINDOWS)" "YES"
+ DYLIB_OBJS=$(COMMON_OBJ) ./common/common.res $(I18N_OBJ) $(STUB_DATA_OBJ)
+else
+ DYLIB_OBJS=$(COMMON_OBJ) $(I18N_OBJ) $(IO_OBJ) $(STUB_DATA_OBJ)
+endif
#################################
# Cleaning
MANUAL_CLEAN_TEST = ./test/collperf ./test/iotest ./test/letest ./test/thaitest ./test/threadtest ./test/testmap ./test
MANUAL_CLEAN_SAMPLE = ./samples/layout ./samples
-CLEAN_SUBDIR = ./stubdata ./common ./i18n ./layout ./layoutex ./data ./tools ./$(MANUAL_CLEAN_TOOLS) $(MANUAL_CLEAN_EXTRA) $(MANUAL_CLEAN_TEST) $(MANUAL_CLEAN_SAMPLE)
+CLEAN_SUBDIR = ./stubdata ./common ./i18n ./io ./layout ./layoutex ./data ./tools ./$(MANUAL_CLEAN_TOOLS) $(MANUAL_CLEAN_EXTRA) $(MANUAL_CLEAN_TEST) $(MANUAL_CLEAN_SAMPLE)
#################################
# Config flags
#################################
-CONFIG_FLAGS = --disable-renaming --disable-extras --disable-ustdio --disable-layout --disable-tests --disable-samples --with-data-packaging=archive --prefix=/usr/local
+ifeq "$(MINIMAL)" "YES"
+ CONFIG_FLAGS = --disable-renaming --disable-extras --disable-icuio --disable-layout \
+ --disable-samples --with-data-packaging=archive --prefix=$(PRIVATE_HDR_PREFIX) \
+ $(DRAFT_FLAG) --srcdir=$(SRCROOT)/icuSources
+else ifeq "$(WINDOWS)" "YES"
+ CONFIG_FLAGS = --disable-extras --disable-icuio --disable-layout \
+ --disable-samples --with-data-packaging=library --prefix=$(PRIVATE_HDR_PREFIX) \
+ $(DRAFT_FLAG)
+else
+ CONFIG_FLAGS = --disable-renaming --disable-extras --disable-layout \
+ --disable-samples --with-data-packaging=archive --prefix=$(PRIVATE_HDR_PREFIX) \
+ $(DRAFT_FLAG) --srcdir=$(SRCROOT)/icuSources
+endif
#################################
# Install paths
# version changes it's API...that is a new version isn't backwards compatible.
# The ICU version/subversion should reflect the actual ICU version.
-LIB_NAME = libicucore
-ICU_VERS = 26
+LIB_NAME = icucore
+ICU_VERS = 36
ICU_SUBVERS = 0
CORE_VERS = A
-DYLIB_SUFF = dylib
-libdir = /usr/lib/
-INSTALLED_DYLIB = $(LIB_NAME).$(CORE_VERS).$(DYLIB_SUFF)
-DYLIB = $(LIB_NAME).$(DYLIB_SUFF)
+ifeq "$(WINDOWS)" "YES"
+ DYLIB_SUFF = dll
+ libdir = /AppleInternal/bin/
+ winlibdir = /AppleInternal/lib/
+else
+ DYLIB_SUFF = dylib
+ libdir = /usr/lib/
+ winlibdir =
+endif
+
+DYLIB = lib$(LIB_NAME).$(DYLIB_SUFF)
+DYLIB_DEBUG = lib$(LIB_NAME)_debug.$(DYLIB_SUFF)
+DYLIB_PROFILE = lib$(LIB_NAME)_profile.$(DYLIB_SUFF)
+ifeq "$(WINDOWS)" "YES"
+ INSTALLED_DYLIB = $(LIB_NAME).$(DYLIB_SUFF)
+ INSTALLED_DYLIB_DEBUG = $(LIB_NAME)_debug.$(DYLIB_SUFF)
+ INSTALLED_DYLIB_PROFILE = $(LIB_NAME)_profile.$(DYLIB_SUFF)
+else
+ INSTALLED_DYLIB = lib$(LIB_NAME).$(CORE_VERS).$(DYLIB_SUFF)
+ INSTALLED_DYLIB_DEBUG = lib$(LIB_NAME).$(CORE_VERS)_debug.$(DYLIB_SUFF)
+ INSTALLED_DYLIB_PROFILE = lib$(LIB_NAME).$(CORE_VERS)_profile.$(DYLIB_SUFF)
+endif
+
+INSTALLED_DYLIB_icu = INSTALLED_DYLIB
+INSTALLED_DYLIB_debug = INSTALLED_DYLIB_DEBUG
+INSTALLED_DYLIB_profile = INSTALLED_DYLIB_PROFILE
+DYLIB_icu = DYLIB
+DYLIB_debug = DYLIB_DEBUG
+DYLIB_profile = DYLIB_PROFILE
#################################
# Data files
#################################
datadir=/usr/share/icu/
-ICU_DATA_DIR= /data/out/
+OPEN_SOURCE_VERSIONS_DIR=/usr/local/OpenSourceVersions/
+OPEN_SOURCE_LICENSES_DIR=/usr/local/OpenSourceLicenses/
+ICU_DATA_DIR= data/out
B_DATA_FILE=icudt$(ICU_VERS)b.dat
L_DATA_FILE=icudt$(ICU_VERS)l.dat
+#################################
+# Environment variables
+#################################
+
+# $(RC_ARCHS:%=-arch %) is a substitution reference. It denotes, in this case,
+# for every value <val> in RC_ARCHS, replace it with "-arch <val>". Substitution
+# references have the form $(var:a=b). We can insert the strip and prebinding commands
+# into CFLAGS (and CXXFLAGS). This controls a lot of the external variables so we don't
+# need to directly modify the ICU files (like for CFLAGS, etc).
+
+LIBOVERRIDES=LIBICUDT="-L$(OBJROOT) -l$(LIB_NAME)" \
+ LIBICUUC="-L$(OBJROOT) -l$(LIB_NAME)" \
+ LIBICUI18N="-L$(OBJROOT) -l$(LIB_NAME)"
+
+ifeq "$(WINDOWS)" "YES"
+ ifeq "$(ICU_BUILD)" "0"
+ CPPOPTIONS =
+ else
+ CPPOPTIONS = CPPFLAGS="-DU_ICU_VERSION_BUILDLEVEL_NUM=$(ICU_BUILD)"
+ endif
+ ENV= CFLAGS="/O2 /Ob2 /MD /GF" CXXFLAGS="/O2 /Ob2 /MD /GF" LDFLAGS="/DEBUG"
+ ENV_CONFIGURE= $(CPPOPTIONS) CFLAGS="/O2 /Ob2 /MD /GF" CXXFLAGS="/O2 /Ob2 /MD /GF" LDFLAGS="/DEBUG"
+ ENV_DEBUG= CFLAGS="/O2 /Ob2 /MDd /GF /Zi" CXXFLAGS="/O2 /Ob2 /MDd /GF /Zi" LDFLAGS="/DEBUG"
+ ENV_PROFILE=
+else
+ ifeq "$(ICU_BUILD)" "0"
+ CPPOPTIONS = CPPFLAGS="-DSTD_INSPIRED -DMAC_OS_X_VERSION_MIN_REQUIRED=1040"
+ else
+ CPPOPTIONS = CPPFLAGS="-DU_ICU_VERSION_BUILDLEVEL_NUM=$(ICU_BUILD) -DSTD_INSPIRED -DMAC_OS_X_VERSION_MIN_REQUIRED=1040"
+ endif
+ ENV= APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
+ CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -fno-exceptions -fvisibility=hidden $(THUMB_FLAG)" \
+ CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -fno-exceptions -fno-rtti -fvisibility=hidden -fvisibility-inlines-hidden $(THUMB_FLAG)" \
+ RC_ARCHS="$(RC_ARCHS)" \
+ TZDATA="$(TZDATA)" \
+ DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
+
+ ENV_CONFIGURE= $(CPPOPTIONS) APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
+ CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" -g -Os -fno-exceptions -fvisibility=hidden $(THUMB_FLAG)" \
+ CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" -g -Os -fno-exceptions -fno-rtti -fvisibility=hidden -fvisibility-inlines-hidden $(THUMB_FLAG)" \
+ RC_ARCHS="$(RC_ARCHS)" \
+ TZDATA="$(TZDATA)" \
+ DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
+
+ ENV_DEBUG = APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
+ CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -O0 -gfull -fno-exceptions -fvisibility=hidden $(THUMB_FLAG)" \
+ CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -O0 -gfull -fno-exceptions -fno-rtti -fvisibility=hidden -fvisibility-inlines-hidden $(THUMB_FLAG)" \
+ RC_ARCHS="$(RC_ARCHS)" \
+ TZDATA="$(TZDATA)" \
+ DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
+
+ ENV_PROFILE = APPLE_INTERNAL_DIR="$(APPLE_INTERNAL_DIR)" \
+ CFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -pg -fno-exceptions -fvisibility=hidden $(THUMB_FLAG)" \
+ CXXFLAGS="-DICU_DATA_DIR=\"\\\"/usr/share/icu/\\\"\" $(RC_ARCHS:%=-arch %) -g -Os -pg -fno-exceptions -fno-rtti -fvisibility=hidden -fvisibility-inlines-hidden $(THUMB_FLAG)" \
+ RC_ARCHS="$(RC_ARCHS)" \
+ TZDATA="$(TZDATA)" \
+ DYLD_LIBRARY_PATH="$(DSTROOT)/usr/local/lib"
+endif
+
+ENV_icu = ENV
+ENV_debug = ENV_DEBUG
+ENV_profile = ENV_PROFILE
+
+ORDERFILE=/usr/local/lib/OrderFiles/libicucore.order
+ifeq "$(shell test -f $(ORDERFILE) && echo YES )" "YES"
+ SECTORDER_FLAGS=-sectorder __TEXT __text $(ORDERFILE)
+else
+ SECTORDER_FLAGS=
+endif
+
+
#################################
#################################
# TARGETS
#################################
#################################
+
+.PHONY : icu check installsrc installhdrs clean install debug debug-install
+.DELETE_ON_ERROR :
+
+icu debug profile : $(OBJROOT)/Makefile
+ (cd $(OBJROOT); \
+ $(MAKE) $($(ENV_$@)); \
+ if test "$(WINDOWS)" = "YES"; then \
+ if test "$@" = "debug"; then \
+ (cd common; \
+ LINK.EXE /subsystem:console /DLL /nologo /base:"0x4a800000" /DEBUG \
+ /IMPLIB:../lib/icuuc_$@.lib /out:../lib/icuuc$(ICU_VERS)_$@.dll *.o \
+ common.res ../stubdata/icudt.lib advapi32.lib;); \
+ (cd i18n; \
+ LINK.EXE /subsystem:console /DLL /nologo /base:"0x4a900000" /DEBUG \
+ /IMPLIB:../lib/icuin_$@.lib /out:../lib/icuin$(ICU_VERS)_$@.dll *.o \
+ i18n.res ../lib/icuuc_$@.lib ../stubdata/icudt.lib advapi32.lib;); \
+ fi; \
+ else \
+ tmpfile=`mktemp -t weakexternal` || exit 1; \
+ nm -m $(RC_ARCHS:%=-arch %) $(DYLIB_OBJS) | fgrep "weak external" | fgrep -v "undefined" | sed -e 's/.*weak external //' | sort | uniq | cat >$$tmpfile; \
+ $($(ENV_$@)) $(CXX) -current_version $(ICU_VERS).$(ICU_SUBVERS) -compatibility_version 1 -dynamiclib -dynamic \
+ $(RC_ARCHS:%=-arch %) $(CXXFLAGS) $(LDFLAGS) -single_module $(SECTORDER_FLAGS) -unexported_symbols_list $$tmpfile -dead_strip \
+ -install_name $(libdir)$($(INSTALLED_DYLIB_$@)) -o ./$($(INSTALLED_DYLIB_$@)) $(DYLIB_OBJS); \
+ if test -f ./$(ICU_DATA_DIR)/$(B_DATA_FILE); then \
+ ln -fs ./$(ICU_DATA_DIR)/$(B_DATA_FILE); \
+ else \
+ DYLD_LIBRARY_PATH="./lib:./stubdata" \
+ ./bin/icupkg -tb ./$(ICU_DATA_DIR)/$(L_DATA_FILE) $(B_DATA_FILE); \
+ fi; \
+ if test -f ./$(ICU_DATA_DIR)/$(L_DATA_FILE); then \
+ ln -fs ./$(ICU_DATA_DIR)/$(L_DATA_FILE); \
+ else \
+ DYLD_LIBRARY_PATH="./lib:./stubdata" \
+ ./bin/icupkg -tl ./$(ICU_DATA_DIR)/$(B_DATA_FILE) $(L_DATA_FILE); \
+ fi; \
+ fi; \
+ );
+
+check : icu
+ (cd $(OBJROOT); \
+ ICU_DATA=$(OBJROOT) $(MAKE) $(ENV) check; \
+ );
+
+check-debug: debug
+ (cd $(OBJROOT); \
+ ICU_DATA=$(OBJROOT) $(MAKE) $(ENV_DEBUG) check; \
+ );
+
+samples: icu
+ (cd $(OBJROOT)/samples; \
+ $(MAKE) $(ENV_DEBUG) $(LIBOVERRIDES); \
+ );
+
+extra: icu
+ (cd $(OBJROOT)/extra; \
+ $(MAKE) $(ENV_DEBUG) $(LIBOVERRIDES); \
+ );
+
+$(OBJROOT)/Makefile :
+ if test ! -d $(OBJROOT); then \
+ mkdir -p $(OBJROOT); \
+ fi;
+ if test "$(WINDOWS)" = "YES"; then \
+ cp -Rpf $(SRCROOT)/icuSources/* $(OBJROOT); \
+ (cd $(OBJROOT)/data/unidata; mv base_unidata/*.txt .;); \
+ (cd $(OBJROOT); $(ENV_CONFIGURE) ./runConfigureICU Cygwin/MSVC $(CONFIG_FLAGS);) \
+ else \
+ (cd $(OBJROOT); $(ENV_CONFIGURE) $(SRCROOT)/icuSources/runConfigureICU MacOSX $(CONFIG_FLAGS);) \
+ fi;
+ if test "$(MINIMAL)" = "YES"; then \
+ (cd $(OBJROOT)/common/unicode/; \
+ cp $(SRCROOT)/icuSources/common/unicode/uconfig.h . ; \
+ patch <$(SRCROOT)/minimalpatchconfig.txt;) \
+ elif test "$(WINDOWS)" = "YES"; then \
+ (cd $(OBJROOT)/common/unicode/; \
+ cp $(SRCROOT)/icuSources/common/unicode/uconfig.h . ; \
+ patch <$(SRCROOT)/windowspatchconfig.txt;) \
+ else \
+ (cd $(OBJROOT)/common/unicode/; \
+ cp $(SRCROOT)/icuSources/common/unicode/uconfig.h . ; \
+ patch <$(SRCROOT)/patchconfig.txt;) \
+ fi; \
+ if test -f $(SRCROOT)/icuSources/common/Makefile.local; then \
+ cp -p $(SRCROOT)/icuSources/common/Makefile.local $(OBJROOT)/common/ ; \
+ fi;
+
+#################################
+# B&I TARGETS
+#################################
+
# Since our sources are in icuSources (ignore the ICU subdirectory for now), we wish to
# copy them to somewhere else. We tar it to stdout, cd to the appropriate directory, and
# untar from stdin. We then look for all the CVS directories and remove them. We may have
installsrc :
if test ! -d $(SRCROOT); then mkdir $(SRCROOT); fi;
if test -d $(SRCROOT)/icuSources ; then rm -rf $(SRCROOT)/icuSources; fi;
- tar cf - ./makefile ./icuSources ./$(L_DATA_FILE) | (cd $(SRCROOT) ; tar xfp -); \
+ tar cf - ./makefile ./ICU.plist ./license.html ./icuSources ./minimalpatchconfig.txt ./windowspatchconfig.txt ./patchconfig.txt | (cd $(SRCROOT) ; tar xfp -); \
for i in `find $(SRCROOT)/icuSources/ | grep "CVS$$"` ; do \
if test -d $$i ; then \
rm -rf $$i; \
# been already). Then we make the install-headers target on specific makefiles (since
# not every subdirectory/sub-component has a install-headers target).
-installhdrs : $(SRCROOT)/icuSources/Makefile
- $(SHELL) -ec \
- 'cd $(SRCROOT)/icuSources; \
- for subdir in $(HDR_MAKE_SUBDIR); do \
- (cd $$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) install-headers); \
- done;'
-
+installhdrs : $(OBJROOT)/Makefile
+ (cd $(OBJROOT); \
+ for subdir in $(HDR_MAKE_SUBDIR); do \
+ (cd $$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) install-headers); \
+ done; \
+ );
+
# We run configure and run make first. This generates the .o files. We then link them
# all up together into libicucore. Then we put it into its install location, create
# symbolic links, and then strip the main dylib. Then install the remaining libraries.
# We cleanup the sources folder.
-
-install : installhdrs $(SRCROOT)/icuSources/Makefile
- $(SHELL) -ec \
- 'cd $(SRCROOT)/icuSources; \
- $(MAKE) $(ENV); \
- $(ENV) $(CXX) -current_version $(ICU_VERS).$(ICU_SUBVERS) -compatibility_version 1 -dynamiclib -dynamic $(RC_ARCHS:%=-arch %) $(CXXFLAGS) $(LDFLAGS) -single_module -sectorder __TEXT __text /usr/local/lib/OrderFiles/libicucore.order -install_name $(libdir)$(INSTALLED_DYLIB) -o ./$(INSTALLED_DYLIB) $(COMMON_OBJ) $(I18N_OBJ) $(STUB_DATA_OBJ); \
+
+install : installhdrs icu
if test ! -d $(DSTROOT)$(libdir)/; then \
$(INSTALL) -d -m 0775 $(DSTROOT)$(libdir)/; \
- fi; \
- $(INSTALL) -b -m 0664 ./$(INSTALLED_DYLIB) $(DSTROOT)$(libdir)$(INSTALLED_DYLIB); \
- cd $(DSTROOT)$(libdir); \
- ln -fs $(INSTALLED_DYLIB) $(DYLIB); \
- cp $(INSTALLED_DYLIB) $(SYMROOT)/$(INSTALLED_DYLIB); \
- strip -x -u -r -S $(DSTROOT)$(libdir)$(INSTALLED_DYLIB);'
- for subdir in $(EXTRA_LIBS); do \
- (cd $(SRCROOT)/icuSources/$$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) install-library;) \
- done;
- if test ! -d $(DSTROOT)$(datadir)/; then \
- $(INSTALL) -d -m 0755 $(DSTROOT)$(datadir)/; \
- fi;
- if test -f $(SRCROOT)/icuSources/$(ICU_DATA_DIR)/$(B_DATA_FILE); then \
- $(INSTALL) -b -m 0644 $(SRCROOT)/icuSources/$(ICU_DATA_DIR)/$(B_DATA_FILE) $(DSTROOT)$(datadir)$(B_DATA_FILE); \
fi;
- if test -f $(SRCROOT)/$(L_DATA_FILE); then \
- $(INSTALL) -b -m 0644 $(SRCROOT)/$(L_DATA_FILE) $(DSTROOT)$(datadir)$(L_DATA_FILE); \
- fi;
- for i in $(CLEAN_SUBDIR) ; do \
- if test -e $(SRCROOT/icuSources/$$i); then \
- (cd $(SRCROOT)/icuSources/$$i; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) distclean); \
+ if test "$(WINDOWS)" = "YES"; then \
+ if test ! -d $(DSTROOT)$(winlibdir)/; then \
+ $(INSTALL) -d -m 0775 $(DSTROOT)$(winlibdir)/; \
fi; \
- done; \
- (cd $(SRCROOT)/icuSources; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) distclean-local;)
- if test -f $(SRCROOT)/icuSources/config/icu-config; then \
- rm -rf $(SRCROOT)/icuSources/config/icu-config; \
- fi;
- if test -f $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); then \
- rm -rf $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); \
- fi;
-
-clean :
- if test -d $(SRCROOT)/icuSources; then \
- if test -e $(SRCROOT)/icuSources/Makefile; then \
- for i in $(CLEAN_SUBDIR) ; do \
- if test -e $(SRCROOT/icuSources/$$i); then \
- (cd $(SRCROOT)/icuSources/$$i; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) distclean); \
- fi; \
- done; \
- (cd $(SRCROOT)/icuSources; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) distclean-local;) \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuuc.lib $(DSTROOT)$(winlibdir)icuuc.lib; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuuc$(ICU_VERS).pdb $(DSTROOT)$(libdir)icuuc$(ICU_VERS).pdb; \
+ $(INSTALL) -b -m 0755 $(OBJROOT)/lib/icuuc$(ICU_VERS).dll $(DSTROOT)$(libdir)icuuc$(ICU_VERS).dll; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuin.lib $(DSTROOT)$(winlibdir)icuin.lib; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuin$(ICU_VERS).pdb $(DSTROOT)$(libdir)icuin$(ICU_VERS).pdb; \
+ $(INSTALL) -b -m 0755 $(OBJROOT)/lib/icuin$(ICU_VERS).dll $(DSTROOT)$(libdir)icuin$(ICU_VERS).dll; \
+ $(INSTALL) -b -m 0755 $(OBJROOT)/lib/icudt$(ICU_VERS).dll $(DSTROOT)$(libdir)icudt$(ICU_VERS).dll; \
+ else \
+ $(INSTALL) -b -m 0664 $(OBJROOT)/$(INSTALLED_DYLIB) $(DSTROOT)$(libdir)$(INSTALLED_DYLIB); \
+ (cd $(DSTROOT)$(libdir); \
+ ln -fs $(INSTALLED_DYLIB) $(DYLIB)); \
+ cp $(OBJROOT)/$(INSTALLED_DYLIB) $(SYMROOT)/$(INSTALLED_DYLIB); \
+ strip -x -u -r -S $(DSTROOT)$(libdir)$(INSTALLED_DYLIB); \
+ for subdir in $(EXTRA_LIBS); do \
+ (cd $(OBJROOT)/$$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) install-library;) \
+ done; \
+ if test ! -d $(DSTROOT)$(datadir)/; then \
+ $(INSTALL) -d -m 0755 $(DSTROOT)$(datadir)/; \
+ fi; \
+ if test -f $(OBJROOT)/$(B_DATA_FILE); then \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/$(B_DATA_FILE) $(DSTROOT)$(datadir)$(B_DATA_FILE); \
fi; \
- fi;
- if test -f $(SRCROOT)/icuSources/config/icu-config; then \
- rm -rf $(SRCROOT)/icuSources/config/icu-config; \
- fi;
- if test -f $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); then \
- rm -rf $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); \
+ if test -f $(OBJROOT)/$(L_DATA_FILE); then \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/$(L_DATA_FILE) $(DSTROOT)$(datadir)$(L_DATA_FILE); \
+ fi; \
+ if test ! -d $(DSTROOT)$(OPEN_SOURCE_VERSIONS_DIR)/; then \
+ $(INSTALL) -d -m 0755 $(DSTROOT)$(OPEN_SOURCE_VERSIONS_DIR)/; \
+ fi; \
+ $(INSTALL) -b -m 0644 $(SRCROOT)/ICU.plist $(DSTROOT)$(OPEN_SOURCE_VERSIONS_DIR)ICU.plist; \
+ if test ! -d $(DSTROOT)$(OPEN_SOURCE_LICENSES_DIR)/; then \
+ $(INSTALL) -d -m 0755 $(DSTROOT)$(OPEN_SOURCE_LICENSES_DIR)/; \
+ fi; \
+ $(INSTALL) -b -m 0644 $(SRCROOT)/license.html $(DSTROOT)$(OPEN_SOURCE_LICENSES_DIR)ICU.html; \
fi;
-$(SRCROOT)/icuSources/Makefile :
- $(SHELL) -ec \
- 'cd $(SRCROOT)/icuSources; \
- $(ENV_CONFIGURE) ./configure $(CONFIG_FLAGS);'
+DEPEND_install_debug = debug
+DEPEND_install_profile = profile
-#################################
-# OPTIONAL TARGETS
-#################################
-
-# These targets aren't required by B&I. They're supposed to make life easier by not deleting
-# the object files so that we don't have to rebuild the entire binary every single time. This
-# should aid in development.
-
-debug: installhdrs $(SRCROOT)/icuSources/Makefile
- $(SHELL) -ec \
- 'cd $(SRCROOT)/icuSources; \
- $(MAKE) $(ENV_DEBUG); \
- $(ENV_DEBUG) $(CXX) -current_version $(ICU_VERS).$(ICU_SUBVERS) -compatibility_version 1 -dynamiclib -dynamic $(RC_ARCHS:%=-arch %) $(CXXFLAGS) $(LDFLAGS) -install_name $(libdir)$(INSTALLED_DYLIB) -o ./$(INSTALLED_DYLIB) $(COMMON_OBJ) $(I18N_OBJ) $(STUB_DATA_OBJ); \
+.SECONDEXPANSION:
+install_debug install_profile : $$(DEPEND_$$@)
if test ! -d $(DSTROOT)$(libdir)/; then \
$(INSTALL) -d -m 0775 $(DSTROOT)$(libdir)/; \
- fi; \
- $(INSTALL) -b -m 0664 ./$(INSTALLED_DYLIB) $(DSTROOT)$(libdir)$(INSTALLED_DYLIB); \
- cd $(DSTROOT)$(libdir); \
- ln -fs $(INSTALLED_DYLIB) $(DYLIB);'
-
-debug-install: debug installhdrs $(SRCROOT)/icuSources/Makefile
- for subdir in $(EXTRA_LIBS); do \
- (cd $(SRCROOT)/icuSources/$$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV_DEBUG) install-library;) \
- done;
- if test ! -d $(DSTROOT)$(datadir)/; then \
- $(INSTALL) -d -m 0755 $(DSTROOT)$(datadir)/; \
- fi;
- if test -f $(SRCROOT)/icuSources/$(ICU_DATA_DIR)/$(B_DATA_FILE); then \
- $(INSTALL) -b -m 0644 $(SRCROOT)/icuSources/$(ICU_DATA_DIR)/$(B_DATA_FILE) $(DSTROOT)$(datadir)$(B_DATA_FILE); \
- else \
- $(INSTALL) -b -m 0644 $(SRCROOT)/icuSources/$(ICU_DATA_DIR)/$(L_DATA_FILE) $(DSTROOT)$(datadir)$(L_DATA_FILE); \
fi;
- (cd $(SRCROOT)/icuSources; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) distclean-local;)
- if test -f $(SRCROOT)/icuSources/config/icu-config; then \
- rm -rf $(SRCROOT)/icuSources/config/icu-config; \
+ if test "$(WINDOWS)" = "YES"; then \
+ if test ! -d $(DSTROOT)$(winlibdir)/; then \
+ $(INSTALL) -d -m 0775 $(DSTROOT)$(winlibdir)/; \
+ fi; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuuc_$(DEPEND_$@).lib $(DSTROOT)$(winlibdir)icuuc_$(DEPEND_$@).lib; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuuc$(ICU_VERS)_$(DEPEND_$@).pdb $(DSTROOT)$(libdir)icuuc$(ICU_VERS)_$(DEPEND_$@).pdb; \
+ $(INSTALL) -b -m 0755 $(OBJROOT)/lib/icuuc$(ICU_VERS)_$(DEPEND_$@).dll $(DSTROOT)$(libdir)icuuc$(ICU_VERS)_$(DEPEND_$@).dll; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuin_$(DEPEND_$@).lib $(DSTROOT)$(winlibdir)icuin_$(DEPEND_$@).lib; \
+ $(INSTALL) -b -m 0644 $(OBJROOT)/lib/icuin$(ICU_VERS)_$(DEPEND_$@).pdb $(DSTROOT)$(libdir)icuin$(ICU_VERS)_$(DEPEND_$@).pdb; \
+ $(INSTALL) -b -m 0755 $(OBJROOT)/lib/icuin$(ICU_VERS)_$(DEPEND_$@).dll $(DSTROOT)$(libdir)icuin$(ICU_VERS)_$(DEPEND_$@).dll; \
+ else \
+ $(INSTALL) -b -m 0664 $(OBJROOT)/$($(INSTALLED_DYLIB_$(DEPEND_$@))) $(DSTROOT)$(libdir)$($(INSTALLED_DYLIB_$(DEPEND_$@))); \
+ (cd $(DSTROOT)$(libdir); \
+ ln -fs $($(INSTALLED_DYLIB_$(DEPEND_$@))) $($(DYLIB_$(DEPEND_$@)))); \
+ cp $(OBJROOT)/$($(INSTALLED_DYLIB_$(DEPEND_$@))) $(SYMROOT)/$($(INSTALLED_DYLIB_$(DEPEND_$@))); \
+ strip -x -u -r -S $(DSTROOT)$(libdir)$($(INSTALLED_DYLIB_$(DEPEND_$@))); \
+ for subdir in $(EXTRA_LIBS); do \
+ (cd $(OBJROOT)/$$subdir; $(MAKE) -e DESTDIR=$(DSTROOT) $(ENV) install-library;) \
+ done; \
fi;
- if test -f $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); then \
- rm -rf $(SRCROOT)/icuSources/$(INSTALLED_DYLIB); \
- fi;
+
+clean :
+ -rm -rf $(OBJROOT)
+