summaryrefslogtreecommitdiff
path: root/include/makeinclude/wrapper_macros.GNU
diff options
context:
space:
mode:
Diffstat (limited to 'include/makeinclude/wrapper_macros.GNU')
-rw-r--r--include/makeinclude/wrapper_macros.GNU52
1 files changed, 32 insertions, 20 deletions
diff --git a/include/makeinclude/wrapper_macros.GNU b/include/makeinclude/wrapper_macros.GNU
index 25f62805c73..e2d019c7b19 100644
--- a/include/makeinclude/wrapper_macros.GNU
+++ b/include/makeinclude/wrapper_macros.GNU
@@ -54,6 +54,10 @@
#
# Variable Description
# -------- -----------
+# ACE_HAS_GNUG_PRE_2_8 CXX includes "g++", and the g++ version is
+# prior to 2.8.0. This is automatically determined
+# below, but can be overridden in the user's
+# platform_macros.GNU or environment.
# ARFLAGS Flags for the archive utility (ar)
# CC C compiler command
# CXX C++ compiler command
@@ -159,10 +163,10 @@ RM = /bin/rm
VAR =
VDIR = .obj/
ifndef ACELIB
-ACELIB = -lACE
+ ACELIB = -lACE
endif
-ifndef VSHDIR
-VSHDIR = .shobj/
+ifndef VSHDIR
+ VSHDIR = .shobj/
endif # VSHDIR
# NOTE: VLDLIBS is defined below, in case it is overridden for static-
# or shared-only builds.
@@ -177,6 +181,26 @@ else
endif
#----------------------------------------------------------------------------
+# Platform-dependent macros that require platform_macros.GNU.
+#----------------------------------------------------------------------------
+
+ifeq ($(findstring g++,$(CXX)),g++)
+ ifndef ACE_HAS_GNUG_PRE_2_8
+ ifeq ($(CXX),g++)
+ ACE_HAS_GNUG_PRE_2_8 := \
+ $(shell \
+ if $(CXX) --version | egrep '^(cygnus-)?2\.[0-7]' > /dev/null; then \
+ echo 1; else echo 0; fi)
+ else # ! plain g++
+ # CXX is something like g++386. Assume, for now, that it's an old g++.
+ ACE_HAS_GNUG_PRE_2_8 = 1
+ endif # ! plain g++
+ endif # ! ACE_HAS_GNUG_PRE_2_8
+else
+ ACE_HAS_GNUG_PRE_2_8 =
+endif # g++
+
+#----------------------------------------------------------------------------
# make flags
#----------------------------------------------------------------------------
@@ -217,23 +241,11 @@ endif # xt_reactor
ifdef exceptions
CPPFLAGS += -DACE_HAS_EXCEPTIONS
-else # ! exceptions
- ifeq ($(findstring g++,$(CXX)),g++)
- ifeq ($(CXX),g++)
- #### Disable the default exception handling of g++ >= 2.8.0.
- G++_HAS_EXCEPTIONS := \
- $(shell \
- if $(CXX) --version | egrep -v '^(cygnus-)?2\.[0-7]' > /dev/null; \
- then echo 1; fi)
- ifdef G++_HAS_EXCEPTIONS
- CCFLAGS += -fno-exceptions
- endif # G++_HAS_EXCEPTIONS
- # else, CXX is something like g++386. Assume that it doesn't
- # support exception handling. The shell command above won't
- # work if CXX isn't on the users PATH.
- endif # plain g++
- else
- endif # g++
+else # ! exceptions
+ ifeq ($(ACE_HAS_GNUG_PRE_2_8),0)
+ #### Disable the default exception handling of g++ >= 2.8.0.
+ CCFLAGS += -fno-exceptions
+ endif # ! ACE_HAS_GNUG_PRE_2_8
endif # ! exceptions
ifeq ($(profile),0)