X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;ds=sidebyside;f=rules%2Fbuild-prog.mk;h=0a801afabfacda1128bc71881751d10fa60cba8a;hb=0856ac59cfb455d32a3042317fdba0f5e85cab9c;hp=6910e8f6e8903d744d67c34a2bdae285e52732b5;hpb=39253008705e3ca590afdfa1b87bfbb5a16da7e7;p=ghc-hetmet.git diff --git a/rules/build-prog.mk b/rules/build-prog.mk index 6910e8f..0a801af 100644 --- a/rules/build-prog.mk +++ b/rules/build-prog.mk @@ -66,7 +66,7 @@ $(call all-target,$1_$2,$1/$2/package-data.mk) # We have a rule for package-data.mk only when the package is # disabled, because we want the build to fail if we haven't run phase 0. ifneq "$(BINDIST)" "YES" -$(call build-package-data,$1,$2) +$(call build-package-data,$1,$2,$3) endif else @@ -83,10 +83,8 @@ $(call build-dependencies,$1,$2) # --- IMPLICIT RULES -$(call distdir-opts,$1,$2,$3) - # Just the 'v' way for programs -$(call distdir-way-opts,$1,$2,v) +$(call distdir-way-opts,$1,$2,v,$3) $(call c-suffix-rules,$1,$2,v,YES) @@ -98,12 +96,10 @@ $(call c-objs,$1,$2,v) $(call hs-objs,$1,$2,v) ifeq "$$(BootingFromHc)" "NO" -$1/$2/build/tmp/$$($1_$2_PROG) : $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) - "$$(MKDIRHIER)" $$(dir $$@) +$1/$2/build/tmp/$$($1_$2_PROG) : $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) | $$$$(dir $$$$@)/. "$$($1_$2_HC)" -o $$@ $$($1_$2_v_ALL_HC_OPTS) $$(LD_OPTS) $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) else -$1/$2/build/tmp/$$($1_$2_PROG) : $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) - "$$(MKDIRHIER)" $$(dir $$@) +$1/$2/build/tmp/$$($1_$2_PROG) : $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) | $$$$(dir $$$$@)/. "$$(CC)" -o $$@ $$($1_$2_v_ALL_CC_OPTS) $$(LD_OPTS) $$($1_$2_v_HS_OBJS) $$($1_$2_v_C_OBJS) $$($1_$2_v_S_OBJS) $$($1_$2_OTHER_OBJS) $$($1_$2_v_EXTRA_CC_OPTS) endif @@ -126,8 +122,8 @@ else ifeq "$$($1_$2_SHELL_WRAPPER) $$(Windows)" "YES NO" $1_$2_INPLACE = $$(INPLACE_LIB)/$$($1_$2_PROG) else -ifeq "$$($1_$2_LIBEXEC)" "YES" -$1_$2_INPLACE = $$(INPLACE_LIB)/$$($1_$2_PROG) +ifeq "$$($1_$2_TOPDIR)" "YES" +$1_$2_INPLACE = $$(INPLACE_TOPDIR)/$$($1_$2_PROG) else $1_$2_INPLACE = $$(INPLACE_BIN)/$$($1_$2_PROG) endif @@ -138,8 +134,7 @@ $(call clean-target,$1,$2_inplace,$$($1_$2_INPLACE)) # INPLACE_BIN might be empty if we're distcleaning ifeq "$(findstring clean,$(MAKECMDGOALS))" "" -$$($1_$2_INPLACE) : $1/$2/build/tmp/$$($1_$2_PROG) $$(MKDIRHIER) - "$$(MKDIRHIER)" $$(dir $$@) +$$($1_$2_INPLACE) : $1/$2/build/tmp/$$($1_$2_PROG) | $$$$(dir $$$$@)/. "$$(CP)" -p $$< $$@ touch $$@ endif @@ -150,8 +145,8 @@ endif $(call shell-wrapper,$1,$2) ifeq "$$($1_$2_INSTALL)" "YES" -ifeq "$$($1_$2_LIBEXEC)" "YES" -INSTALL_LIBEXECS += $1/$2/build/tmp/$$($1_$2_PROG) +ifeq "$$($1_$2_TOPDIR)" "YES" +INSTALL_TOPDIRS += $1/$2/build/tmp/$$($1_$2_PROG) else INSTALL_BINS += $1/$2/build/tmp/$$($1_$2_PROG) endif