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