X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fdriver%2FMakefile;h=3a87ab43c504f2d30569176e29305e17e092e069;hb=e6218fe7eff4e34e1a3c823cd4b7aebe09d2d4fb;hp=3245addacf6f2dcec3540c83748642aaa1a53cc9;hpb=cd3d16fee2b09994a3a3f5d57eaf70432785ae4d;p=ghc-hetmet.git diff --git a/ghc/driver/Makefile b/ghc/driver/Makefile index 3245add..3a87ab4 100644 --- a/ghc/driver/Makefile +++ b/ghc/driver/Makefile @@ -1,143 +1,28 @@ -#----------------------------------------------------------------------------- -# $Id: Makefile,v 1.33 2000/06/14 10:27:07 simonmar Exp $ +# -----------------------------------------------------------------------------= +# $Id: Makefile,v 1.76 2005/03/02 09:49:11 simonmar Exp $ +# +# (c) The University of Glasgow 2002 # TOP=.. -CURRENT_DIR=ghc/driver include $(TOP)/mk/boilerplate.mk -ifneq "$(GhcWithHscBuiltViaC)" "YES" -HC=$(WithGhcHc) -else -HC=$(GHC_INPLACE) -endif - -SRC_HC_OPTS += -fglasgow-exts -cpp -syslib concurrent -syslib posix -syslib text - -HS_PROG = ghc-$(ProjectVersion) -HS_SRCS = Config.hs Package.hs Main.hs -MKDEPENDHS_SRCS = Config.hs Main.hs PackageSrc.hs -LINK = ghc - -SUBDIRS = mangler split stats - -# we need the driver for generating dependencies... -boot :: all - -# ----------------------------------------------------------------------------- -# Create driver configuration - -boot :: Config.hs - -Config.hs : $(FPTOOLS_TOP)/mk/config.mk Makefile - @$(RM) -f Config.hs - @echo -n "Creating Config.hs ... " - @echo "module Config where" >>Config.hs - @echo "_ProjectName = \"$(ProjectName)\"" >> Config.hs - @echo "_ProjectVersion = \"$(ProjectVersion)\"" >> Config.hs - @echo "_ProjectVersionInt = \"$(ProjectVersionInt)\"" >> Config.hs - @echo "_ProjectPatchLevel = \"$(ProjectPatchLevel)\"" >> Config.hs - @echo "_HOSTPLATFORM = \"$(HOSTPLATFORM)\"" >> Config.hs - @echo "_TARGETPLATFORM = \"$(TARGETPLATFORM)\"" >> Config.hs - @echo "_CURRENT_DIR = \"$(CURRENT_DIR)\"" >> Config.hs - @echo "_GHC_LIB_DIR = \"$(GHC_LIB_DIR)\"" >> Config.hs - @echo "_GHC_RUNTIME_DIR = \"$(GHC_RUNTIME_DIR)\"" >> Config.hs - @echo "_GHC_UTILS_DIR = \"$(GHC_UTILS_DIR)\"" >> Config.hs - @echo "_GHC_INCLUDE_DIR = \"$(GHC_INCLUDE_DIR)\"" >> Config.hs - @echo "_GHC_DRIVER_DIR = \"$(GHC_DRIVER_DIR)\"" >> Config.hs - @echo "_GCC = \"$(WhatGccIsCalled)\"" >> Config.hs - @echo "_GhcWithNativeCodeGen = \"$(GhcWithNativeCodeGen)\"" >> Config.hs - @echo "_LeadingUnderscore = \"$(LeadingUnderscore)\"" >> Config.hs - @echo "_GHC_MKDEPENDHS = \"$(GHC_MKDEPENDHS)\"" >> Config.hs - @echo "_GHC_UNLIT = \"$(GHC_UNLIT)\"" >> Config.hs - @echo "_GHC_HSCPP = \"$(GHC_HSCPP)\"" >> Config.hs - @echo "_GHC_HSC = \"$(GHC_HSC)\"" >> Config.hs - @echo "_GHC_MANGLER = \"$(GHC_MANGLER)\"" >> Config.hs - @echo "_GHC_SPLIT = \"$(GHC_SPLIT)\"" >> Config.hs - @echo "_GHC_STATS = \"$(GHC_STATS)\"" >> Config.hs - @echo "_GHC_SYSMAN = \"$(GHC_SYSMAN)\"" >> Config.hs - @echo "_EnableWin32DLLs = \"$(EnableWin32DLLs)\"" >> Config.hs - @echo "_CP = \"$(CP)\"" >> Config.hs - @echo "_RM = \"$(RM)\"" >> Config.hs - @echo "_CONTEXT_DIFF = \"$(CONTEXT_DIFF)\"" >> Config.hs - @echo "_HaveLibGmp = \"$(HaveLibGmp)\"" >> Config.hs - @echo "_GhcWithRegisterised = \"$(GhcWithRegisterised)\"" >> Config.hs - @echo "_USER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> Config.hs - @echo "_USER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> Config.hs - @echo "_libdir = \"$(libdir)\"" >> Config.hs - @echo "_libexecdir = \"$(libexecdir)\"" >> Config.hs - @echo "_datadir = \"$(datadir)\"" >> Config.hs - @echo "_bindir = \"$(bindir)\"" >> Config.hs - @echo "_TMPDIR = \"$(TMPDIR)\"" >> Config.hs - @echo "_FPTOOLS_TOP_ABS = \"$(FPTOOLS_TOP_ABS)\"" >> Config.hs - @echo done. - -CLEAN_FILES += Config.hs - -# ----------------------------------------------------------------------------- -# create ghc-inplace, a convenient way to run ghc from the build tree... - -all :: ghc-inplace +SUBDIRS = mangler split ghc ghci -ghc-inplace : ghc - @$(RM) $@ - echo '#!/bin/sh' >>$@ - echo exec $(FPTOOLS_TOP_ABS)/ghc/driver/ghc -B$(FPTOOLS_TOP_ABS) $$\* >>$@ - chmod 755 $@ +boot all :: package.conf.inplace package.conf -# ----------------------------------------------------------------------------- -# package configuration files... +package.conf.inplace : + echo "[]" > $@ -all :: package.conf package.conf.inplace +package.conf : + echo "[]" > $@ -pkgconf : Config.o Package.o PackageSrc.o - $(HC) $(HC_OPTS) $(LD_OPTS) Config.o Package.o PackageSrc.o -o pkgconf +override datadir = $(libdir) +INSTALL_DATAS += package.conf ghc-usage.txt ghci-usage.txt -package.conf.inplace : pkgconf - ./pkgconf in-place >$@ - -package.conf : pkgconf - ./pkgconf install >$@ - -INSTALL_DATAS += package.conf - -CLEAN_FILES += pkgconf package.conf.inplace package.conf - -# ----------------------------------------------------------------------------- -# installation... - -INSTALL_PROGS = ghc-$(ProjectVersion) - -override datadir=$(libdir) -INSTALL_DATAS += ghc-usage.txt - -# ----------------------------------------------------------------------------- +# Since cleaning effectively uninstalls all the packages, we must +# remove the stamp files that the build system uses to avoid unnecessarily +# re-installing packages. +CLEAN_FILES += package.conf* stamp-pkg-conf* include $(TOP)/mk/target.mk - -# ----------------------------------------------------------------------------- -# Create link to from ghc-x.xx to ghc... - -all :: $(LINK) - -$(LINK) : $(HS_PROG) - @if ( $(PERL) -e '$$fn="$(LINK)"; exit ((! -f $$fn || -l $$fn) ? 0 : 1);' ); then \ - echo "Creating a symbolic link from $(HS_PROG) to $(LINK)"; \ - $(RM) $(LINK); \ - $(LN_S) $(HS_PROG) $(LINK); \ - else \ - echo "Creating a symbolic link from $(HS_PROG) to $(LINK) failed: \`$(LINK)' already exists"; \ - echo "Perhaps remove \`$(LINK)' manually?"; \ - exit 1; \ - fi; - -install :: - @if ( $(PERL) -e '$$fn="$(bindir)/$(LINK)"; exit ((! -f $$fn || -l $$fn) ? 0 : 1);' ); then \ - echo "Creating a symbol link from $(HS_PROG) to $(LINK) in $(bindir)"; \ - $(RM) $(bindir)/$(LINK); \ - $(LN_S) $(HS_PROG) $(bindir)/$(LINK); \ - else \ - echo "Creating a symbol link from $(HS_PROG) to $(LINK) in $(bindir) failed: \`$(bindir)/$(LINK)' already exists"; \ - echo "Perhaps remove \`$(bindir)/$(LINK)' manually?"; \ - exit 1; \ - fi;