X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rules%2Fdistdir-way-opts.mk;h=5fd825361ec9154026a1ecba1c203b6c50ee7093;hb=7fc01c4671980ea3c66d549c0ece4d82fd3f5ade;hp=ac7c0d8dcdf95bfff18f6296ff2c301b87dd0d96;hpb=01d63b084d9115746772876e54edacd82028d35c;p=ghc-hetmet.git diff --git a/rules/distdir-way-opts.mk b/rules/distdir-way-opts.mk index ac7c0d8..5fd8253 100644 --- a/rules/distdir-way-opts.mk +++ b/rules/distdir-way-opts.mk @@ -77,12 +77,20 @@ endif # We have to do this mangling using the shell, because words may contain # spaces and GNU make doesn't have any quoting interpretation. -ifneq ($(strip $($1_$2_DEP_INCLUDE_DIRS)),) +ifneq ($$(strip $$($1_$2_DEP_INCLUDE_DIRS)),) $1_$2_CC_INC_FLAGS:=$$(shell for i in $$($1_$2_DEP_INCLUDE_DIRS); do echo $$($1_$2_DEP_INCLUDE_DIRS_FLAG)\"$$$$i\"; done) endif +# The CONF_CC_OPTS_STAGE$4 options are what we use to get gcc to +# behave correctly, but they are specific to the gcc that we are using. +# If GHC is compiling C code then it will take care of that for us, +# and in the case of the stage 0 compiler it may be using a different +# gcc, so we don't want to use our gcc-specific options. +$1_$2_DIST_GCC_CC_OPTS = \ + $$(CONF_CC_OPTS_STAGE$4) \ + $$($1_$2_DIST_CC_OPTS) + $1_$2_DIST_CC_OPTS = \ - $$(CONF_CC_OPTS) \ $$(SRC_CC_OPTS) \ $$($1_CC_OPTS) \ $$(foreach dir,$$(filter-out /%,$$($1_$2_INCLUDE_DIRS)),-I$1/$$(dir)) \ @@ -92,12 +100,12 @@ $1_$2_DIST_CC_OPTS = \ $$($1_$2_CC_INC_FLAGS) \ $$($1_$2_DEP_CC_OPTS) -ifneq ($(strip $($1_$2_DEP_LIB_DIRS)),) +ifneq ($$(strip $$($1_$2_DEP_LIB_DIRS)),) $1_$2_DIST_LD_LIB_DIRS:=$$(shell for i in $$($1_$2_DEP_LIB_DIRS); do echo \"-L$$$$i\"; done) endif $1_$2_DIST_LD_OPTS = \ - $$(CONF_LD_OPTS) \ + $$(CONF_LD_OPTS_STAGE$4) \ $$(SRC_LD_OPTS) \ $$($1_LD_OPTS) \ $$($1_$2_LD_OPTS) \ @@ -108,10 +116,10 @@ $1_$2_DIST_LD_OPTS = \ # c.f. Cabal's Distribution.Simple.PreProcess.ppHsc2hs # We use '' around cflags and lflags to handle paths with backslashes in # on Windows -ifneq ($(strip $($1_$2_DIST_CC_OPTS)),) -$1_$2_$3_HSC2HS_CC_OPTS:=$$(shell for i in $$($1_$2_DIST_CC_OPTS); do echo \'--cflag=$$$$i\'; done) +ifneq ($$(strip $$($1_$2_DIST_GCC_CC_OPTS)),) +$1_$2_$3_HSC2HS_CC_OPTS:=$$(shell for i in $$($1_$2_DIST_GCC_CC_OPTS); do echo \'--cflag=$$$$i\'; done) endif -ifneq ($(strip $($1_$2_DIST_LD_OPTS)),) +ifneq ($$(strip $$($1_$2_DIST_LD_OPTS)),) $1_$2_$3_HSC2HS_LD_OPTS:=$$(shell for i in $$($1_$2_DIST_LD_OPTS); do echo \'--lflag=$$$$i\'; done) endif @@ -129,13 +137,18 @@ $1_$2_$3_ALL_HSC2HS_OPTS = \ $1_$2_$3_ALL_CC_OPTS = \ $$(WAY_$3_CC_OPTS) \ - $$($1_$2_DIST_CC_OPTS) \ + $$($1_$2_DIST_GCC_CC_OPTS) \ $$($1_$2_$3_CC_OPTS) \ $$($$(basename $$<)_CC_OPTS) \ $$(EXTRA_CC_OPTS) $1_$2_$3_GHC_CC_OPTS = \ - $$(addprefix -optc, $$($1_$2_$3_ALL_CC_OPTS)) \ + $$(addprefix -optc, \ + $$(WAY_$3_CC_OPTS) \ + $$($1_$2_DIST_CC_OPTS) \ + $$($1_$2_$3_CC_OPTS) \ + $$($$(basename $$<)_CC_OPTS) \ + $$(EXTRA_CC_OPTS)) \ $$($1_$2_$3_MOST_HC_OPTS) $1_$2_$3_ALL_AS_OPTS = \