* h8300-tdep.c, tm-h8300.h: turn off some experimental features
[deliverable/binutils-gdb.git] / Makefile.in
index 8d9e0125999c2183fd39d85612ba1a02b1d845b7..d8c903a08c31d96ee2c27a3fe4f5c821ef1e979f 100644 (file)
@@ -1,6 +1,6 @@
 #
 # Makefile for directory with subdirs to build.
-#   Copyright (C) 1990, 1991 Cygnus Support
+#   Copyright (C) 1990, 1991, 1992 Free Software Foundation
 #
 # This file is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -21,10 +21,15 @@ srcdir = .
 
 prefix = /usr/local
 
+exec_prefix = $(prefix)
+bindir = $(exec_prefix)/bin
+libdir = $(exec_prefix)/lib
+tooldir = $(libdir)
+
+program_transform_name =
+
 datadir = $(prefix)/lib
-bindir = $(prefix)/bin
-libdir = $(prefix)/lib
-mandir = $(datadir)/man
+mandir = $(prefix)/man
 man1dir = $(mandir)/man1
 man2dir = $(mandir)/man2
 man3dir = $(mandir)/man3
@@ -34,31 +39,53 @@ man6dir = $(mandir)/man6
 man7dir = $(mandir)/man7
 man8dir = $(mandir)/man8
 man9dir = $(mandir)/man9
-infodir = $(datadir)/info
+infodir = $(prefix)/info
 includedir = $(prefix)/include
 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`
+
+LEX = `if [ -f $${rootme}/flex/flex ] ; \
+       then echo $${rootme}/flex/flex ; \
+       else echo flex ; fi`
+
+MAKEINFO = `if [ -f $${rootme}/texinfo/C/makeinfo ] ; \
+       then echo $${rootme}/texinfo/C/makeinfo ; \
+       else echo makeinfo ; fi`
 
-BISON = `if [ -d $(unsubdir)/../bison ] ; \
-       then echo \`pwd\`/$(unsubdir)/../bison$(subdir)/bison -L \`pwd\`/$(unsubdir)/../bison$(subdir)/ -y ; \
-       else echo bison -y ; fi`
 
-MAKEINFO = makeinfo
-FRESHMAKEINFO = `if [ -d $(unsubdir)/../texinfo/C ] ; \
-       then echo \`pwd\`/$(unsubdir)/../texinfo/C$(subdir)/makeinfo ; \
-       else echo echo ; fi`
+# libraries that may need to be augmented on a system-by-system basis
+X11_LIB = -lX11
 
-#\`(cd $(srcdir)/bison ; \\`pwd\\`)\`
-SUBDIRS = libiberty glob readline bfd gdb binutils ld gas gcc libg++ gnulib clib
+# 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,1596 +94,1273 @@ 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`
+
+# FIXME: This is badly named.
+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 all sub-makes.
+# Please keep these in alphabetical order.
+BASE_FLAGS_TO_PASS = \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "AR_FOR_TARGET=$(AR_FOR_TARGET)" \
+       "AS_FOR_TARGET=$(AS_FOR_TARGET)" \
+       "BISON=$(BISON)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+       "CC_FOR_TARGET=$(CC_FOR_TARGET)" \
+       "CFLAGS=$(CFLAGS)" \
+$(start-sanitize-chill)\
+       "CHILLFLAGS=$(CHILLFLAGS)" \
+       "CHILL_FOR_TARGET=$(CHILL_FOR_TARGET)" \
+       "CHILL_LIB=$(CHILL_LIB)" \
+$(end-sanitize-chill)\
+       "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
+       "CXXFLAGS=$(CXXFLAGS)" \
+       "CXX_FOR_TARGET=$(CXX_FOR_TARGET)" \
+       "GCC_FOR_TARGET=$(GCC_FOR_TARGET)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "LEX=$(LEX)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "NM_FOR_TARGET=$(NM_FOR_TARGET)" \
+       "RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \
+       "XTRAFLAGS_FOR_TARGET=$(XTRAFLAGS)" \
+       "exec_prefix=$(exec_prefix)" \
+       "prefix=$(prefix)" \
+       "tooldir=$(tooldir)" 
+
+# Flags to pass down to most sub-makes, in which we're building with
+# the host environment.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_HOST_FLAGS = \
+       "AR=$(AR)" \
+       "AS=$(AS)" \
+       "CC=$(CC)" \
+       "CXX=$(CXX)" \
+       "NM=$(NM)" \
+       "RANLIB=$(RANLIB)" \
+       "XTRAFLAGS="
+
+FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_HOST_FLAGS)
+
+# 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)"
+
+# Shell case of subdirectories which are built with the target environment.
+TARGET_LIBS=libg++ | xiberty | newlib
+$(start-sanitize-chill)
+TARGET_LIBS=libg++ | xiberty | newlib | chillrt
+$(end-sanitize-chill)
+
+# Flags to pass down to makes which are built with the target environment.
+# The double $ decreases the length of the command line; the variables
+# are set in BASE_FLAGS_TO_PASS, and the sub-make will expand them.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_TARGET_FLAGS = \
+       'AR=$$(AR_FOR_TARGET)' \
+       'AS=$$(AS_FOR_TARGET)' \
+       'CC=$$(CC_FOR_TARGET)' \
+       'CXX=$$(CXX_FOR_TARGET)' \
+       'NM=$$(NM_FOR_TARGET)' \
+       'RANLIB=$$(RANLIB_FOR_TARGET)' \
+       'XTRAFLAGS=$$(XTRAFLAGS_FOR_TARGET)'
+
+TARGET_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_TARGET_FLAGS)
+
+# 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.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_GCC_FLAGS = \
+       'AR=$$(AR_FOR_TARGET)' \
+       "AS=$(AS)" \
+       "CC=$(CC)" \
+       "CXX=$(CXX)" \
+       "NM=$(NM)" \
+       'RANLIB=$$(RANLIB_FOR_TARGET)' \
+       "XTRAFLAGS="
+
+GCC_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_GCC_FLAGS)
+
+# The first rule in the file had better be this one.  Don't put any above it.
 all:   $(ALL)
 
-info:  cfg-paper.info
-       $(MAKE) subdir_do DO=info "DODIRS=$(SUBDIRS)"
+.PHONY: all check dvi info install-info install-info-dirs
+.PHONY: do-info do-check do-dvi do-install-info
+.PHONY: do-clean do-mostlyclean do-distclean do-realclean
+.NOEXPORT:
+
+# Do a target for all the subdirectories.  A ``make do-X'' will do a
+# ``make X'' in all subdirectories (because, in general, X depends on
+# fdo-X, a ``make X'' will also do this, but it may do additional work
+# as well).
+# This target ensures that $(BASE_FLAGS_TO_PASS) appears only once,
+# because it is so large that it can easily overflow the command line
+# length limit on some systems.
+do-info do-check do-dvi do-install-info do-clean do-mostlyclean do-distclean do-realclean:
+       @target=`echo $@ | sed -e 's/^do-//'`; \
+       rootme=`pwd`; export rootme; \
+       srcroot=`cd $(srcdir); pwd`; export srcroot; \
+       for i in $(SUBDIRS); do \
+         if [ -f ./$$i/localenv ] || [ -f ./$$i/Makefile ]; then \
+           case $$i in \
+           $(TARGET_LIBS) ) \
+             extra_flags=`echo $(EXTRA_TARGET_FLAGS)`; \
+             ;; \
+           gcc) \
+             extra_flags=`echo $(EXTRA_GCC_FLAGS)`; \
+             ;; \
+           *) \
+             extra_flags=`echo $(EXTRA_HOST_FLAGS)`; \
+             ;; \
+           esac ; \
+           export extra_flags; \
+           if (cd ./$$i; \
+               $(MAKE) $(BASE_FLAGS_TO_PASS) $${extra_flags} $${target}); \
+           then true; else exit 1; fi; \
+         else true; fi; \
+       done
 
-clean-info:
-       $(MAKE) subdir_do DO=clean-info "DODIRS=$(SUBDIRS)"
-       rm -f cfg-paper.info
+info: do-info
+check: do-check
+dvi: do-dvi
 
-cfg-paper.info: cfg-paper.texi
-       $(MAKEINFO) -o cfg-paper.info $(srcdir)/cfg-paper.texi
+install-info: install-info-dirs do-install-info dir.info
+       $(INSTALL_DATA) dir.info $(infodir)/dir.info
 
-configure.info: configure.texi
-       $(MAKEINFO) -o configure.info $(srcdir)/configure.texi
+do-install-info: install-info-dirs
+
+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 local-clean local-distclean
+
+local-clean:
+       -rm -f *.a TEMP errs core *.o *~ \#* TAGS *.E
+
+local-distclean:
+       -rm -f Makefile config.status
+
+clean: do-clean local-clean
+mostlyclean: do-mostlyclean local-clean
+distclean: do-distclean local-clean local-distclean
+realclean: do-realclean local-clean local-distclean
+
+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 ./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
 
-install-info: install-info-dirs force
-       $(MAKE) subdir_do DO=install-info "DODIRS=$(SUBDIRS)"
-       $(INSTALL_DATA) cfg-paper.info $(infodir)/cfg-paper.info
-       $(MAKE) dir.info install-dir.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
 
-install-dir.info:
-       $(INSTALL_DATA) dir.info $(infodir)/dir.info
+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
 
-# clib prms
-#      all-gnulib
-all.normal: all-texinfo all-bison all-byacc all-flex all-ld \
-       all-gcc all-gas all-binutils \
-       all-libg++ all-gdb all-make all-cvs all-emacs all-ispell all-fileutils
-all.cross: all-bison all-ld all-gnulib all-gdb
-#      $(MAKE) subdir_do DO=all "DODIRS=$(SUBDIRS) $(OTHERS)"
-
-clean: clean-libiberty clean-texinfo clean-bfd clean-binutils \
-       clean-bison clean-byacc clean-flex clean-ld clean-gas \
-       clean-gcc clean-gnulib clean-readline clean-glob clean-gdb \
-       clean-make clean-diff clean-grep clean-rcs clean-gdbm \
-       clean-cvs clean-emacs clean-ispell clean-fileutils
-       rm -rf *.a TEMP errs core *.o *~ \#* TAGS *.E
-
-install: $(INSTALL_TARGET) $(srcdir)/configure.man
-       $(INSTALL_DATA) $(srcdir)/configure.man $(man1dir)/configure.1
-
-install.all: install-dirs install-libiberty install-texinfo \
-       install-binutils install-bison install-byacc install-flex \
-       install-ld install-gas install-gcc install-gnulib \
-       install-readline install-glob install-gdb install-make \
-       install-cvs install-emacs install-ispell install-fileutils
-install.cross: install-dirs install-libiberty install-binutils install-bison \
-       install-byacc install-ld install-gas install-gnulib \
-       install-readline install-glob install-gdb
+### 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-deja-gnu: force
+       @if [ -f ./deja-gnu/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./deja-gnu; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### autoconf
+all-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### etc
+all-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (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
 
 ### libiberty
-.PHONY: all-libiberty just-libiberty
-all-libiberty: just-libiberty
-just-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(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
-
-clean-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-libiberty: force
+       @if [ -f ./libiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libiberty; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./libiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libiberty; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### 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 ./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
 
 ### texinfo
-.PHONY: all-texinfo just-texinfo
-all-texinfo: just-texinfo
-just-texinfo: just-libiberty force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(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
-
-clean-texinfo: force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-texinfo: all-libiberty
+       @if [ -f ./texinfo/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./texinfo; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-texinfo: force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./texinfo/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./texinfo; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### bfd
-.PHONY: all-bfd just-bfd
-all-bfd: just-bfd
-just-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(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
-
-clean-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-bfd: force
+       @if [ -f ./bfd/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./bfd; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./bfd/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./bfd; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+
+### opcodes
+all-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### binutils
-.PHONY: all-binutils just-binutils
-all-binutils: just-binutils
-just-binutils: just-libiberty just-bfd force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(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
-
-clean-binutils: force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-binutils: all-opcodes all-libiberty all-bfd all-flex
+       @if [ -f ./binutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./binutils; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-binutils: force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./binutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./binutils; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### newlib
+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) $(TARGET_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-newlib: force
+       @if [ -f ./newlib/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./newlib; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### 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 ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./chillrt; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-chillrt: force
+       @if [ -f ./chillrt/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./chillrt; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+### end-sanitize-chill
+
+### gprof
+all-gprof: all-libiberty all-bfd
+       @if [ -f ./gprof/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-gprof: force
+       @if [ -f ./gprof/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### byacc
-.PHONY: all-byacc just-byacc
-all-byacc: just-byacc
-just-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(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
-
-clean-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-byacc: force
+       @if [ -f ./byacc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(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
-
-### bison
-.PHONY: all-bison just-bison
-all-bison: just-bison
-just-bison: just-libiberty force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(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
-
-clean-bison: force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(MAKE) \
-                       "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-bison: force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./byacc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### flex
+all-flex: all-libiberty
+       @if [ -f ./flex/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
+install-flex: force
+       @if [ -f ./flex/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 ### gcc
-.PHONY: all-gcc just-gcc
-all-gcc: just-gcc
-#just-gcc: just-libiberty just-bison just-gnulib1 force
-just-gcc: just-libiberty just-bison force
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(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
-
-clean-gcc: force
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(MAKE) \
-                       "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-gcc:
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+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) $(GCC_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-gcc: force
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./gcc; \
+               $(MAKE) $(GCC_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### readline
-.PHONY: all-readline just-readline
-all-readline: just-readline
-just-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(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
-
-clean-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-readline: force
+       @if [ -f ./readline/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./readline; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./readline/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./readline; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### glob
-.PHONY: all-glob just-glob
-all-glob: just-glob
-just-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(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
-
-clean-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-glob: force
+       @if [ -f ./glob/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./glob; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./glob/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./glob; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### gas
-.PHONY: all-gas just-gas
-all-gas: just-gas
-just-gas: just-libiberty just-bfd force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(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
-
-clean-gas: force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-gas: all-libiberty all-opcodes all-bfd
+       @if [ -f ./gas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gas; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-gas: force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./gas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gas; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### gas
+all-tgas: all-libiberty all-bfd
+       @if [ -f ./tgas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./tgas; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
+
 ### ld
-.PHONY: all-ld just-ld
-all-ld: just-ld
-just-ld: just-libiberty just-bfd just-bison force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(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
-
-clean-ld: force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-ld: all-libiberty all-bfd all-byacc all-flex
+       @if [ -f ./ld/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ld; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-ld: force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(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
-
-### gnulib (and gnulib1)
-.PHONY: all-gnulib just-gnulib1 just-gnulib
-just-gnulib1: all-gas all-binutils force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       gnulib1.a) ; \
-       else \
-               true ; \
-       fi
-
-clean-gnulib1: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean-gnulib1) ; \
-       else \
-               true ; \
-       fi
-
-install-gnulib1: force
-       echo gnulib1 is a component, not an installable target
-
-all-gnulib: just-gnulib
-just-gnulib: all-gcc all-gas all-binutils force
-       true
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(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
-
-clean-gnulib: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "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-gnulib: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./ld/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ld; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### gdb
-.PHONY: all-gdb just-gdb
-all-gdb: just-gdb
-just-gdb: just-bfd just-libiberty just-readline just-glob just-bison force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(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
-
-clean-gdb: force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+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 ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-gdb: force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./gdb/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### make
-.PHONY: all-make just-make
-all-make: just-make
-just-make: all-libiberty force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(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
-
-clean-make: force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-make: all-libiberty
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-make: force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### diff
-.PHONY: all-diff just-diff
-all-diff: just-diff
-just-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff$(subdir); \
-               $(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
-
-clean-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-diff: force
+       @if [ -f ./diff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./diff; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff/$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./diff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./diff/; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### grep
-.PHONY: all-grep just-grep
-all-grep: just-grep
-just-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(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
-
-clean-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+all-grep: force
+       @if [ -f ./grep/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./grep/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### rcs
-.PHONY: all-rcs just-rcs
-all-rcs: just-rcs
-just-rcs: just-diff just-grep force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(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
-
-clean-rcs: force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(MAKE) \
-                       "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-rcs: install-grep install-diff force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(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
-
-### gdbm
-.PHONY: all-gdbm just-gdbm
-all-gdbm: just-gdbm
-just-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(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
-
-clean-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(MAKE) \
-                       "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-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+all-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### cvs
-.PHONY: all-cvs just-cvs
-all-cvs: just-cvs just-rcs just-grep just-diff
-just-cvs: just-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(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
-
-clean-cvs: clean-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(MAKE) \
-                       "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-cvs: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+all-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### patch
+all-patch: force
+       @if [ -f ./patch/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-patch: force
+       @if [ -f ./patch/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) \
+                       bindir=$(bindir) \
+                       man1dir=$(man1dir) install) ; \
        else \
                true ; \
        fi
 
 ### emacs
-.PHONY: all-emacs just-emacs
-all-emacs: just-emacs
-just-emacs: force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(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
-
-clean-emacs: force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(MAKE) \
-                       "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-emacs: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+all-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### ispell
-.PHONY: all-ispell just-ispell
-all-ispell: just-ispell
-just-ispell: all-emacs force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(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
-
-clean-ispell: force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(MAKE) \
-                       "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-ispell: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+all-ispell: all-emacs
+       @if [ -f ./ispell/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### flex
-.PHONY: all-flex just-flex
-all-flex: just-flex
-just-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(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
-
-clean-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+install-ispell: force
+       @if [ -f ./ispell/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+### send_pr
+all-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-### fileutils
-.PHONY: all-fileutils just-fileutils
-all-fileutils: just-fileutils
-just-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(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
-
-clean-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(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) ; \
+install-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-install-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(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) ; \
+### libm
+all-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libm; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libm; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### libg++
-.PHONY: all-libg++ just-libg++
-all-libg++: just-libg++
-# NOTE!  We have added GXX= to the $(MAKE) line!!!  Do not clone this one.
-just-libg++: just-gcc force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(MAKE) \
-                       GXX=`cd $(unsubdir)/..$(subdir); pwd`"/gcc/gcc -B"`cd $(unsubdir)/..$(subdir);pwd`"/gcc/ -I"`cd $(unsubdir)/..$(subdir); pwd`/gcc/include \
-                       "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
-
-clean-libg++: force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(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) ; \
+
+all-libg++: all-gas all-ld all-gcc all-xiberty all-newlib
+       @if [ -f ./libg++/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 install-libg++: force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(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) ; \
+       @if [ -f ./libg++/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               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-tcl: force
+       @if [ -f ./tcl/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tcl; \
+               $(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: force
-       for i in $(DODIRS); do \
-               if [ -f $(unsubdir)/$$i/localenv ] ; then \
-                       if (cd $(unsubdir)/$$i$(subdir); \
-                               $(MAKE) \
-                                       "against=$(against)" \
-                                       "BISON=$(BISON)" \
-                                       "MAKEINFO=$(MAKEINFO)" \
-                                       $(DO)) ; then true ; \
-                               else exit 1 ; fi ; \
-               else if [ -d $(unsubdir)/$$i ] ; then \
-                       if (cd $(unsubdir)/$$i$(subdir); \
-                               $(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 ; \
-       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 $(unsubdir)/gas$(subdir)/stdarg.h
-       $(MAKE) subdir_do "DO=all info" "DODIRS=$(SUBDIRS)" \
-               "CC=`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/gcc \
-               -O $(GCCVERBOSE) -I`pwd`/$(unsubdir)/gcc$(subdir)/include \
-               -B`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/gas$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/ld$(subdir)/$(stagepass)/" \
-               "AR=`pwd`/$(unsubdir)/binutils$(subdir)/$(stagepass)/ar" \
-               "LD=`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/gcc $(GCCVERBOSE)" \
-               "RANLIB=`pwd`/$(unsubdir)/binutils$(subdir)/$(stagepass)/ranlib" \
-               "LOADLIBES=`pwd`/$(unsubdir)/gnulib$(subdir)/$(stagepass)/gnulib.a /lib/libc.a" \
-               "LDFLAGS=-nostdlib /lib/crt0.o \
-               -L`pwd`/$(unsubdir)/gnulib$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/ld$(subdir)/$(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.
+### tk
+all-tk: all-tcl
+       @if [ -f ./tk/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tk; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-tk: force
+       @if [ -f ./tk/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./tk; \
+               $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### expect
+all-expect: all-tcl
+       @if [ -f ./expect/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./expect; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-expect: force
+       @if [ -f ./expect/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd`; export srcroot ; \
+               (cd ./expect; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### sim
+all-sim: all-bfd 
+       @if [ -f ./sim/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./sim; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-sim: force
+       @if [ -f ./sim/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./sim; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### 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 ./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
+
+install-find: force
+       @if [ -f ./find/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (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-gawk: force
+       @if [ -f ./gawk/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gawk; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### 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 ./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
+
+install-sed: force
+       @if [ -f ./sed/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (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-time: force
+       @if [ -f ./time/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./time; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### wdiff
+all-wdiff: force
+       @if [ -f ./wdiff/Makefile ] ; then \
+         rootme=`pwd` ; export rootme ; \
+               (cd ./wdiff; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+install-wdiff: force
+       @if [ -f ./wdiff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./wdiff; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       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
+
+install-uudecode: force
+       @if [ -f ./uudecode/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (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
+
+install-shellutils: force
+       @if [ -f ./shellutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (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-textutils: force
+       @if [ -f ./textutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./textutils; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+
+
+### other supporting targets
 
 MAKEDIRS= \
        $(prefix) \
-       $(bindir) \
-       $(libdir) \
-       $(includedir) \
-       $(datadir) \
-       $(docdir) \
-       $(mandir) \
-       $(man1dir) \
-       $(man5dir)
+       $(exec_prefix) \
+       $(tooldir)
+
+#      $(bindir) \
+#      $(libdir) \
+#      $(includedir) \
+#      $(datadir) \
+#      $(docdir) \
+#      $(mandir) \
+#      $(man1dir) \
+#      $(man5dir)
 
 #      $(man2dir) \
 #      $(man3dir) \
@@ -1665,28 +1369,39 @@ MAKEDIRS= \
 #      $(man7dir) \
 #      $(man8dir)
 
-install-dirs: force
+install-dirs:
        for i in $(MAKEDIRS) ; do \
                echo Making $$i... ; \
-               if [ -d $$i ] ; then true ; else mkdir $$i || exit 1 ; fi ; \
+               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: force
+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
+       -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
 
-dir.info: force
-       $(srcdir)/texinfo/gen-info-dir $(infodir) > dir.info.new
+dir.info: do-install-info
+       $(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: FORCE
+TAGS:
        etags `$(MAKE) ls`
 
 ls:
@@ -1712,41 +1427,52 @@ 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
-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 \
                ln -s ../$$i . ; \
        done)
-       # Take out texinfo from configurable dirs
+       # Put only one copy (four hard links) of COPYING in the tar file.
+       rm                          proto-toplev/bfd/COPYING
+       ln proto-toplev/gdb/COPYING proto-toplev/bfd/COPYING
+       rm                          proto-toplev/include/COPYING
+       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 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
+       sed -e '/^all\.normal: /s/\all-texinfo //' \
+           -e '/^      install-texinfo /d' \
+           -e '\/^BISON =/,\/^$$/c\
+               BISON = bison -y' \
+       <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"; \
@@ -1754,8 +1480,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.070372 seconds and 4 git commands to generate.