2005-01-11 Peter Bartok <pbartok@novell.com>
[mono.git] / mcs / build / rules.make
index 8f3d2ac7c06c7133a461044deb8416af26ef3b9d..470856e88c0abcfb3d3c3370223d2d5258806d7b 100644 (file)
 dots := $(shell echo $(thisdir) |sed -e 's,[^./][^/]*,..,g')
 topdir := $(dots)
 
-VERSION = 0.28.99
+VERSION = 0.93
 
 USE_MCS_FLAGS = $(LOCAL_MCS_FLAGS) $(PLATFORM_MCS_FLAGS) $(PROFILE_MCS_FLAGS) $(MCS_FLAGS)
+USE_MBAS_FLAGS = $(LOCAL_MBAS_FLAGS) $(PLATFORM_MBAS_FLAGS) $(PROFILE_MBAS_FLAGS) $(MBAS_FLAGS)
 USE_CFLAGS = $(LOCAL_CFLAGS) $(CFLAGS)
 CSCOMPILE = $(MCS) $(USE_MCS_FLAGS)
+BASCOMPILE = $(MBAS) $(USE_MBAS_FLAGS)
 CCOMPILE = $(CC) $(USE_CFLAGS)
 BOOT_COMPILE = $(BOOTSTRAP_MCS) $(USE_MCS_FLAGS)
 INSTALL_DATA = $(INSTALL) -m 644
 INSTALL_BIN = $(INSTALL) -m 755
 INSTALL_LIB = $(INSTALL_BIN)
 MKINSTALLDIRS = $(SHELL) $(topdir)/mkinstalldirs
-INTERNAL_MCS = $(RUNTIME) $(topdir)/mcs/mcs.exe
-corlib = corlib.dll
+INTERNAL_MCS = $(RUNTIME) $(topdir)/class/lib/$(PROFILE)/mcs.exe
+INTERNAL_MBAS = $(RUNTIME) $(topdir)/mbas/mbas.exe
+INTERNAL_GMCS = $(RUNTIME) $(topdir)/gmcs/gmcs.exe
+INTERNAL_ILASM = $(RUNTIME) $(topdir)/ilasm/ilasm.exe
+INTERNAL_RESGEN = $(RUNTIME) $(topdir)/tools/resgen/resgen.exe
+corlib = mscorlib.dll
 
 depsdir = $(topdir)/build/deps
-distdir = $(dots)/$(package)/$(thisdir)
 
 # Make sure these propagate if set manually
 
@@ -43,10 +48,12 @@ export MKINSTALLDIRS
 export TEST_HARNESS
 export BOOTSTRAP_MCS
 export DESTDIR
+export RESGEN
 
 # Get this so the platform.make platform-check rule doesn't become the
 # default target
 
+.DEFAULT: all
 default: all
 
 # Get initial configuration. pre-config is so that the builder can
@@ -87,58 +94,65 @@ endif
 include $(topdir)/build/profiles/$(PROFILE).make
 -include $(topdir)/build/config.make
 
-# Simple rules
-
-%-recursive:
-       @list='$(SUBDIRS)'; for d in $$list ; do \
-           (cd $$d && $(MAKE) $*) || exit 1 ; \
-       done
-
-# note: dist-local dep, extra subdirs, $* has become $@
-
-dist-recursive: dist-local
-       @list='$(SUBDIRS) $(DIST_ONLY_SUBDIRS)'; for d in $$list ; do \
-           (cd $$d && $(MAKE) $@) || exit 1 ; \
-       done
-
-# We do this manually to not have a make[1]: blah message (That is,
-# instead of using a '%: %-recursive %-local' construct.)
-#
-# Let the makefile override these for special situations (running checks
-# in the toplevel makefile, or a directory that needs to be built before
-# its subdirectories).
-
-ifndef OVERRIDE_BARE_TARGETS
-
-all: all-recursive all-local
-
-install: install-recursive install-local
-
-test: test-recursive test-local
+ifdef OVERRIDE_TARGET_ALL
+all: all.override
+else
+all: all.real
+endif
 
-run-test: run-test-recursive test-local run-test-local
+all.real: all-recursive
+       $(MAKE) all-local
 
-clean: clean-recursive clean-local
+STD_TARGETS = test run-test run-test-ondotnet clean install uninstall
 
-uninstall: uninstall-recursive uninstall-local
+$(STD_TARGETS): %: %-recursive
+       $(MAKE) $@-local
 
+# The way this is set up, any profile-specific subdirs list should
+# be listed _before_ including rules.make.  However, the default
+# SUBDIRS list can come after, so don't use the eager := syntax when
+# using the defaults.
+PROFILE_SUBDIRS := $($(PROFILE)_SUBDIRS)
+ifndef PROFILE_SUBDIRS
+PROFILE_SUBDIRS = $(SUBDIRS)
 endif
 
-# Can only do this from the top dir
-# ## dist: dist-recursive dist-local
+%-recursive:
+       @set . $$MAKEFLAGS; final_exit=:; \
+       case $$2 in --unix) shift ;; esac; \
+       case $$2 in *=*) dk="exit 1" ;; *k*) dk=: ;; *) dk="exit 1" ;; esac; \
+       list='$(PROFILE_SUBDIRS)'; for d in $$list ; do \
+           (cd $$d && $(MAKE) $*) || { final_exit="exit 1"; $$dk; } ; \
+       done; \
+       $$final_exit
+
+ifndef DIST_SUBDIRS
+DIST_SUBDIRS = $(SUBDIRS) $(DIST_ONLY_SUBDIRS)
+endif
+dist-recursive: dist-local
+       @case '$(distdir)' in [\\/$$]* | ?:[\\/]* ) reldir='$(distdir)' ;; *) reldir='../$(distdir)' ;; esac ; \
+       list='$(DIST_SUBDIRS)'; for d in $$list ; do \
+           (cd $$d && $(MAKE) distdir=$$reldir/$$d $@) || exit 1 ; \
+       done
 
-# We invert the test here to not end in an error
-# if ChangeLog doesn't exist.
+# The following target can be used like
 #
-# Note that we error out if we try to dist a nonexistant
-# file. Seems reasonable to me.
-
+#   dist-local: dist-default
+#      ... additional commands ...
+#
+# Notes: 
+#  1. we invert the test here to not end in an error if ChangeLog doesn't exist.
+#  2. we error out if we try to dist a nonexistant file.
+#  3. we pick up Makefile, makefile, or GNUmakefile.
 dist-default:
-       -mkdir $(distdir)
+       -mkdir -p $(distdir)
        test '!' -f ChangeLog || cp ChangeLog $(distdir)
-       for f in Makefile $(DISTFILES) ; do \
+       if test -f Makefile; then m=M; fi; \
+       if test -f makefile; then m=m; fi; \
+       if test -f GNUmakefile; then m=GNUm; fi; \
+       for f in $${m}akefile $(DISTFILES) ; do \
            dest=`dirname $(distdir)/$$f` ; \
-           $(MKINSTALLDIRS) $$dest && cp $$f $$dest || exit 1 ; \
+           $(MKINSTALLDIRS) $$dest && cp -p $$f $$dest || exit 1 ; \
        done
 
 # Useful