X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/b75a7d8f3b4adbae880cab104ce2c6a50eee4db2..729e4ab9bc6618bc3d8a898e575df7f4019e29ca:/icuSources/config/mh-hpux-acc diff --git a/icuSources/config/mh-hpux-acc b/icuSources/config/mh-hpux-acc index e94ca432..ab935965 100644 --- a/icuSources/config/mh-hpux-acc +++ b/icuSources/config/mh-hpux-acc @@ -1,27 +1,53 @@ ## -*-makefile-*- ## HP/UX-specific setup using aCC -## Copyright (c) 1999-2003, International Business Machines Corporation and +## Copyright (c) 1999-2010, International Business Machines Corporation and ## others. All Rights Reserved. -## -## $Id: mh-hpux-acc,v 1.1.1.2 2003/07/03 18:13:33 avery Exp $ ## Commands to generate dependency files GEN_DEPS.c= : GEN_DEPS.cc= : ## Flags for position independent code -SHAREDLIBCFLAGS = +z -SHAREDLIBCXXFLAGS = +z +SHAREDLIBCFLAGS = +Z +SHAREDLIBCXXFLAGS = +Z + +## Additional flags when building libraries with threads +## We use this instead of -mt, which isn't available in all versions of aCC +## Our tools won't compile with -D_POSIX_C_SOURCE=199506L +THREADSCPPFLAGS = -D_REENTRANT -D_THREAD_SAFE # Use Extended ANSI mode, which is useful for 64-bit numbers -# +Olibcalls uses intrinsic functions for strlen and others # +W ignores some warnings -# 495 The linkage directive is ignored for an object or function... # 740 Unsafe cast between pointers/references to incomplete classes... # 749 This operation is non-portable and potentially unsafe. # (Ironically the solution to fix this warning is non-portable) -CFLAGS += +Olibcalls -Ae +ESlit -CXXFLAGS += +Olibcalls +W495 +W740 +W749 +# 823 Redundant preprocessing concatenation operation results in two valid +# preprocessing tokens. This comes from INT64_C in +# 4232 conversion to a more strictly aligned type may cause misaligned access. +CFLAGS += -Ae +Olit=all +CXXFLAGS += -Wc,-ansi_for_scope,on +W740 +W749 +W823 +W4232 + +ifeq ($(UCLN_NO_AUTO_CLEANUP),0) +# set up init point. +UCLN_FINI = ucln_fini$(TARGET_STUBNAME)_$(SO_TARGET_VERSION_MAJOR)$(ICULIBSUFFIXCNAME) +CPPFLAGS_FINI = -DUCLN_FINI=$(UCLN_FINI) +LDFLAGS_FINI = -Wl,+fini,$(UCLN_FINI) + +CPPFLAGSICUUC += $(CPPFLAGS_FINI) +LDFLAGSICUUC += $(LDFLAGS_FINI) +CPPFLAGSICUIO += $(CPPFLAGS_FINI) +LDFLAGSICUIO += $(LDFLAGS_FINI) +CPPFLAGSICUI18N += $(CPPFLAGS_FINI) +LDFLAGSICUI18N += $(LDFLAGS_FINI) +CPPFLAGSCTESTFW += $(CPPFLAGS_FINI) +LDFLAGSCTESTFW += $(LDFLAGS_FINI) + +# ICUUC, ICUIO, ICUI18N, CTESTFW +endif + +# -Bhidden_def Hides all symbols defined in the module. +#LIBCFLAGS = -Bhidden_def +#LIBCXXFLAGS = -Bhidden_def ## Commands to compile COMPILE.c= $(CC) $(DEFS) $(CPPFLAGS) $(CFLAGS) -c @@ -29,7 +55,7 @@ COMPILE.cc= $(CXX) $(DEFS) $(CPPFLAGS) $(CXXFLAGS) -c ## Common 'default' path to ensure the sanity of users. Search the current ## directory, at least. -LD_DEFAULTPATH= -Wl,+b,.:'$$'ORIGIN/ +LD_DEFAULTPATH= -Wl,+b,'$$'ORIGIN/ # Use SHLIB_PATH and LD_LIBRARY_PATH to locate shared libraries LDFLAGS += -Wl,+s $(LD_DEFAULTPATH) @@ -39,10 +65,19 @@ LDFLAGS += -Wl,+s $(LD_DEFAULTPATH) LINK.c= $(CXX) $(CXXFLAGS) $(LDFLAGS) LINK.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) +## Shared library options +## HPUX PA-risc does not recognize -Bprotected_def aC++ option. +## Use linker option -Wl,-B,symbolic instead. +ifeq ($(shell uname -m),ia64) + LD_SOOPTIONS= -Bprotected_def +else + LD_SOOPTIONS= -Wl,-B,symbolic +endif + ## Commands to make a shared library #SHLIB.c= $(LD) $(LDFLAGS) -b -SHLIB.c= $(CXX) $(CXXFLAGS) $(LDFLAGS) -b -SHLIB.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) -b +SHLIB.c= $(CXX) $(CXXFLAGS) $(LDFLAGS) -b $(LD_SOOPTIONS) +SHLIB.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) -b $(LD_SOOPTIONS) ## Compiler switch to embed a runtime search path LD_RPATH= -Wl,+b, @@ -52,7 +87,11 @@ LD_RPATH_PRE= LDLIBRARYPATH_ENVVAR = SHLIB_PATH ## Compiler switch to embed a library name -LD_SONAME = -Wl,+h,$(MIDDLE_SO_TARGET) +LD_SONAME = -Wl,+h,$(notdir $(MIDDLE_SO_TARGET)) + +## The type of assembly needed when pkgdata is used for generating shared libraries. +# Commented out for now because the hp1 test machine runs out of memory. +#GENCCODE_ASSEMBLY=-a aCC-parisc ## Shared object suffix SO= sl @@ -70,8 +109,6 @@ STATIC_O = o %.o: $(srcdir)/%.cpp $(COMPILE.cc) $(DYNAMICCPPFLAGS) $(DYNAMICCXXFLAGS) -o $@ $< -../data/%.o: ../data/%.c - $(COMPILE.c) $(DYNAMICCPPFLAGS) $(DYNAMICCFLAGS) -o $@ $< ## Dependency rules %.d : $(srcdir)/%.c @@ -85,11 +122,15 @@ STATIC_O = o ## Versioned libraries rules %.$(SO).$(SO_TARGET_VERSION_MAJOR): %.$(SO).$(SO_TARGET_VERSION) - $(RM) $@ && ln -s $< $@ + $(RM) $@ && ln -s ${