Simulator consolidation
[deliverable/binutils-gdb.git] / Makefile.in
index 2514705a4f3a48e83402ce55322bea2e02d13d54..66c88c28cc5a41b1fc1e5ba54b88e7ffa36feb21 100644 (file)
@@ -24,6 +24,9 @@ prefix = /usr/local
 exec_prefix = $(prefix)
 bindir = $(exec_prefix)/bin
 libdir = $(exec_prefix)/lib
+tooldir = $(libdir)
+
+program_transform_name =
 
 datadir = $(prefix)/lib
 mandir = $(prefix)/man
@@ -42,23 +45,47 @@ docdir = $(datadir)/doc
 
 SHELL = /bin/sh
 
-INSTALL = install -c
+INSTALL = cp
 INSTALL_PROGRAM = $(INSTALL)
 INSTALL_DATA = $(INSTALL)
 
+AS = as
 AR = ar
-AR_FLAGS = qc
+AR_FLAGS = rc
+CC = cc
+CFLAGS = -g
+$(start-sanitize-chill)
+CHILLFLAGS = $(CFLAGS)
+CHILL_LIB = -lchill
+$(end-sanitize-chill)
+CXX = gcc
+CXXFLAGS = -g -O
 RANLIB = ranlib
+NM = nm
+
+BISON = `if [ -f $${rootme}/byacc/byacc ] ; \
+           then echo $${rootme}/byacc/byacc ; \
+           else echo byacc ; \
+       fi`
 
-BISON = `if [ -d $${rootme}/bison ] ; \
-       then echo $${rootme}/bison/bison -L $${rootme}/bison/ -y ; \
-       else echo bison -y ; fi`
+LEX = `if [ -f $${rootme}/flex/flex ] ; \
+       then echo $${rootme}/flex/flex ; \
+       else echo flex ; fi`
 
-MAKEINFO = `if [ -d $${rootme}/texinfo/C ] ; \
+MAKEINFO = `if [ -f $${rootme}/texinfo/C/makeinfo ] ; \
        then echo $${rootme}/texinfo/C/makeinfo ; \
        else echo makeinfo ; fi`
 
-SUBDIRS = libiberty glob readline bfd gdb binutils ld gas gcc libg++ libgcc clib newlib
+
+# libraries that may need to be augmented on a system-by-system basis
+X11_LIB = -lX11
+
+# compilers to use to create programs which must be run in the build
+# environment.
+CC_FOR_BUILD = $(CC)
+CXX_FOR_BUILD = $(CXX)
+
+SUBDIRS = "this is set via configure, don't edit this"
 OTHERS = 
 
 ALL = all.normal
@@ -67,1751 +94,1282 @@ INSTALL_TARGET = install.all
 ### for debugging
 #GCCVERBOSE=-v
 
+CC_FOR_TARGET = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(CC); \
+    else \
+      t='$(program_transform_name)'; echo gcc | sed -e '' $$t; \
+    fi; \
+  fi`
+
+GCC_FOR_TARGET = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(CC); \
+    else \
+      t='$(program_transform_name)'; echo gcc | sed -e '' $$t; \
+    fi; \
+  fi`
+
+$(start-sanitize-chill)
+CHILL_FOR_TARGET = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/ -L$${rootme}/chillrt/; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(CC); \
+    else \
+      t='$(program_transform_name)'; echo gcc | sed -e '' $$t; \
+    fi; \
+  fi`
+$(end-sanitize-chill)
+
+CXX_FOR_TARGET = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(CXX); \
+    else \
+      t='$(program_transform_name)'; echo gcc | sed -e '' $$t; \
+    fi; \
+  fi`
+
+AS_FOR_TARGET = ` \
+  if [ -f $${rootme}/gas/Makefile ] ; then \
+    echo $${rootme}/gas/as.new ; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(AS); \
+    else \
+       t='$(program_transform_name)'; echo as | sed -e '' $$t ; \
+    fi \
+  fi`
+
+AR_FOR_TARGET = ` \
+  if [ -f $${rootme}/binutils/Makefile ] ; then \
+    echo $${rootme}/binutils/ar ; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(AR); \
+    else \
+       t='$(program_transform_name)'; echo ar | sed -e '' $$t ; \
+    fi \
+  fi`
+
+RANLIB_FOR_TARGET = ` \
+  if [ -f $${rootme}/binutils/Makefile ] ; then \
+    echo $${rootme}/binutils/ranlib ; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(RANLIB); \
+    else \
+       t='$(program_transform_name)'; echo ranlib | sed -e '' $$t ; \
+    fi \
+  fi`
+
+NM_FOR_TARGET = ` \
+  if [ -f $${rootme}/binutils/Makefile ] ; then \
+    echo $${rootme}/binutils/nm ; \
+  else \
+    if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \
+      echo $(NM); \
+    else \
+       t='$(program_transform_name)'; echo nm | sed -e '' $$t ; \
+    fi \
+  fi`
+
+XTRAFLAGS = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    if [ -f $${rootme}/newlib/Makefile ] ; then \
+      echo -I$${rootme}/newlib/targ-include -I$${srcroot}/newlib/libc/include -I$${rootme}/gcc/include -nostdinc ; \
+    else \
+      echo -I$${rootme}/gcc/include ; \
+    fi ; \
+  else \
+     echo ; \
+  fi`
+
 
 #### host and target specific makefile fragments come in here.
 ###
 
-.PHONY: all info install-info clean-info
-
+# Flags to pass down to sub-makes -- please keep these in alphabetical order
+FLAGS_TO_PASS = \
+       "AR=$(AR)" \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "AR_FOR_TARGET=$(AR_FOR_TARGET)" \
+       "BISON=$(BISON)" \
+       "CXXFLAGS=$(CXXFLAGS)" \
+       "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
+       "CC=$(CC)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+       "CFLAGS=$(CFLAGS)" \
+$(start-sanitize-chill)\
+       "CHILLFLAGS=$(CHILLFLAGS)" \
+       "CHILL_FOR_TARGET=$(CHILL_FOR_TARGET)" \
+       "CHILL_LIB=$(CHILL_LIB)" \
+$(end-sanitize-chill)\
+       "GCC_FOR_TARGET=$(GCC_FOR_TARGET)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "LEX=$(LEX)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "RANLIB=$(RANLIB)" \
+       "RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \
+       "exec_prefix=$(exec_prefix)" \
+       "prefix=$(prefix)" \
+       "tooldir=$(tooldir)" 
+
+# Flags that are concerned with the location of the X11 include files
+# and library files
+
+X11_FLAGS_TO_PASS = \
+       "X11_INCLUDE_FLAGS=$(X11_INCLUDE_FLAGS)" \
+       "X11_LIB_FLAGS=$(X11_LIB_FLAGS)" \
+       "X11_LIB=$(X11_LIB)"
+
+# Flags to pass down to makes which are built with the target
+# environment (e.g. libg++, xiberty, newlib).  -- keep these in alpha order please
+TARGET_FLAGS_TO_PASS = \
+       "AR=$(AR_FOR_TARGET)" \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "AS=$(AS_FOR_TARGET)" \
+       "BISON=$(BISON)" \
+       "CXX=$(CXX_FOR_TARGET)" \
+       "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
+       "CXXFLAGS=$(CXXFLAGS)" \
+       "CC=$(CC_FOR_TARGET)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+       "CFLAGS=$(CFLAGS)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "LEX=$(LEX)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "NM=$(NM_FOR_TARGET)" \
+       "RANLIB=$(RANLIB_FOR_TARGET)" \
+       "XTRAFLAGS=$(XTRAFLAGS)" \
+       "exec_prefix=$(exec_prefix)" \
+       "prefix=$(prefix)" \
+       "tooldir=$(tooldir)" 
+
+# Flags to pass down to gcc.  gcc builds a library, libgcc.a, so it
+# unfortunately needs the native compiler and the target ar and
+# ranlib.  Keep these in alphabetical order, please.
+GCC_FLAGS_TO_PASS = \
+       "AR=$(AR_FOR_TARGET)" \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "AR_FOR_TARGET=$(AR_FOR_TARGET)" \
+       "AS=$(AS)" \
+       "BISON=$(BISON)" \
+       "CXX=$(CXX)" \
+       "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
+       "CXXFLAGS=$(CXXFLAGS)" \
+       "CC=$(CC)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+       "CFLAGS=$(CFLAGS)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "LEX=$(LEX)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "NM=$(NM)" \
+       "RANLIB=$(RANLIB_FOR_TARGET)" \
+       "RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \
+       "XTRAFLAGS=$(XTRAFLAGS)" \
+       "exec_prefix=$(exec_prefix)" \
+       "prefix=$(prefix)" \
+       "tooldir=$(tooldir)" 
+
+# The first rule in the file had better be this one.  Don't put any above it.
 all:   $(ALL)
 
-info:  cfg-paper.info configure.info
-       rootme=`pwd` ; export rootme ; $(MAKE) subdir_do DO=info "DODIRS=$(SUBDIRS)" "MAKEINFO=$(MAKEINFO)"
+.PHONY: all check dvi info install-info 
+.NOEXPORT:
+
+info check dvi:        
+       @rootme=`pwd` ; export rootme ; \
+         $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
 
-check:; rootme=`pwd` ; export rootme ; $(MAKE) subdir_do DO=check \
-       "DODIRS=`echo $(SUBDIRS) | sed -e \"s/libg\+\+//\"" \
-       "MAKEINFO=$(MAKEINFO)"
-       if [ -d libg++ ] ; then \
+install-info: install-info-dirs force
+       -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
+       @rootme='pwd' ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) DO=install-info "DODIRS=$(SUBDIRS)" subdir_do
+       @rootme='pwd' ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) dir.info install-dir.info
+
+install-dir.info:
+       -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
+       $(INSTALL_DATA) dir.info $(infodir)/dir.info
+
+all.normal: all-m4 all-autoconf all-libiberty all-mmalloc all-texinfo \
+       all-byacc all-flex all-opcodes all-bfd all-ld all-gas all-tgas \
+       all-gcc all-binutils  all-libg++ all-readline all-sim all-gdb \
+       all-make all-rcs all-cvs all-diff all-grep \
+       all-patch all-emacs all-ispell all-etc \
+       all-tcl all-tk all-expect \
+       all-newlib \
+       $(start-sanitize-chill) \
+       all-chillrt \
+       $(end-sanitize-chill) \
+       all-gprof all-send_pr all-libm all-deja-gnu \
+       all-fileutils all-find all-gawk all-sed all-shellutils \
+       all-textutils all-time all-wdiff all-uudecode 
+
+
+all.cross: all-libiberty all-mmalloc all-gas all-byacc all-flex all-ld \
+       all-opcodes all-bfd all-readline all-sim \
+       all-gdb all-binutils all-gcc all-newlib \
+       $(start-sanitize-chill) \
+       all-chillrt \
+       $(end-sanitize-chill) \
+       all-deja-gnu
+
+.PHONY: clean distclean mostlyclean realclean do_clean
+
+do_clean:
+       -rm -f *.a TEMP errs core *.o *~ \#* TAGS *.E
+
+clean mostlyclean: do_clean
+       @rootme=`pwd` ; export rootme ; \
+         $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
+
+distclean realclean: do_clean
+       @rootme=`pwd` ; export rootme ; \
+         $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
+       -rm -f Makefile config.status
+
+uninstall:
+       @echo "the uninstall target is not supported in this tree"
+
+install: $(INSTALL_TARGET) 
+       -parent=`echo $(man1dir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(man1dir) ] ; then true ; else mkdir $(man1dir) ; fi
+
+install.all: install-no-fixedincludes
+       @if [ -f ./gcc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd libg++ ; \
-                $(MAKE) check "CC=$${rootme}/gcc/gcc \
-                -B$${rootme}/gcc/") ; \
-       fi
-               
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) install-headers) ; \
+       else \
+               true ; \
+       fi
+
+install-no-fixedincludes: install-dirs gcc-no-fixedincludes \
+       install-autoconf \
+       install-bfd \
+       install-binutils \
+       install-opcodes \
+       install-byacc \
+       install-cvs \
+       install-diff \
+       install-deja-gnu \
+       install-emacs \
+       install-etc \
+       install-expect \
+       install-flex \
+       install-gas \
+       install-gdb \
+       install-glob \
+       install-gprof \
+       install-grep \
+       install-ispell \
+       install-ld \
+       install-libg++ \
+       install-libiberty \
+       install-libm \
+       install-make \
+       install-mmalloc \
+       install-newlib \
+       $(start-sanitize-chill) \
+       install-chillrt \
+       $(end-sanitize-chill) \
+       install-patch \
+       install-rcs \
+       install-readline \
+       install-send_pr \
+       install-tcl \
+       install-texinfo \
+       install-tk  \
+       install-sim \
+       install-fileutils install-find install-gawk install-m4 install-sed install-shellutils \
+       install-textutils install-time install-wdiff install-uudecode
 
-clean-info:
-       $(MAKE) subdir_do DO=clean-info "DODIRS=$(SUBDIRS)"
-       rm -f cfg-paper.info* configure.info*
+#
+# Install the gcc headers files, but not the fixed include files,
+# which we are not allowed to distribute.  This rule is very dependent
+# on the workings of the gcc Makefile.in.
+#
+gcc-no-fixedincludes:
+       @if [ -f ./gcc/Makefile ]; then \
+         rm -rf gcc/tmp-include; \
+         mv gcc/include gcc/tmp-include 2>/dev/null; \
+         mkdir gcc/include; \
+         touch gcc/stmp-fixincludes; \
+         rm -f gcc/stmp-headers; \
+         rootme=`pwd`; export rootme; \
+         srcroot=`cd $(srcdir); pwd` ; export srcroot; \
+         (cd ./gcc; \
+          $(MAKE) $(GCC_FLAGS_TO_PASS) install); \
+         rm -rf gcc/include; \
+         mv gcc/tmp-include gcc/include 2>/dev/null; \
+       else true; fi
 
-cfg-paper.info: cfg-paper.texi
-       rootme=`pwd` ; export rootme ; $(MAKEINFO) -o cfg-paper.info $(srcdir)/cfg-paper.texi
+install.cross: install-dirs install-libiberty install-mmalloc \
+        install-binutils install-opcodes install-byacc install-flex \
+        install-ld install-gas install-readline \
+        install-glob install-gdb install-mmalloc \
+        install-newlib \
+       $(start-sanitize-chill) \
+       install-chillrt \
+       $(end-sanitize-chill) \
+       install-gcc install-etc install-deja-gnu
 
-configure.info: configure.texi
-       rootme=`pwd` ; export rootme ; $(MAKEINFO) -o configure.info $(srcdir)/configure.texi
+### deja-gnu
+all-deja-gnu: force
+       @if [ -f ./deja-gnu/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./deja-gnu; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
 
-install-info: install-info-dirs force
-       [ -d $(infodir) ] || mkdir $(infodir)
-       $(MAKE) subdir_do DO=install-info "DODIRS=$(SUBDIRS)"
-       $(INSTALL_DATA) cfg-paper.info $(infodir)/cfg-paper.info
-       $(INSTALL_DATA) configure.info $(infodir)/configure.info
-       $(MAKE) dir.info install-dir.info
+install-deja-gnu: force
+       @if [ -f ./deja-gnu/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./deja-gnu; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 
-install-dir.info:
-       $(INSTALL_DATA) dir.info $(infodir)/dir.info
+### autoconf
+all-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
 
-# clib send_pr
-#      all-libgcc
-all.normal: .stmp-libiberty .stmp-texinfo .stmp-bison .stmp-byacc \
-       .stmp-bfd .stmp-ld .stmp-gas .stmp-gcc .stmp-binutils \
-       .stmp-libg++ .stmp-readline .stmp-gdb .stmp-make .stmp-cvs \
-       .stmp-grep .stmp-patch .stmp-emacs .stmp-ispell .stmp-fileutils \
-       .stmp-newlib 
-all.cross: .stmp-libiberty .stmp-gas .stmp-bison .stmp-ld .stmp-libgcc .stmp-gdb
-#      $(MAKE) subdir_do DO=all "DODIRS=$(SUBDIRS) $(OTHERS)"
-
-clean: clean-stamps clean-libiberty clean-texinfo clean-bfd clean-newlib clean-binutils \
-       clean-bison clean-byacc clean-ld clean-gas \
-       clean-gcc clean-libgcc clean-readline clean-glob clean-gdb \
-       clean-make clean-diff clean-grep clean-rcs clean-gdbm \
-       clean-cvs clean-patch clean-emacs clean-ispell clean-fileutils \
-       clean-libg++
-       -rm -rf *.a TEMP errs core *.o *~ \#* TAGS *.E
-
-clean-stamps:
-       -rm -f .stmp-*
-
-install: $(INSTALL_TARGET) $(srcdir)/configure.man
-       $(INSTALL_DATA) $(srcdir)/configure.man $(man1dir)/configure.1
-
-install.all: install-dirs install-libiberty install-texinfo \
-       install-bfd install-binutils install-bison install-byacc \
-       install-ld install-gas install-gcc \
-       install-libgcc install-readline install-glob install-gdb \
-       install-make install-cvs install-patch install-emacs \
-       install-ispell install-fileutils install-libg++ install-newlib
-
-install.cross: install-dirs install-libiberty install-binutils install-bison \
-       install-byacc install-ld install-gas install-libgcc \
-       install-readline install-glob install-gdb
+install-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 
-### libiberty
-all-libiberty: .stmp-libiberty
-.stmp-libiberty:
-       if [ -d ./libiberty ] ; then \
+### etc
+all-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libiberty; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./etc; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./etc; $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-libiberty
 
-clean-libiberty: force
-       if [ -d ./libiberty ] ; then \
+### libiberty
+all-libiberty: force
+       @if [ -f ./libiberty/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./libiberty; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-libiberty: force
-       if [ -d ./libiberty ] ; then \
+       @if [ -f ./libiberty/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./libiberty; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### texinfo
-all-texinfo: .stmp-libiberty .stmp-texinfo
-.stmp-texinfo:
-       if [ -d ./texinfo ] ; then \
+### xiberty
+all-xiberty: all-gcc all-newlib
+       @if [ -f ./xiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./xiberty; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-xiberty: force
+       @if [ -f ./xiberty/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./xiberty; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### mmalloc
+all-mmalloc: force
+       @if [ -f ./mmalloc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./texinfo; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./mmalloc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-mmalloc: force
+       @if [ -f ./mmalloc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./mmalloc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-texinfo
 
-clean-texinfo: force
-       if [ -d ./texinfo ] ; then \
+### texinfo
+all-texinfo: all-libiberty
+       @if [ -f ./texinfo/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./texinfo; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-texinfo: force
-       if [ -d ./texinfo ] ; then \
+       @if [ -f ./texinfo/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./texinfo; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### bfd
-all-bfd: .stmp-bfd
-.stmp-bfd:
-       if [ -d ./bfd ] ; then \
+all-bfd: force
+       @if [ -f ./bfd/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./bfd; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-bfd
 
-clean-bfd: force
-       if [ -d ./bfd ] ; then \
+install-bfd: force
+       @if [ -f ./bfd/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./bfd; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-bfd: force
-       if [ -d ./bfd ] ; then \
+
+### opcodes
+all-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./bfd; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### binutils
-all-binutils: .stmp-libiberty .stmp-bfd .stmp-binutils
-.stmp-binutils:
-       if [ -d ./binutils ] ; then \
+install-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./binutils; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-binutils
 
-clean-binutils: force
-       if [ -d ./binutils ] ; then \
+### binutils
+all-binutils: all-opcodes all-libiberty all-bfd all-flex
+       @if [ -f ./binutils/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./binutils; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-binutils: force
-       if [ -d ./binutils ] ; then \
+       @if [ -f ./binutils/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./binutils; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### newlib
-all-newlib: .stmp-newlib
-.stmp-newlib:
-       if [ -d ./newlib ] ; then \
+all-newlib: all-binutils all-ld all-gas all-gcc
+       @if [ -f ./newlib/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
                (cd ./newlib; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-newlib
 
-clean-newlib: force
-       if [ -d ./newlib ] ; then \
+install-newlib: force
+       @if [ -f ./newlib/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
                (cd ./newlib; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-newlib: force
-       if [ -d ./newlib ] ; then \
+### start-sanitize-chill
+### chillrt
+all-chillrt: all-binutils all-ld all-gas all-gcc all-newlib
+       @if [ -f ./chillrt/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./newlib; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./chillrt; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### byacc
-all-byacc: .stmp-byacc
-.stmp-byacc:
-       if [ -d ./byacc ] ; then \
+install-chillrt: force
+       @if [ -f ./chillrt/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./byacc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./chillrt; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-byacc
+### end-sanitize-chill
 
-clean-byacc: force
-       if [ -d ./byacc ] ; then \
+### gprof
+all-gprof: all-libiberty all-bfd
+       @if [ -f ./gprof/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./byacc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-byacc: force
-       if [ -d ./byacc ] ; then \
+install-gprof: force
+       @if [ -f ./gprof/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./byacc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### bison
-all-bison: .stmp-libiberty .stmp-bison
-.stmp-bison:
-       if [ -d ./bison ] ; then \
+### byacc
+all-byacc: force
+       @if [ -f ./byacc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./bison; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-bison
 
-clean-bison: force
-       if [ -d ./bison ] ; then \
+install-byacc: force
+       @if [ -f ./byacc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./bison; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-bison: force
-       if [ -d ./bison ] ; then \
+### flex
+all-flex: all-libiberty
+       @if [ -f ./flex/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./bison; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### gcc
-all-gcc: .stmp-libiberty .stmp-bison .stmp-gas .stmp-gcc
-.stmp-gcc:
-       if [ -d ./gcc ] ; then \
+install-flex: force
+       @if [ -f ./flex/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-gcc
-
-clean-gcc: force
-       if [ -d ./gcc ] ; then \
+### gcc
+all-gcc: all-libiberty all-byacc all-binutils all-gas
+       @if [ -f ./gcc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
                (cd ./gcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(GCC_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-gcc:
-       if [ -d ./gcc ] ; then \
+install-gcc: force
+       @if [ -f ./gcc/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
                (cd ./gcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(GCC_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### readline
-all-readline: .stmp-readline
-.stmp-readline:
-       if [ -d ./readline ] ; then \
-               rootme=`pwd` ; export rootme ; \
-               (cd ./readline; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-       touch .stmp-readline
-
-clean-readline: force
-       if [ -d ./readline ] ; then \
+all-readline: force
+       @if [ -f ./readline/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./readline; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-readline: force
-       if [ -d ./readline ] ; then \
+       @if [ -f ./readline/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./readline; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### glob
-all-glob: .stmp-glob
-.stmp-glob:
-       if [ -d ./glob ] ; then \
-               rootme=`pwd` ; export rootme ; \
-               (cd ./glob; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-       touch .stmp-glob
-
-clean-glob: force
-       if [ -d ./glob ] ; then \
+all-glob: force
+       @if [ -f ./glob/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./glob; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-glob: force
-       if [ -d ./glob ] ; then \
+       @if [ -f ./glob/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./glob; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### gas
-all-gas: .stmp-libiberty .stmp-bfd .stmp-gas
-.stmp-gas:
-       if [ -d ./gas ] ; then \
+all-gas: all-libiberty all-opcodes all-bfd
+       @if [ -f ./gas/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./gas; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-gas
 
-clean-gas: force
-       if [ -d ./gas ] ; then \
+install-gas: force
+       @if [ -f ./gas/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./gas; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-gas: force
-       if [ -d ./gas ] ; then \
+### gas
+all-tgas: all-libiberty all-bfd
+       @if [ -f ./tgas/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gas; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./tgas; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
+
 ### ld
-all-ld: .stmp-libiberty .stmp-bfd .stmp-bison .stmp-ld
-.stmp-ld: 
-       if [ -d ./ld ] ; then \
+all-ld: all-libiberty all-bfd all-byacc all-flex
+       @if [ -f ./ld/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./ld; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-ld
 
-clean-ld: force
-       if [ -d ./ld ] ; then \
+install-ld: force
+       @if [ -f ./ld/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
                (cd ./ld; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-ld: force
-       if [ -d ./ld ] ; then \
+### gdb
+all-gdb: all-bfd all-opcodes all-libiberty all-mmalloc all-readline all-glob all-byacc
+       @if [ -f ./gdb/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./ld; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
-       else \
-               true ; \
-       fi
-
-### libgcc (and libgcc1)
-all-libgcc1: all-gas all-binutils .stmp-libgcc1
-.stmp-libgcc1:
-       if [ -d ./libgcc ] ; then \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-gdb: force
+       @if [ -f ./gdb/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libgcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       libgcc1.a) ; \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-libgcc1
 
-clean-libgcc1: force
-       if [ -d ./libgcc ] ; then \
+### make
+all-make: all-libiberty
+       @if [ -f ./make/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libgcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean-libgcc1) ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-libgcc1: force
-       echo libgcc1 is a component, not an installable target
+install-make: force
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 
-all-libgcc: all-gas all-gcc all-binutils .stmp-libgcc
-.stmp-libgcc:
-       true
-       if [ -d ./libgcc ] ; then \
+### diff
+all-diff: force
+       @if [ -f ./diff/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libgcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./diff; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-libgcc
 
-clean-libgcc: force
-       if [ -d ./libgcc ] ; then \
+install-diff: force
+       @if [ -f ./diff/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libgcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./diff/; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-libgcc: force
-       if [ -d ./libgcc ] ; then \
+### grep
+all-grep: force
+       @if [ -f ./grep/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libgcc; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### gdb
-all-gdb: .stmp-bfd .stmp-libiberty .stmp-readline .stmp-glob .stmp-bison .stmp-gdb
-.stmp-gdb: 
-       if [ -d ./gdb ] ; then \
+install-grep: force
+       @if [ -f ./grep/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdb; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-gdb
 
-clean-gdb: force
-       if [ -d ./gdb ] ; then \
+### rcs
+all-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdb; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-gdb: force
-       if [ -d ./gdb ] ; then \
+install-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdb; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### make
-all-make: all-libiberty .stmp-make
-.stmp-make:
-       if [ -d ./make ] ; then \
+### cvs
+all-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./make; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-make
 
-clean-make: force
-       if [ -d ./make ] ; then \
+install-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./make; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-make: force
-       if [ -d ./make ] ; then \
+### patch
+all-patch: force
+       @if [ -f ./patch/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./make; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### diff
-all-diff: .stmp-diff
-.stmp-diff:
-       if [ -d ./diff ] ; then \
+install-patch: force
+       @if [ -f ./patch/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./diff; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) \
+                       bindir=$(bindir) \
+                       man1dir=$(man1dir) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-diff
 
-clean-diff: force
-       if [ -d ./diff ] ; then \
+### emacs
+all-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./diff; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-diff: force
-       if [ -d ./diff ] ; then \
+install-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./diff/; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### grep
-all-grep: .stmp-grep
-.stmp-grep:
-       if [ -d ./grep ] ; then \
+### ispell
+all-ispell: all-emacs
+       @if [ -f ./ispell/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./grep; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-grep
 
-clean-grep: force
-       if [ -d ./grep ] ; then \
+install-ispell: force
+       @if [ -f ./ispell/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./grep; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-grep: force
-       if [ -d ./grep ] ; then \
+### send_pr
+all-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./grep; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### rcs
-all-rcs: .stmp-diff .stmp-grep .stmp-rcs
-.stmp-rcs:
-       if [ -d ./rcs ] ; then \
+install-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./rcs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-rcs
 
-clean-rcs: force
-       if [ -d ./rcs ] ; then \
+### libm
+all-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./rcs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./libm; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-rcs: install-grep install-diff force
-       if [ -d ./rcs ] ; then \
+install-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./rcs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./libm; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### gdbm
-all-gdbm: .stmp-gdbm
-.stmp-gdbm:
-       if [ -d ./gdbm ] ; then \
+### libg++
+
+all-libg++: all-gas all-ld all-gcc all-xiberty all-newlib
+       @if [ -f ./libg++/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdbm; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-gdbm
 
-clean-gdbm: force
-       if [ -d ./gdbm ] ; then \
+install-libg++: force
+       @if [ -f ./libg++/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdbm; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+### tcl
+all-tcl: 
+       @if [ -f ./tcl/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tcl; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-gdbm: force
-       if [ -d ./gdbm ] ; then \
+install-tcl: force
+       @if [ -f ./tcl/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./gdbm; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tcl; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### cvs
 
-all-cvs: .stmp-cvs .stmp-rcs .stmp-grep .stmp-diff
-.stmp-cvs: .stmp-gdbm
-       if [ -d ./cvs ] ; then \
+### tk
+all-tk: all-tcl
+       @if [ -f ./tk/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./cvs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tk; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-cvs
 
-clean-cvs: clean-gdbm
-       if [ -d ./cvs ] ; then \
+install-tk: force
+       @if [ -f ./tk/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./cvs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tk; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-cvs: install-rcs install-gdbm
-       if [ -d ./cvs ] ; then \
+### expect
+all-expect: all-tcl
+       @if [ -f ./expect/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./cvs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./expect; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### patch
-all-patch: .stmp-patch
-.stmp-patch:
-       if [ -d ./patch ] ; then \
+install-expect: force
+       @if [ -f ./expect/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./patch; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./expect; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
-       touch .stmp-patch
 
-clean-patch:
-       if [ -d ./patch ] ; then \
+### sim
+all-sim: all-bfd 
+       @if [ -f ./sim/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./patch; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./sim; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-patch:
-       if [ -d ./patch ] ; then \
+install-sim: force
+       @if [ -f ./sim/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./patch; \
-               $(MAKE) \
-                       bindir=$(bindir) \
-                       man1dir=$(man1dir) \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./sim; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### emacs
-all-emacs: .stmp-emacs
-.stmp-emacs:
-       if [ -d ./emacs ] ; then \
+### fileutils
+all-fileutils: force
+       @if [ -f ./fileutils/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./fileutils; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-fileutils: force
+       @if [ -f ./fileutils/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./emacs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./fileutils; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### find
+all-find: force
+       @if [ -f ./find/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./find; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-emacs
 
-clean-emacs:
-       if [ -d ./emacs ] ; then \
+install-find: force
+       @if [ -f ./find/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./emacs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./find; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### gawk
+all-gawk: force
+       @if [ -f ./gawk/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./gawk; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-emacs: install-rcs install-gdbm
-       if [ -d ./emacs ] ; then \
+install-gawk: force
+       @if [ -f ./gawk/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./emacs; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./gawk; $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### ispell
-all-ispell: .stmp-emacs .stmp-ispell
-.stmp-ispell:
-       if [ -d ./ispell ] ; then \
+### m4
+all-m4: all-libiberty
+       @if [ -f ./m4/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./m4; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-m4: force
+       @if [ -f ./m4/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./ispell; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./m4; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### sed
+all-sed: force
+       @if [ -f ./sed/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./sed; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-ispell
 
-clean-ispell:
-       if [ -d ./ispell ] ; then \
+install-sed: force
+       @if [ -f ./sed/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./ispell; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./sed; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### time
+all-time: force
+       @if [ -f ./time/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./time; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-ispell: install-rcs install-gdbm
-       if [ -d ./ispell ] ; then \
+install-time: force
+       @if [ -f ./time/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./ispell; \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./time; $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### fileutils
-all-fileutils: .stmp-fileutils
-.stmp-fileutils:
-       if [ -d ./fileutils ] ; then \
-               rootme=`pwd` ; export rootme ; \
-               (cd ./fileutils; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-       touch .stmp-fileutils
-
-clean-fileutils:
-       if [ -d ./fileutils ] ; then \
-               rootme=`pwd` ; export rootme ; \
-               (cd ./fileutils; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-fileutils:
-       if [ -d ./fileutils ] ; then \
-               rootme=`pwd` ; export rootme ; \
-               (cd ./fileutils; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+### wdiff
+all-wdiff: force
+       @if [ -f ./wdiff/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./wdiff; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### libg++
-GXX = `if [ -d $${rootme}/gcc ] ; \
-       then echo $${rootme}/gcc/gcc -B$${rootme}/gcc/ ; \
-       else echo gcc ; fi`
+install-wdiff: force
+       @if [ -f ./wdiff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./wdiff; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 
-XTRAFLAGS = `if [ -d $${rootme}/gcc ] ; \
-       then echo -I$${rootme}/gcc/include ; \
-       else echo ; fi`
+### uudecode
+all-uudecode: all-libiberty
+       @if [ -f ./uudecode/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./uudecode; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
 
-all-libg++: .stmp-gas .stmp-ld .stmp-gcc .stmp-libg++
-.stmp-libg++: .stmp-gcc
-       if [ -d ./libg++ ] ; then \
+install-uudecode: force
+       @if [ -f ./uudecode/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libg++; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=${GXX}" \
-                       "XTRAFLAGS=${XTRAFLAGS}" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+               (cd ./uudecode; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### shellutils
+all-shellutils: force
+       @if [ -f ./shellutils/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./shellutils; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
-       touch .stmp-libg++
 
-clean-libg++:
-       if [ -d ./libg++ ] ; then \
+install-shellutils: force
+       @if [ -f ./shellutils/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libg++; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+               (cd ./shellutils; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### textutils
+all-textutils: force
+       @if [ -f ./textutils/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./textutils; $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-install-libg++:
-       if [ -d ./libg++ ] ; then \
+install-textutils: force
+       @if [ -f ./textutils/Makefile ] ; then \
                rootme=`pwd` ; export rootme ; \
-               (cd ./libg++; \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+               (cd ./textutils; $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
+
+
 ### other supporting targets
-# this is a bad hack.
-all.xclib:     all.normal
-       if [ -d clib ] ; then \
-               (cd clib ; $(MAKE)) ; \
-       fi
 
 subdir_do:
-       for i in $(DODIRS); do \
-               if [ -f ./$$i/localenv ] ; then \
-                       if (rootme=`pwd` ; export rootme ; cd ./$$i; \
-                               $(MAKE) \
-                                       "against=$(against)" \
-                                       "BISON=$(BISON)" \
-                                       "MAKEINFO=$(MAKEINFO)" \
-                                       $(DO)) ; then true ; \
-                               else exit 1 ; fi ; \
-               else if [ -d ./$$i ] ; then \
-                       if (rootme=`pwd` ; export rootme ; cd ./$$i; \
-                               $(MAKE) \
-                                       "against=$(against)" \
-                                       "AR=$(AR)" \
-                                       "AR_FLAGS=$(AR_FLAGS)" \
-                                       "CC=$(CC)" \
-                                       "RANLIB=$(RANLIB)" \
-                                       "LOADLIBES=$(LOADLIBES)" \
-                                       "LDFLAGS=$(LDFLAGS)" \
-                                       "BISON=$(BISON)" \
-                                       "MAKEINFO=$(MAKEINFO)" \
-                                       $(DO)) ; then true ; \
-                       else exit 1 ; fi ; \
-               else true ; fi ; \
-       fi ; \
+### start-sanitize-chill
+### 
+### WARNING: THIS IS VERY UGLY AND I DID NOT DO THIS WILLINGLY
+###
+### if you change the code for libg++ et al, also change the
+### code for chillrt
+###
+### end-sanitize-chill
+       @for i in $(DODIRS); do \
+         if [ -f ./$$i/localenv ] || [ -f ./$$i/Makefile ] ; then \
+           case $$i in \
+           libg++ | xiberty | newlib) \
+             if (rootme=`pwd` ; export rootme ; \
+                 srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+                 cd ./$$i ; \
+                 $(MAKE) $(TARGET_FLAGS_TO_PASS) $(DO)) ; then true ; \
+             else exit 1 ; fi \
+             ;; \
+       $(start-sanitize-chill) \
+           chillrt) \
+             if (rootme=`pwd` ; export rootme ; \
+                 srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+                 cd ./$$i ; \
+                 $(MAKE) $(TARGET_FLAGS_TO_PASS) $(DO)) ; then true ; \
+             else exit 1 ; fi \
+             ;; \
+       $(end-sanitize-chill) \
+           gcc) \
+             if (rootme=`pwd` ; export rootme ; \
+                 srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+                 cd ./$$i ; \
+                 $(MAKE) $(GCC_FLAGS_TO_PASS) $(DO)) ; then true ; \
+             else exit 1 ; fi \
+             ;; \
+           *) \
+             if (rootme=`pwd` ; export rootme ; \
+                 cd ./$$i ; \
+                 $(MAKE) $(FLAGS_TO_PASS) $(DO)) ; then true ; \
+             else exit 1 ; fi \
+             ;; \
+           esac ; \
+         else true ; fi ; \
        done
 
-bootstrap:
-       $(MAKE) all info
-       $(MAKE) stage1
-       $(MAKE) pass "stagepass=stage1"
-       $(MAKE) stage2
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-bootstrap2:
-       $(MAKE) pass "stagepass=stage1"
-       $(MAKE) stage2
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-bootstrap3:
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-pass:
-       cp $(srcdir)/gcc/gstdarg.h ./gas/stdarg.h
-       $(MAKE) subdir_do "DO=all info" "DODIRS=$(SUBDIRS)" \
-               "CC=`pwd`/gcc/$(stagepass)/gcc \
-               -O $(GCCVERBOSE) -I`pwd`/gcc/include \
-               -B`pwd`/gcc/$(stagepass)/ \
-               -B`pwd`/gas/$(stagepass)/ \
-               -B`pwd`/ld/$(stagepass)/" \
-               "AR=`pwd`/binutils/$(stagepass)/ar" \
-               "LD=`pwd`/gcc/$(stagepass)/gcc $(GCCVERBOSE)" \
-               "RANLIB=`pwd`/binutils/$(stagepass)/ranlib" \
-               "LOADLIBES=`pwd`/libgcc/$(stagepass)/libgcc.a /lib/libc.a" \
-               "LDFLAGS=-nostdlib /lib/crt0.o \
-               -L`pwd`/libgcc/$(stagepass)/ \
-               -B`pwd`/ld/$(stagepass)/"
-
-
-stage1:
-       $(MAKE) subdir_do DO=stage1 "DODIRS=$(SUBDIRS)"
-
-stage2:
-       $(MAKE) subdir_do DO=stage2 "DODIRS=$(SUBDIRS)"
-
-stage3:
-       $(MAKE) subdir_do DO=stage3 "DODIRS=$(SUBDIRS)"
-
-stage4:
-       $(MAKE) subdir_do DO=stage4 "DODIRS=$(SUBDIRS)"
-
-against=stage2
-
-comparison:; $(MAKE) subdir_do DO=comparison against=$(against) "DODIRS=$(SUBDIRS)"
-
-de-stage1:; $(MAKE) subdir_do DO=de-stage1 "DODIRS=$(SUBDIRS)"
-de-stage2:; $(MAKE) subdir_do DO=de-stage2 "DODIRS=$(SUBDIRS)"
-de-stage3:; $(MAKE) subdir_do DO=de-stage3 "DODIRS=$(SUBDIRS)"
-de-stage4:; $(MAKE) subdir_do DO=de-stage4 "DODIRS=$(SUBDIRS)"
-
 # The "else true" stuff is for Ultrix; the shell returns the exit code
 # of the "if" command, if no commands are run in the "then" or "else" part,
 # causing Make to quit.
@@ -1819,15 +1377,16 @@ de-stage4:; $(MAKE) subdir_do DO=de-stage4 "DODIRS=$(SUBDIRS)"
 MAKEDIRS= \
        $(prefix) \
        $(exec_prefix) \
-       $(bindir) \
-       $(libdir) \
-       $(tooldir) \
-       $(includedir) \
-       $(datadir) \
-       $(docdir) \
-       $(mandir) \
-       $(man1dir) \
-       $(man5dir)
+       $(tooldir)
+
+#      $(bindir) \
+#      $(libdir) \
+#      $(includedir) \
+#      $(datadir) \
+#      $(docdir) \
+#      $(mandir) \
+#      $(man1dir) \
+#      $(man5dir)
 
 #      $(man2dir) \
 #      $(man3dir) \
@@ -1839,22 +1398,30 @@ MAKEDIRS= \
 install-dirs:
        for i in $(MAKEDIRS) ; do \
                echo Making $$i... ; \
-               [ -d $$i ] || mkdir $$i || exit 1 ; \
+               parent=`echo $$i|sed -e 's@/[^/]*$$@@'`; \
+               if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi ; \
+               if [ ! -d $$i ] ; then \
+                       if mkdir $$i ; then \
+                               true ; \
+                       else \
+                               exit 1 ; \
+                       fi ; \
+               else \
+                       true ; \
+               fi ; \
        done
 
-MAKEINFODIRS= \
-       $(prefix) \
-       $(infodir)
-
 install-info-dirs:
        if [ -d $(prefix) ] ; then true ; else mkdir $(prefix) ; fi
-       if [ -d $(datadir) ] ; then true ; else mkdir $(datadir) ; fi
-       if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
 
 dir.info:
-       $(srcdir)/texinfo/gen-info-dir $(infodir) > dir.info.new
+       $(srcdir)/texinfo/gen-info-dir $(infodir) $(srcdir)/texinfo/dir.info-template > dir.info.new
        mv -f dir.info.new dir.info
 
+dist:
+       @echo "Building a full distribution of this tree isn't done"
+       @echo "via 'make dist'.  Check out the etc/ subdirectory" 
+
 etags tags: TAGS
 
 TAGS:
@@ -1883,27 +1450,23 @@ Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag)
 #
 # Build GDB distributions that contain BFD, Include, Libiberty, Readline, etc
 
-DEVO_SUPPORT= README cfg-paper.texi Makefile.in configure configure.in \
-       config.sub config configure.man
-GDB_SUPPORT_DIRS= bfd include libiberty readline glob
-GDB_SUPPORT_FILES= $(GDB_SUPPORT_DIRS) texinfo/fsf/texinfo.tex
+DEVO_SUPPORT= README Makefile.in configure configure.in \
+       config.guess config.sub config etc move-if-change \
+       COPYING.LIB
+GDB_SUPPORT_DIRS= bfd include libiberty mmalloc opcodes readline glob
+GDB_SUPPORT_FILES= $(GDB_SUPPORT_DIRS)
 
-setup-dirs: force_update
+setup-dirs: force
        ./configure sun4
        make clean
        ./configure -rm sun4
        chmod og=u `find $(DEVO_SUPPORT) $(GDB_SUPPORT_FILES) -print`
 
-bfd.ilrt.tar.Z: setup-dirs
-       rm -f bfd.ilrt.tar.Z
-       tar cf - $(DEVO_SUPPORT) $(GDB_SUPPORT_FILES) \
-               | compress -v >bfd.ilrt.tar.Z
-
 gdb.tar.Z: setup-dirs
        (cd gdb; $(MAKE) -f Makefile.in make-proto-gdb.dir)
        $(MAKE) $(MFLAGS) -f Makefile.in make-gdb.tar.Z
 
-make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/fsf/texinfo.tex
+make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/texinfo.tex
        rm -rf proto-toplev; mkdir proto-toplev
        ln -s ../gdb/proto-gdb.dir proto-toplev/gdb
        (cd proto-toplev; for i in $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS); do \
@@ -1916,21 +1479,23 @@ make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/fsf/texinfo.tex
        ln proto-toplev/gdb/COPYING proto-toplev/include/COPYING
        rm                          proto-toplev/readline/COPYING
        ln proto-toplev/gdb/COPYING proto-toplev/readline/COPYING
-       # Take out texinfo from configurable dirs
+
+       # Take out texinfo and glob from configurable dirs
        rm proto-toplev/configure.in
-       sed '/^configdirs=/s/texinfo //' <configure.in >proto-toplev/configure.in
-       # Take out glob from buildable dirs
+       sed -e '/^host_tools=/s/texinfo //' \
+           -e '/^host_libs=/s/glob //' \
+           <configure.in >proto-toplev/configure.in
+
+       # Take out texinfo from a few places; make simple BISON=bison line.
        rm proto-toplev/Makefile.in
-       sed '/^SUBDIRS =/s/glob //' <Makefile.in >proto-toplev/Makefile.in
-       # Take out texinfo from buildable dirs
-       cp proto-toplev/Makefile.in temp.$$
-       sed '/^all\.normal: /s/all-texinfo //' <temp.$$ >temp1.$$
-       sed '/^clean: /s/clean-texinfo //' <temp1.$$ >temp.$$
-       sed '/^install\.all: /s/install-texinfo //' <temp.$$ >proto-toplev/Makefile.in
-       rm temp.$$ temp1.$$
+       sed -e '/^all\.normal: /s/\all-texinfo //' \
+           -e '/^      install-texinfo /d' \
+           -e '\/^BISON =/,\/^$$/c\
+               BISON = bison' \
+       <Makefile.in >proto-toplev/Makefile.in
+
        mkdir proto-toplev/texinfo
-       mkdir proto-toplev/texinfo/fsf
-       ln -s ../../../texinfo/fsf/texinfo.tex proto-toplev/texinfo/fsf/
+       ln -s ../../texinfo/texinfo.tex proto-toplev/texinfo/
        chmod og=u `find proto-toplev -print`
        (VER=`sed <gdb/Makefile.in -n 's/VERSION = //p'`; \
                echo "==> Making gdb-$$VER.tar.Z"; \
@@ -1938,8 +1503,5 @@ make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/fsf/texinfo.tex
                tar cfh - gdb-$$VER \
                | compress -v >gdb-$$VER.tar.Z)
 
-force_update:
-
-nothing:
 
 # end of Makefile.in
This page took 0.053319 seconds and 4 git commands to generate.