X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fdriver%2FMakefile;h=d6571ec632c5aa36e6c20765110f0d73517f4c05;hb=292c077de7dbe98eb44911648f16e243b40db2ac;hp=7c65e00fccd80c87398c97be05a87ce82707c271;hpb=7a5e524c04975bfada27e3395f7bc4f7746f54f0;p=ghc-hetmet.git diff --git a/ghc/driver/Makefile b/ghc/driver/Makefile index 7c65e00..d6571ec 100644 --- a/ghc/driver/Makefile +++ b/ghc/driver/Makefile @@ -1,115 +1,157 @@ #----------------------------------------------------------------------------- -# $Id: Makefile,v 1.31 2000/05/25 13:11:17 panne Exp $ - -# We create two driver scripts: -# - one to run in-place in the build tree for building libraries -# - one wired to the install locations for later installation +# $Id: Makefile,v 1.45 2000/11/07 10:42:56 simonmar Exp $ # -# the installation script is built first, and we invoke make recursively -# to build the in-place version. TOP=.. CURRENT_DIR=ghc/driver include $(TOP)/mk/boilerplate.mk -INSTALLING=1 - -DYN_LOADABLE_BITS = \ - ghc-asm.prl \ - ghc-consist.prl \ - ghc-split.prl - -INSTALLED_SCRIPT_PROG = ghc-$(ProjectVersion) -INPLACE_SCRIPT_PROG = ghc-inplace - -ifeq "$(INSTALLING)" "1" -TOP_PWD := $(prefix) -SCRIPT_PROG = $(INSTALLED_SCRIPT_PROG) -SCRIPT_LINK = ghc -else -TOP_PWD := $(FPTOOLS_TOP_ABS) -SCRIPT_PROG = $(INPLACE_SCRIPT_PROG) +ifeq "$(GhcWithHscBuiltViaC)" "YES" +HC=$(GHC_INPLACE) endif -SCRIPT_OBJS = ghc.prl - -INTERP=perl - -# -# The driver needs to know the options and names for -# all possible ways, so we magically generate the -# the make variable names for them here. -# - -USER_WAY_NAMES = $(foreach way,$(USER_WAYS),WAY_$(way)_NAME) -USER_WAY_OPTS = $(foreach way,$(USER_WAYS),WAY_$(way)_REAL_OPTS) - -SCRIPT_SUBST_VARS := \ - INSTALLING \ - ProjectName ProjectVersion ProjectVersionInt \ - HscMajorVersion HscMinorVersion CcMajorVersion CcMinorVersion \ - CURRENT_DIR HOSTPLATFORM TARGETPLATFORM \ - GHC_LIB_DIR GHC_RUNTIME_DIR GHC_INCLUDE_DIR \ - GHC_OPT_HILEV_ASM GhcWithNativeCodeGen LeadingUnderscore\ - GHC_UNLIT GHC_HSCPP GHC_MKDEPENDHS GHC_HSC GHC_SYSMAN EnableWin32DLLs \ - CP RM CONTEXT_DIFF LibGmp GhcWithRegisterised LibsReadline \ - $(USER_WAY_NAMES) $(USER_WAY_OPTS) - -# -# When creating a binary distribution, we prefix the driver script -# with a short msg about what variables need to be set to get the -# script going. -# - -ifeq "$(BIN_DIST)" "1" -SCRIPT_PREFIX_FILES=prefix.txt +ghc_407_at_least = $(shell expr "$(GhcMinVersion)" \>= 7) +ifeq "$(ghc_407_at_least)" "1" +ifneq "$(mingw32_TARGET_OS)" "1" +SRC_HC_OPTS += -fglasgow-exts -cpp -package concurrent -package posix -package text else -SCRIPT_SUBST_VARS += libdir includedir libexecdir datadir bindir TMPDIR TOP_PWD +SRC_HC_OPTS += -fglasgow-exts -cpp -package concurrent -package text endif - -all :: $(DYN_LOADABLE_BITS) - -# don't recurse on 'make install' -# -ifeq "$(INSTALLING)" "1" -all clean distclean mostlyclean maintainer-clean :: - $(MAKE) INSTALLING=0 BIN_DIST=0 $(MFLAGS) $@ +else +SRC_HC_OPTS += -fglasgow-exts -cpp -syslib concurrent -syslib posix -syslib misc endif -# -# Install setup: -# the driver goes in $(bindir), the perl script helpers -# in $(libdir) -# -# ToDo: allow different install name for driver? -# -INSTALL_SCRIPTS += $(SCRIPT_PROG) -INSTALL_LIBS += $(DYN_LOADABLE_BITS) - -# -# depend setup: other directories need the driver script to compute -# their dependencies, so `depend' is simply an alias for `all' here. -depend :: all - -# -# Clean up -# -CLEAN_FILES += $(SCRIPT_OBJS) $(SCRIPT_LINK) $(DYN_LOADABLE_BITS) ghc-[0-9].* - -# -# Source distribution -# -SRC_DEST_FILES=$(patsubst %.prl,%.lprl,$(DYN_LOADABLE_BITS)) ghc.lprl ordering-passes test_mangler +HS_PROG = ghc-$(ProjectVersion) +HS_SRCS = Config.hs Package.hs GetImports.hs Main.hs Utils.hs +MKDEPENDHS_SRCS = Config.hs Main.hs GetImports.hs PackageSrc.hs Utils.hs +LINK = ghc + +SUBDIRS = mangler split stats + +# ----------------------------------------------------------------------------- +# 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 "cProjectName = \"$(ProjectName)\"" >> Config.hs + @echo "cProjectVersion = \"$(ProjectVersion)\"" >> Config.hs + @echo "cProjectVersionInt = \"$(ProjectVersionInt)\"" >> Config.hs + @echo "cHscIfaceFileVersion = \"$(HscIfaceFileVersion)\"" >> Config.hs + @echo "cHOSTPLATFORM = \"$(HOSTPLATFORM)\"" >> Config.hs + @echo "cTARGETPLATFORM = \"$(TARGETPLATFORM)\"" >> Config.hs + @echo "cCURRENT_DIR = \"$(CURRENT_DIR)\"" >> Config.hs + @echo "cGHC_LIB_DIR = \"$(GHC_LIB_DIR)\"" >> Config.hs + @echo "cGHC_RUNTIME_DIR = \"$(GHC_RUNTIME_DIR)\"" >> Config.hs + @echo "cGHC_UTILS_DIR = \"$(GHC_UTILS_DIR)\"" >> Config.hs + @echo "cGHC_INCLUDE_DIR = \"$(GHC_INCLUDE_DIR)\"" >> Config.hs + @echo "cGHC_DRIVER_DIR = \"$(GHC_DRIVER_DIR)\"" >> Config.hs + @echo "cGCC = \"$(WhatGccIsCalled)\"" >> Config.hs + @echo "cGhcWithNativeCodeGen = \"$(GhcWithNativeCodeGen)\"" >> Config.hs + @echo "cLeadingUnderscore = \"$(LeadingUnderscore)\"" >> Config.hs + @echo "cGHC_UNLIT = \"$(GHC_UNLIT)\"" >> Config.hs + @echo "cGHC_HSC = \"$(GHC_HSC)\"" >> Config.hs + @echo "cGHC_MANGLER = \"$(GHC_MANGLER)\"" >> Config.hs + @echo "cGHC_SPLIT = \"$(GHC_SPLIT)\"" >> Config.hs + @echo "cGHC_STATS = \"$(GHC_STATS)\"" >> Config.hs + @echo "cGHC_SYSMAN = \"$(GHC_SYSMAN)\"" >> Config.hs + @echo "cDLLized = \"$(DLLized)\"" >> Config.hs + @echo "cCP = \"$(CP)\"" >> Config.hs + @echo "cRM = \"$(RM)\"" >> Config.hs + @echo "cCONTEXT_DIFF = \"$(CONTEXT_DIFF)\"" >> Config.hs + @echo "cHaveLibGmp = \"$(HaveLibGmp)\"" >> Config.hs + @echo "cGhcWithRegisterised = \"$(GhcWithRegisterised)\"" >> Config.hs + @echo "cUSER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> Config.hs + @echo "cUSER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> Config.hs + @echo "clibdir = \"$(libdir)\"" >> Config.hs + @echo "clibexecdir = \"$(libexecdir)\"" >> Config.hs + @echo "cdatadir = \"$(datadir)\"" >> Config.hs + @echo "cbindir = \"$(bindir)\"" >> Config.hs + @echo "cDEFAULT_TMPDIR = \"$(DEFAULT_TMPDIR)\"" >> Config.hs + @echo "cFPTOOLS_TOP_ABS = \"$(FPTOOLS_TOP_ABS)\"" >> Config.hs + @echo "cRAWCPP = \"$(RAWCPP)\"" >> Config.hs + @echo done. + +CLEAN_FILES += Config.hs + +# ----------------------------------------------------------------------------- +# create ghc-inplace, a convenient way to run ghc from the build tree... + +all :: ghc-inplace + +ghc-inplace : ghc + @$(RM) $@ + echo '#!/bin/sh' >>$@ + echo exec $(FPTOOLS_TOP_ABS)/ghc/driver/ghc -B$(FPTOOLS_TOP_ABS) '"$$@"' >>$@ + chmod 755 $@ + +CLEAN_FILES += ghc-inplace + +# ----------------------------------------------------------------------------- +# package configuration files... + +all :: package.conf package.conf.inplace + +pkgconf : Config.o Package.o PackageSrc.o Utils.o + $(HC) $(HC_OPTS) $(LD_OPTS) Config.o Package.o PackageSrc.o Utils.o -o pkgconf + +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 + +# ----------------------------------------------------------------------------- include $(TOP)/mk/target.mk -ghc.prl : $(TOP)/mk/version.mk - -# -# Another hack (hmm..I can see a pattern developing here :-) -# In ghc/driver, we create a symlink from ghc- to -# ghc, but we don't want this included in a source distribution. -# We `solve' this by removing `ghc' from the dist tree here. -dist :: - @echo "Patching dist tree: removing $(SRC_DIST_DIR)/ghc symlink" - $(RM) $(SRC_DIST_DIR)/ghc +# We need the driver for generating dependencies... so build it as +# part of make boot. We need to do this using a recursive invocation +# of $(MAKE), so that dependencies we just generated for the driver +# itself are picked up. +boot :: + $(MAKE) $(MFLAGS) all + +# ----------------------------------------------------------------------------- +# 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; + +CLEAN_FILES += $(LINK) + +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;