diff options
Diffstat (limited to 'ghc/ghc.mk')
-rw-r--r-- | ghc/ghc.mk | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/ghc/ghc.mk b/ghc/ghc.mk new file mode 100644 index 0000000000..7f9c630771 --- /dev/null +++ b/ghc/ghc.mk @@ -0,0 +1,127 @@ +# ToDo +ghc_USES_CABAL = NO +# ghc_PACKAGE = ghc-bin + +ghc_stage1_HC_OPTS = $(GhcStage1HcOpts) +ghc_stage2_HC_OPTS = $(GhcStage2HcOpts) +ghc_stage3_HC_OPTS = $(GhcStage3HcOpts) + +ifeq "$(GhcWithInterpreter)" "YES" +ghc_stage2_HC_OPTS += -DGHCI +ghc_stage3_HC_OPTS += -DGHCI +endif + +ifeq "$(GhcDebugged)" "YES" +ghc_HC_OPTS += -debug +endif + +ifeq "$(GhcThreaded)" "YES" +# Use threaded RTS with GHCi, so threads don't get blocked at the prompt. +ghc_HC_OPTS += -threaded +endif + +ifeq "$(BuildSharedLibs)" "YES" +ghc_HC_OPTS += -dynamic +endif + +# XXX ToDp +# ifeq "$(GhcProfiled)" "YES" + +ghc_stage1_MODULES = Main + +ghc_stage2_MODULES = $(ghc_stage1_MODULES) +ghc_stage3_MODULES = $(ghc_stage1_MODULES) + +ghc_stage1_PROG = ghc-stage1$(exeext) +ghc_stage2_PROG = ghc-stage2$(exeext) +ghc_stage3_PROG = ghc-stage3$(exeext) + +# ToDo: perhaps use ghc-cabal to configure ghc-bin +ghc_stage1_USE_BOOT_LIBS = YES +ghc_stage1_HC_OPTS += -package $(compiler_PACKAGE)-$(compiler_stage1_VERSION) +ghc_stage2_HC_OPTS += -package $(compiler_PACKAGE)-$(compiler_stage2_VERSION) +ghc_stage3_HC_OPTS += -package $(compiler_PACKAGE)-$(compiler_stage3_VERSION) + +ghc_stage1_HC_OPTS += -XCPP -XPatternGuards +ghc_stage2_HC_OPTS += -XCPP -XPatternGuards +ghc_stage3_HC_OPTS += -XCPP -XPatternGuards + +# In stage1 we might not benefit from cross-package dependencies and +# recompilation checking. We must force recompilation here, otherwise +# Main.o won't necessarily be rebuilt when the ghc package has changed: +ghc_stage1_HC_OPTS += -fforce-recomp + +# Further dependencies we need only in stage 1, due to no +# cross-package dependencies or recompilation checking. +ghc/stage1/build/Main.o : $(compiler_stage1_v_LIB) + +ghc_stage1_SHELL_WRAPPER = YES +ghc_stage2_SHELL_WRAPPER = YES +ghc_stage3_SHELL_WRAPPER = YES +ghc_stage1_SHELL_WRAPPER_NAME = ghc/ghc.wrapper +ghc_stage2_SHELL_WRAPPER_NAME = ghc/ghc.wrapper +ghc_stage3_SHELL_WRAPPER_NAME = ghc/ghc.wrapper + +ghc_stage$(INSTALL_GHC_STAGE)_INSTALL_SHELL_WRAPPER = YES +ghc_stage$(INSTALL_GHC_STAGE)_INSTALL_SHELL_WRAPPER_NAME = ghc-$(ProjectVersion) + +# stage 1 is enabled unless $(stage) is set to something other than 1 +ifeq "$(filter-out 1,$(stage))" "" +$(eval $(call build-prog,ghc,stage1,0)) +endif + +# stage 2 is enabled unless $(stage) is set to something other than 2 +ifeq "$(filter-out 2,$(stage))" "" +$(eval $(call build-prog,ghc,stage2,1)) +endif + +# stage 3 has to be requested explicitly with stage=3 +ifeq "$(stage)" "3" +$(eval $(call build-prog,ghc,stage3,2)) +endif + +ifneq "$(BINDIST)" "YES" + +# ToDo: should we add these in the build-prog macro? +ghc/stage1/build/tmp/$(ghc_stage1_PROG) : $(compiler_stage1_v_LIB) +ghc/stage2/build/tmp/$(ghc_stage2_PROG) : $(compiler_stage2_v_LIB) +ghc/stage3/build/tmp/$(ghc_stage3_PROG) : $(compiler_stage3_v_LIB) + +all_ghc_stage1 : $(GHC_STAGE1) +all_ghc_stage2 : $(GHC_STAGE2) +all_ghc_stage3 : $(GHC_STAGE3) + +$(INPLACE_LIB)/extra-gcc-opts : extra-gcc-opts + $(CP) $< $@ + +# The GHC programs need to depend on all the helper programs they might call +$(GHC_STAGE1) : $(INPLACE_LIB)/extra-gcc-opts $(MANGLER) $(SPLIT) +$(GHC_STAGE2) : $(INPLACE_LIB)/extra-gcc-opts $(MANGLER) $(SPLIT) +$(GHC_STAGE3) : $(INPLACE_LIB)/extra-gcc-opts $(MANGLER) $(SPLIT) + +ifeq "$(Windows)" "YES" +$(GHC_STAGE1) : $(TOUCHY) $(INPLACE)/stamp-mingw $(INPLACE_LIB)/perl.exe +$(GHC_STAGE2) : $(TOUCHY) $(INPLACE)/stamp-mingw $(INPLACE_LIB)/perl.exe +$(GHC_STAGE3) : $(TOUCHY) $(INPLACE)/stamp-mingw $(INPLACE_LIB)/perl.exe +endif + +endif + +INSTALL_LIBS += extra-gcc-opts + +ifeq "$(Windows)" "NO" +install: install_ghc_link +.PNONY: install_ghc_link +install_ghc_link: + $(RM) -f $(DESTDIR)$(bindir)/ghc + $(LN_S) ghc-$(ProjectVersion) $(DESTDIR)$(bindir)/ghc +else +# On Windows we install the main binary as $(bindir)/ghc.exe +# To get ghc-<version>.exe we have a little C program in driver/ghc +install: install_ghc_post +.PHONY: install_ghc_post +install_ghc_post: install_bins + $(RM) -f $(DESTDIR)$(bindir)/ghc.exe + $(MV) -f $(DESTDIR)$(bindir)/ghc-stage$(INSTALL_GHC_STAGE).exe $(DESTDIR)$(bindir)/ghc.exe +endif + |