X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=utils%2FMakefile;h=a6d39cca5d37cfefdc816698cb930b4a29b5312b;hb=ad773dac21ea6960293246e836e9a143249e4e11;hp=a6f5f9af2e3218ec0bdb592985a242037589373f;hpb=0fef954527222d451cb437bb28731f041a301289;p=ghc-hetmet.git diff --git a/utils/Makefile b/utils/Makefile index a6f5f9a..a6d39cc 100644 --- a/utils/Makefile +++ b/utils/Makefile @@ -1,26 +1,27 @@ TOP=.. include $(TOP)/mk/boilerplate.mk -ifeq "$(MAKING_BIN_DIST)" "1" +ifeq "$(DOING_BIN_DIST)" "YES" # We're doing a binary-dist, descend into a subset of the dirs. -SUBDIRS = hp2ps unlit +SUBDIRS = mkdirhier hp2ps parallel unlit else ifeq "$(BootingFromHc)" "YES" -SUBDIRS = mkdependC mkdirhier runstdtest genapply genprimopcode ghc-pkg unlit +SUBDIRS = mkdependC mkdirhier runstdtest genapply genprimopcode unlit else -SUBDIRS = mkdependC mkdirhier runstdtest ghc-pkg hasktags hp2ps hsc2hs \ - parallel prof unlit genprimopcode genapply runghc +SUBDIRS = mkdependC mkdirhier runstdtest hp2ps \ + parallel unlit genprimopcode genapply endif +#ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +## lndir doesn't build on Windows +#SUBDIRS += lndir +#endif endif ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" SUBDIRS += touchy endif -ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32" -# lndir doesn't build on Windows -SUBDIRS += lndir -endif +# XXX pwd and lndir building disabled for now # Utils that we don't build by default: # nofib-analyse @@ -41,6 +42,11 @@ endif # unlikely to want it desperately. It is easy to build once you have # a Haskell compiler and if you want it. +binary-dist: + $(INSTALL_DIR) $(BIN_DIST_DIR)/utils + $(INSTALL_DATA) Makefile $(BIN_DIST_DIR)/utils/ + set -e; for d in $(SUBDIRS); do $(MAKE) -C $$d binary-dist; done + include $(TOP)/mk/target.mk # genprimopcode is needed to boot in ghc/compiler... @@ -49,3 +55,38 @@ boot :: $(MAKE) -C genprimopcode endif +WITH_BOOTSTRAPPING_COMPILER = installPackage ghc-pkg hsc2hs hpc + +WITH_STAGE1 = installPackage ghc-pkg hasktags runghc hpc +ifneq "$(NO_INSTALL_HSC2HS)" "YES" +WITH_STAGE1 += hsc2hs +endif + +# sort removes duplicates - we don't actually care about the order +WITH_EITHER = $(sort $(WITH_BOOTSTRAPPING_COMPILER) $(WITH_STAGE1)) + +clean distclean:: $(foreach P,$(WITH_EITHER),clean.$P) + +with-bootstrapping-compiler: \ + $(foreach P,$(WITH_BOOTSTRAPPING_COMPILER),with-bootstrapping-compiler.$P) + +with-stage-1: $(foreach P,$(WITH_STAGE1),with-stage-1.$P) + +install:: $(foreach P,$(WITH_STAGE1),install.$P) + +$(foreach P,$(WITH_EITHER),clean.$P): \ +clean.%: + $(MAKE) -C $* clean + +$(foreach P,$(WITH_BOOTSTRAPPING_COMPILER),with-bootstrapping-compiler.$P): \ +with-bootstrapping-compiler.%: + $(MAKE) -C $* with-bootstrapping-compiler + +$(foreach P,$(WITH_STAGE1),with-stage-1.$P): \ +with-stage-1.%: + $(MAKE) -C $* with-stage-1 + +$(foreach P,$(WITH_STAGE1),install.$P): \ +install.%: + $(MAKE) -C $* install +