* z8k-dis.c (unparse_instr): prettier tabs
[deliverable/binutils-gdb.git] / Makefile.in
index 318f8d99f5bda6877f9eac0ad95bc39f91d4c4e7..c4f3064322fdcba1c2060445e8dcf16326e73444 100644 (file)
@@ -1,6 +1,6 @@
 #
 # Makefile for directory with subdirs to build.
-#   Copyright (C) 1990, 1991 Cygnus Support
+#   Copyright (C) 1990, 1991, 1992 Free Software Foundation
 #
 # This file is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -21,10 +21,15 @@ srcdir = .
 
 prefix = /usr/local
 
+exec_prefix = $(prefix)
+bindir = $(exec_prefix)/bin
+libdir = $(exec_prefix)/lib
+tooldir = $(libdir)
+
+program_transform_name =
+
 datadir = $(prefix)/lib
-bindir = $(prefix)/bin
-libdir = $(prefix)/lib
-mandir = $(datadir)/man
+mandir = $(prefix)/man
 man1dir = $(mandir)/man1
 man2dir = $(mandir)/man2
 man3dir = $(mandir)/man3
@@ -34,7 +39,7 @@ man6dir = $(mandir)/man6
 man7dir = $(mandir)/man7
 man8dir = $(mandir)/man8
 man9dir = $(mandir)/man9
-infodir = $(datadir)/info
+infodir = $(prefix)/info
 includedir = $(prefix)/include
 docdir = $(datadir)/doc
 
@@ -44,21 +49,31 @@ INSTALL = install -c
 INSTALL_PROGRAM = $(INSTALL)
 INSTALL_DATA = $(INSTALL)
 
+AS = as
 AR = ar
 AR_FLAGS = qc
+CFLAGS = -g
 RANLIB = ranlib
+NM = nm
+
+BISON = `if [ -f $${rootme}/byacc/byacc ] ; \
+           then echo $${rootme}/byacc/byacc ; \
+           else echo bison -y ; \
+       fi`
 
-BISON = `if [ -d $(unsubdir)/../bison ] ; \
-       then echo \`pwd\`/$(unsubdir)/../bison$(subdir)/bison -L \`pwd\`/$(unsubdir)/../bison$(subdir)/ -y ; \
-       else echo bison -y ; fi`
+LEX = `if [ -f $${rootme}/flex/flex ] ; \
+       then echo $${rootme}/flex/flex ; \
+       else echo flex ; fi`
 
-MAKEINFO = makeinfo
-FRESHMAKEINFO = `if [ -d $(unsubdir)/../texinfo/C ] ; \
-       then echo \`pwd\`/$(unsubdir)/../texinfo/C$(subdir)/makeinfo ; \
-       else echo echo ; fi`
+MAKEINFO = `if [ -f $${rootme}/texinfo/C/makeinfo ] ; \
+       then echo $${rootme}/texinfo/C/makeinfo ; \
+       else echo makeinfo ; fi`
 
-#\`(cd $(srcdir)/bison ; \\`pwd\\`)\`
-SUBDIRS = libiberty glob readline bfd gdb binutils ld gas gcc libg++ gnulib clib
+# C compiler to use to create programs which must be run in the build
+# environment.
+CC_FOR_BUILD = $(CC)
+
+SUBDIRS = libiberty mmalloc glob readline opcodes bfd gdb  binutils ld gas tgas gcc libg++ newlib
 OTHERS = 
 
 ALL = all.normal
@@ -67,1549 +82,1051 @@ INSTALL_TARGET = install.all
 ### for debugging
 #GCCVERBOSE=-v
 
+CC_FOR_TARGET = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    echo $${rootme}/gcc/gcc -B$${rootme}/gcc/; \
+  else \
+    if [ "$(host_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; then \
+      echo $(CC); \
+    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_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; 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_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; 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_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; 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_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; then \
+      echo $(NM); \
+    else \
+       t='$(program_transform_name)'; echo nm | sed -e '' $$t ; \
+    fi \
+  fi`
+
+XTRAFLAGS = ` \
+  if [ -f $${rootme}/gcc/Makefile ] ; then \
+    if [ "$(host_cpu)-$(host_vendor)-$(host_os)" = "$(target_cpu)-$(target_vendor)-$(target_os)" ] ; then \
+      echo -I$${rootme}/gcc/include ; \
+    else \
+      echo -I$${rootme}/gcc/include -I$${rootme}/newlib/targ-include -I$${srcroot}/newlib/libc/include ; \
+    fi ; \
+  else \
+     echo ; \
+  fi`
 
 #### host and target specific makefile fragments come in here.
 ###
 
+# Flags to pass down to sub-makes
+FLAGS_TO_PASS = \
+       "prefix=$(prefix)" \
+       "exec_prefix=$(exec_prefix)" \
+       "tooldir=$(tooldir)" \
+       "AR=$(AR)" \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "CC=$(CC)" \
+       "CFLAGS=$(CFLAGS)" \
+       "RANLIB=$(RANLIB)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "BISON=$(BISON)" \
+       "LEX=$(LEX)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)"
+
+# Flags to pass down to makes which are built with the target
+# environment (e.g. libg++, xiberty, newlib).
+TARGET_FLAGS_TO_PASS = \
+       "prefix=$(prefix)" \
+       "exec_prefix=$(exec_prefix)" \
+       "tooldir=$(tooldir)" \
+       "AR_FLAGS=$(AR_FLAGS)" \
+       "CFLAGS=$(CFLAGS)" \
+       "LOADLIBES=$(LOADLIBES)" \
+       "LDFLAGS=$(LDFLAGS)" \
+       "BISON=$(BISON)" \
+       "LEX=$(LEX)" \
+       "MAKEINFO=$(MAKEINFO)" \
+       "INSTALL=$(INSTALL)" \
+       "INSTALL_DATA=$(INSTALL_DATA)" \
+       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
+       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+       "CC=$(CC_FOR_TARGET)" \
+       "AS=$(AS_FOR_TARGET)" \
+       "AR=$(AR_FOR_TARGET)" \
+       "RANLIB=$(RANLIB_FOR_TARGET)" \
+       "NM=$(NM_FOR_TARGET)" \
+       "XTRAFLAGS=$(XTRAFLAGS)"
+
 .PHONY: all info install-info clean-info
+.NOEXPORT:
 
 all:   $(ALL)
 
-info:  cfg-paper.info
-       $(MAKE) subdir_do DO=info "DODIRS=$(SUBDIRS)"
+info:  
+       @rootme=`pwd` ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) subdir_do DO=info "DODIRS=$(SUBDIRS)" 
 
-clean-info:
-       $(MAKE) subdir_do DO=clean-info "DODIRS=$(SUBDIRS)"
-       rm -f cfg-paper.info
-
-cfg-paper.info: cfg-paper.texi
-       $(MAKEINFO) -o cfg-paper.info $(srcdir)/cfg-paper.texi
-
-configure.info: configure.texi
-       $(MAKEINFO) -o configure.info $(srcdir)/configure.texi
+check:
+       @rootme=`pwd` ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) DO=check "DODIRS=$(SUBDIRS)" subdir_do
 
+clean-info:
+       @rootme='pwd' ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) DO=clean-info "DODIRS=$(SUBDIRS)" subdir_do
+       
 install-info: install-info-dirs force
-       $(MAKE) subdir_do DO=install-info "DODIRS=$(SUBDIRS)"
-       $(INSTALL_DATA) cfg-paper.info $(infodir)/cfg-paper.info
-       $(MAKE) dir.info install-dir.info
+       -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
 
-# clib prms
-#      all-gnulib
-all.normal: all-texinfo all-bison all-byacc all-flex all-ld \
-       all-gcc all-gas all-binutils \
-       all-libg++ all-gdb all-make all-cvs all-patch all-emacs all-ispell all-fileutils
-all.cross: all-bison all-ld all-gnulib all-gdb
-#      $(MAKE) subdir_do DO=all "DODIRS=$(SUBDIRS) $(OTHERS)"
-
-clean: clean-libiberty clean-texinfo clean-bfd clean-binutils \
-       clean-bison clean-byacc clean-flex clean-ld clean-gas \
-       clean-gcc clean-gnulib clean-readline clean-glob clean-gdb \
-       clean-make clean-diff clean-grep clean-rcs clean-gdbm \
-       clean-cvs clean-patch clean-emacs clean-ispell clean-fileutils
-       rm -rf *.a TEMP errs core *.o *~ \#* TAGS *.E
-
-install: $(INSTALL_TARGET) $(srcdir)/configure.man
-       $(INSTALL_DATA) $(srcdir)/configure.man $(man1dir)/configure.1
-
-install.all: install-dirs install-libiberty install-texinfo \
-       install-binutils install-bison install-byacc install-flex \
-       install-ld install-gas install-gcc install-gnulib \
-       install-readline install-glob install-gdb install-make \
-       install-cvs install-patch install-emacs install-ispell install-fileutils
-install.cross: install-dirs install-libiberty install-binutils install-bison \
-       install-byacc install-ld install-gas install-gnulib \
-       install-readline install-glob install-gdb
+all.normal: 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-gdb \
+       all-make all-rcs all-cvs all-diff all-grep \
+       all-patch all-emacs all-ispell all-etc \
+       all-newlib all-gprof all-send_pr all-libm
+
+all.cross: all-libiberty all-mmalloc all-gas all-byacc all-flex all-ld \
+        all-opcodes all-bfd all-readline all-gdb all-binutils all-gcc \
+       all-newlib
+
+clean: clean-autoconf clean-libiberty clean-mmalloc clean-texinfo \
+       clean-bfd clean-newlib clean-binutils clean-flex \
+       clean-byacc clean-ld clean-gas clean-etc clean-opcodes \
+       clean-gcc clean-readline clean-glob clean-gdb \
+       clean-make clean-diff clean-grep clean-rcs \
+       clean-cvs clean-patch clean-emacs clean-ispell \
+       clean-libg++ clean-gprof clean-send_pr clean-libm
+       -rm -rf *.a TEMP errs core *.o *~ \#* TAGS *.E
+
+clean-stamps:
+       -rm -f all-*
+
+install: $(INSTALL_TARGET) 
+       -parent=`echo $(man1dir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(man1dir) ] ; then true ; else mkdir $(man1dir) ; fi
+
+install.all: install-no-fixedincludes
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) install-headers) ; \
+       else \
+               true ; \
+       fi
+install-no-fixedincludes: install-dirs gcc-no-fixedincludes \
+       install-autoconf \
+       install-bfd \
+       install-binutils \
+       install-opcodes \
+       install-byacc \
+       install-cvs \
+       install-diff \
+       install-emacs \
+       install-etc \
+       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 \
+       install-patch \
+       install-rcs \
+       install-readline \
+       install-send_pr \
+       install-texinfo 
+       
+gcc-no-fixedincludes:
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) install install-man \
+                       "INSTALL_HEADERS=install-common-headers install-float-h install-limits-h") ; \
+       else \
+               true ; \
+       fi
+
+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 install-gcc install-etc
+
+### autoconf
+all-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-autoconf: force
+       @if [ -f ./autoconf/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./autoconf; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### etc
+all-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./etc; $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./etc; $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-etc: force
+       @if [ -f ./etc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./etc; $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 
 ### libiberty
-.PHONY: all-libiberty just-libiberty
-all-libiberty: just-libiberty
-just-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-libiberty: force
+       @if [ -f ./libiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libiberty; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./libiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libiberty; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-libiberty: force
-       if [ -d $(unsubdir)/libiberty ] ; then \
-               (cd $(unsubdir)/libiberty$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./libiberty/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libiberty; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### mmalloc
+all-mmalloc: force
+       @if [ -f ./mmalloc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./mmalloc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-mmalloc: force
+       @if [ -f ./mmalloc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./mmalloc; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-mmalloc: force
+       @if [ -f ./mmalloc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./mmalloc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### texinfo
-.PHONY: all-texinfo just-texinfo
-all-texinfo: just-texinfo
-just-texinfo: just-libiberty force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-texinfo: all-libiberty
+       @if [ -f ./texinfo/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./texinfo; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-texinfo: force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./texinfo/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./texinfo; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-texinfo: force
-       if [ -d $(unsubdir)/texinfo ] ; then \
-               (cd $(unsubdir)/texinfo$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./texinfo/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./texinfo; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### bfd
-.PHONY: all-bfd just-bfd
-all-bfd: just-bfd
-just-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-bfd: force
+       @if [ -f ./bfd/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./bfd; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./bfd/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./bfd; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-bfd: force
-       if [ -d $(unsubdir)/bfd ] ; then \
-               (cd $(unsubdir)/bfd$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./bfd/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./bfd; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+
+### opcodes
+all-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-opcodes: force
+       @if [ -f ./opcodes/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./opcodes; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### binutils
-.PHONY: all-binutils just-binutils
-all-binutils: just-binutils
-just-binutils: just-libiberty just-bfd force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-binutils: all-opcodes all-libiberty all-bfd all-flex
+       @if [ -f ./binutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./binutils; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-binutils: force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./binutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./binutils; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-binutils: force
-       if [ -d $(unsubdir)/binutils ] ; then \
-               (cd $(unsubdir)/binutils$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./binutils/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./binutils; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### newlib
+all-newlib: all-binutils all-ld all-gas all-gcc
+       @if [ -f ./newlib/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./newlib; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-newlib: force
+       @if [ -f ./newlib/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./newlib; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-newlib: force
+       @if [ -f ./newlib/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./newlib; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### gprof
+all-gprof: all-libiberty all-bfd
+       @if [ -f ./gprof/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-gprof: force
+       @if [ -f ./gprof/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-gprof: force
+       @if [ -f ./gprof/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gprof; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### byacc
-.PHONY: all-byacc just-byacc
-all-byacc: just-byacc
-just-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-byacc: force
+       @if [ -f ./byacc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./byacc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-byacc: force
-       if [ -d $(unsubdir)/byacc ] ; then \
-               (cd $(unsubdir)/byacc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
-       else \
-               true ; \
-       fi
-
-### bison
-.PHONY: all-bison just-bison
-all-bison: just-bison
-just-bison: just-libiberty force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-
-clean-bison: force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-bison: force
-       if [ -d $(unsubdir)/bison ] ; then \
-               (cd $(unsubdir)/bison$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./byacc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./byacc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### flex
+all-flex: all-libiberty
+       @if [ -f ./flex/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-flex: force
+       @if [ -f ./flex/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
+install-flex: force
+       @if [ -f ./flex/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./flex; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
 ### gcc
-.PHONY: all-gcc just-gcc
-all-gcc: just-gcc
-#just-gcc: just-libiberty just-bison just-gnulib1 force
-just-gcc: just-libiberty just-bison force
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-gcc: all-libiberty all-byacc
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-gcc: force
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
-install-gcc:
-       if [ -d $(unsubdir)/gcc ] ; then \
-               (cd $(unsubdir)/gcc$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+install-gcc: force
+       @if [ -f ./gcc/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gcc; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### readline
-.PHONY: all-readline just-readline
-all-readline: just-readline
-just-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-readline: force
+       @if [ -f ./readline/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./readline; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./readline/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./readline; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-readline: force
-       if [ -d $(unsubdir)/readline ] ; then \
-               (cd $(unsubdir)/readline$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./readline/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./readline; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### glob
-.PHONY: all-glob just-glob
-all-glob: just-glob
-just-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-glob: force
+       @if [ -f ./glob/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./glob; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./glob/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./glob; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-glob: force
-       if [ -d $(unsubdir)/glob ] ; then \
-               (cd $(unsubdir)/glob$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./glob/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./glob; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### gas
-.PHONY: all-gas just-gas
-all-gas: just-gas
-just-gas: just-libiberty just-bfd force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-gas: all-libiberty all-opcodes all-bfd
+       @if [ -f ./gas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gas; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-gas: force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./gas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gas; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-gas: force
-       if [ -d $(unsubdir)/gas ] ; then \
-               (cd $(unsubdir)/gas$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./gas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gas; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### gas
+all-tgas: all-libiberty all-bfd
+       @if [ -f ./tgas/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./tgas; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
+
 ### ld
-.PHONY: all-ld just-ld
-all-ld: just-ld
-just-ld: just-libiberty just-bfd just-bison force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-ld: all-libiberty all-bfd all-byacc all-flex
+       @if [ -f ./ld/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ld; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-ld: force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./ld/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ld; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-ld: force
-       if [ -d $(unsubdir)/ld ] ; then \
-               (cd $(unsubdir)/ld$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
-       else \
-               true ; \
-       fi
-
-### gnulib (and gnulib1)
-.PHONY: all-gnulib just-gnulib1 just-gnulib
-just-gnulib1: all-gas all-binutils force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       gnulib1.a) ; \
-       else \
-               true ; \
-       fi
-
-clean-gnulib1: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean-gnulib1) ; \
-       else \
-               true ; \
-       fi
-
-install-gnulib1: force
-       echo gnulib1 is a component, not an installable target
-
-all-gnulib: just-gnulib
-just-gnulib: all-gcc all-gas all-binutils force
-       true
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-
-clean-gnulib: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-gnulib: force
-       if [ -d $(unsubdir)/gnulib ] ; then \
-               (cd $(unsubdir)/gnulib$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./ld/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ld; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### gdb
-.PHONY: all-gdb just-gdb
-all-gdb: just-gdb
-just-gdb: just-bfd just-libiberty just-readline just-glob just-bison force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-gdb: all-bfd all-opcodes all-libiberty all-mmalloc all-readline all-glob all-byacc
+       @if [ -f ./gdb/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-gdb: force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./gdb/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-gdb: force
-       if [ -d $(unsubdir)/gdb ] ; then \
-               (cd $(unsubdir)/gdb$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./gdb/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./gdb; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### make
-.PHONY: all-make just-make
-all-make: just-make
-just-make: all-libiberty force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-make: all-libiberty
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-make: force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-make: force
-       if [ -d $(unsubdir)/make ] ; then \
-               (cd $(unsubdir)/make$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./make/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./make; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### diff
-.PHONY: all-diff just-diff
-all-diff: just-diff
-just-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-diff: force
+       @if [ -f ./diff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./diff; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./diff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./diff; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-diff: force
-       if [ -d $(unsubdir)/diff ] ; then \
-               (cd $(unsubdir)/diff/$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./diff/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./diff/; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### grep
-.PHONY: all-grep just-grep
-all-grep: just-grep
-just-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-grep: force
+       @if [ -f ./grep/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./grep/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-grep: force
-       if [ -d $(unsubdir)/grep ] ; then \
-               (cd $(unsubdir)/grep$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./grep/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./grep; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### rcs
-.PHONY: all-rcs just-rcs
-all-rcs: just-rcs
-just-rcs: just-diff just-grep force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-rcs: force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-rcs: install-grep install-diff force
-       if [ -d $(unsubdir)/rcs ] ; then \
-               (cd $(unsubdir)/rcs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
-       else \
-               true ; \
-       fi
-
-### gdbm
-.PHONY: all-gdbm just-gdbm
-all-gdbm: just-gdbm
-just-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-
-clean-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-gdbm: force
-       if [ -d $(unsubdir)/gdbm ] ; then \
-               (cd $(unsubdir)/gdbm$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./rcs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-rcs: force
+       @if [ -f ./rcs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./rcs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### cvs
-.PHONY: all-cvs just-cvs
-all-cvs: just-cvs just-rcs just-grep just-diff
-just-cvs: just-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-
-clean-cvs: clean-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-cvs: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/cvs ] ; then \
-               (cd $(unsubdir)/cvs$(subdir); \
-               $(MAKE) \
-                       "bindir=$(bindir)" \
-                       "mandir=$(man1dir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+all-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-cvs: force
+       @if [ -f ./cvs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./cvs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### patch
-.PHONY: all-patch just-patch
-all-patch: just-patch
-just-patch: force
-       if [ -d $(unsubdir)/patch ] ; then \
-               (cd $(unsubdir)/patch$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-patch: force
+       @if [ -f ./patch/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-patch: force
-       if [ -d $(unsubdir)/patch ] ; then \
-               (cd $(unsubdir)/patch$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./patch/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-patch: force
-       if [ -d $(unsubdir)/patch ] ; then \
-               (cd $(unsubdir)/patch$(subdir); \
-               $(MAKE) \
+       @if [ -f ./patch/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./patch; \
+               $(MAKE) $(FLAGS_TO_PASS) \
                        bindir=$(bindir) \
-                       man1dir=$(man1dir) \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+                       man1dir=$(man1dir) install) ; \
        else \
                true ; \
        fi
 
 ### emacs
-.PHONY: all-emacs just-emacs
-all-emacs: just-emacs
-just-emacs: force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-emacs: force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./emacs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
-install-emacs: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/emacs ] ; then \
-               (cd $(unsubdir)/emacs$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+install-emacs: force
+       @if [ -f ./emacs/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./emacs; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### ispell
-.PHONY: all-ispell just-ispell
-all-ispell: just-ispell
-just-ispell: all-emacs force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+all-ispell: all-emacs
+       @if [ -f ./ispell/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-ispell: force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./ispell/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
-install-ispell: install-rcs install-gdbm force
-       if [ -d $(unsubdir)/ispell ] ; then \
-               (cd $(unsubdir)/ispell$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+install-ispell: force
+       @if [ -f ./ispell/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./ispell; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
-### flex
-.PHONY: all-flex just-flex
-all-flex: just-flex
-just-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+### send_pr
+all-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
-clean-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+clean-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
-install-flex: force
-       if [ -d $(unsubdir)/flex ] ; then \
-               (cd $(unsubdir)/flex$(subdir); \
-               $(MAKE) \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
-       else \
-               true ; \
-       fi
-
-### fileutils
-.PHONY: all-fileutils just-fileutils
-all-fileutils: just-fileutils
-just-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
-       else \
-               true ; \
-       fi
-
-clean-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
-       else \
-               true ; \
-       fi
-
-install-fileutils: force
-       if [ -d $(unsubdir)/fileutils ] ; then \
-               (cd $(unsubdir)/fileutils$(subdir); \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+install-send_pr: force
+       @if [ -f ./send_pr/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./send_pr; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
+       else \
+               true ; \
+       fi
+
+### libm
+all-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libm; \
+               $(MAKE) $(FLAGS_TO_PASS) all) ; \
+       else \
+               true ; \
+       fi
+
+clean-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libm; \
+               $(MAKE) $(FLAGS_TO_PASS) clean) ; \
+       else \
+               true ; \
+       fi
+
+install-libm: force
+       @if [ -f ./libm/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               (cd ./libm; \
+               $(MAKE) $(FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
 
 ### libg++
-.PHONY: all-libg++ just-libg++
-all-libg++: just-gcc just-libg++
-# NOTE!  We have added GXX= and XTRAFLAGS to the $(MAKE) line!!!
-# Do not clone this one.
-just-libg++: force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(MAKE) \
-                       GXX=`cd $(unsubdir)/..$(subdir); pwd`"/gcc/gcc -B"`cd $(unsubdir)/..$(subdir);pwd`"/gcc/" \
-                       "XTRAFLAGS=-I"`cd $(unsubdir)/..$(subdir); pwd`/gcc/include\
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       all) ; \
+
+all-libg++: all-gas all-ld all-gcc
+       @if [ -f ./libg++/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) all) ; \
        else \
                true ; \
        fi
 
 clean-libg++: force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       clean) ; \
+       @if [ -f ./libg++/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) clean) ; \
        else \
                true ; \
        fi
 
 install-libg++: force
-       if [ -d $(unsubdir)/libg++ ] ; then \
-               (cd $(unsubdir)/libg++$(subdir); \
-               $(MAKE) \
-                       "prefix=$(prefix)" \
-                       "datadir=$(datadir)" \
-                       "mandir=$(mandir)" \
-                       "against=$(against)" \
-                       "AR=$(AR)" \
-                       "AR_FLAGS=$(AR_FLAGS)" \
-                       "CC=$(CC)" \
-                       "RANLIB=$(RANLIB)" \
-                       "LOADLIBES=$(LOADLIBES)" \
-                       "LDFLAGS=$(LDFLAGS)" \
-                       "BISON=$(BISON)" \
-                       "MAKEINFO=$(MAKEINFO)" \
-                       install) ; \
+       @if [ -f ./libg++/Makefile ] ; then \
+               rootme=`pwd` ; export rootme ; \
+               srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
+               (cd ./libg++; \
+               $(MAKE) $(TARGET_FLAGS_TO_PASS) install) ; \
        else \
                true ; \
        fi
@@ -1617,108 +1134,48 @@ install-libg++: force
 ### other supporting targets
 # this is a bad hack.
 all.xclib:     all.normal
-       if [ -d clib ] ; then \
-               (cd clib ; $(MAKE)) ; \
-       fi
-
-subdir_do: force
-       for i in $(DODIRS); do \
-               if [ -f $(unsubdir)/$$i/localenv ] ; then \
-                       if (cd $(unsubdir)/$$i$(subdir); \
-                               $(MAKE) \
-                                       "against=$(against)" \
-                                       "BISON=$(BISON)" \
-                                       "MAKEINFO=$(MAKEINFO)" \
-                                       $(DO)) ; then true ; \
-                               else exit 1 ; fi ; \
-               else if [ -d $(unsubdir)/$$i ] ; then \
-                       if (cd $(unsubdir)/$$i$(subdir); \
-                               $(MAKE) \
-                                       "against=$(against)" \
-                                       "AR=$(AR)" \
-                                       "AR_FLAGS=$(AR_FLAGS)" \
-                                       "CC=$(CC)" \
-                                       "RANLIB=$(RANLIB)" \
-                                       "LOADLIBES=$(LOADLIBES)" \
-                                       "LDFLAGS=$(LDFLAGS)" \
-                                       "BISON=$(BISON)" \
-                                       "MAKEINFO=$(MAKEINFO)" \
-                                       $(DO)) ; then true ; \
-                       else exit 1 ; fi ; \
-               else true ; fi ; \
-       fi ; \
+       if [ -f clib/Makefile ] ; then \
+               (cd clib ; $(MAKE) $(FLAGS_TO_PASS)) ; \
+       fi
+
+subdir_do:
+       @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 \
+             ;; \
+           *) \
+             if (rootme=`pwd` ; export rootme ; \
+                 cd ./$$i ; \
+                 $(MAKE) $(FLAGS_TO_PASS) $(DO)) ; then true ; \
+             else exit 1 ; fi \
+             ;; \
+           esac ; \
+         else true ; fi ; \
        done
 
-bootstrap:
-       $(MAKE) all info
-       $(MAKE) stage1
-       $(MAKE) pass "stagepass=stage1"
-       $(MAKE) stage2
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-bootstrap2:
-       $(MAKE) pass "stagepass=stage1"
-       $(MAKE) stage2
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-bootstrap3:
-       $(MAKE) pass "stagepass=stage2"
-       $(MAKE) comparison
-
-pass:
-       cp $(srcdir)/gcc/gstdarg.h $(unsubdir)/gas$(subdir)/stdarg.h
-       $(MAKE) subdir_do "DO=all info" "DODIRS=$(SUBDIRS)" \
-               "CC=`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/gcc \
-               -O $(GCCVERBOSE) -I`pwd`/$(unsubdir)/gcc$(subdir)/include \
-               -B`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/gas$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/ld$(subdir)/$(stagepass)/" \
-               "AR=`pwd`/$(unsubdir)/binutils$(subdir)/$(stagepass)/ar" \
-               "LD=`pwd`/$(unsubdir)/gcc$(subdir)/$(stagepass)/gcc $(GCCVERBOSE)" \
-               "RANLIB=`pwd`/$(unsubdir)/binutils$(subdir)/$(stagepass)/ranlib" \
-               "LOADLIBES=`pwd`/$(unsubdir)/gnulib$(subdir)/$(stagepass)/gnulib.a /lib/libc.a" \
-               "LDFLAGS=-nostdlib /lib/crt0.o \
-               -L`pwd`/$(unsubdir)/gnulib$(subdir)/$(stagepass)/ \
-               -B`pwd`/$(unsubdir)/ld$(subdir)/$(stagepass)/"
-
-
-stage1:
-       $(MAKE) subdir_do DO=stage1 "DODIRS=$(SUBDIRS)"
-
-stage2:
-       $(MAKE) subdir_do DO=stage2 "DODIRS=$(SUBDIRS)"
-
-stage3:
-       $(MAKE) subdir_do DO=stage3 "DODIRS=$(SUBDIRS)"
-
-stage4:
-       $(MAKE) subdir_do DO=stage4 "DODIRS=$(SUBDIRS)"
-
-against=stage2
-
-comparison:; $(MAKE) subdir_do DO=comparison against=$(against) "DODIRS=$(SUBDIRS)"
-
-de-stage1:; $(MAKE) subdir_do DO=de-stage1 "DODIRS=$(SUBDIRS)"
-de-stage2:; $(MAKE) subdir_do DO=de-stage2 "DODIRS=$(SUBDIRS)"
-de-stage3:; $(MAKE) subdir_do DO=de-stage3 "DODIRS=$(SUBDIRS)"
-de-stage4:; $(MAKE) subdir_do DO=de-stage4 "DODIRS=$(SUBDIRS)"
-
 # The "else true" stuff is for Ultrix; the shell returns the exit code
 # of the "if" command, if no commands are run in the "then" or "else" part,
 # causing Make to quit.
 
 MAKEDIRS= \
        $(prefix) \
-       $(bindir) \
-       $(libdir) \
-       $(includedir) \
-       $(datadir) \
-       $(docdir) \
-       $(mandir) \
-       $(man1dir) \
-       $(man5dir)
+       $(exec_prefix) \
+       $(tooldir)
+
+#      $(bindir) \
+#      $(libdir) \
+#      $(includedir) \
+#      $(datadir) \
+#      $(docdir) \
+#      $(mandir) \
+#      $(man1dir) \
+#      $(man5dir)
 
 #      $(man2dir) \
 #      $(man3dir) \
@@ -1727,28 +1184,39 @@ MAKEDIRS= \
 #      $(man7dir) \
 #      $(man8dir)
 
-install-dirs: force
+install-dirs:
        for i in $(MAKEDIRS) ; do \
                echo Making $$i... ; \
-               if [ -d $$i ] ; then true ; else mkdir $$i || exit 1 ; fi ; \
+               parent=`echo $$i|sed -e 's@/[^/]*$$@@'`; \
+               if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi ; \
+               if [ ! -d $$i ] ; then \
+                       if mkdir $$i ; then \
+                               true ; \
+                       else \
+                               exit 1 ; \
+                       fi ; \
+               else \
+                       true ; \
+               fi ; \
        done
 
 MAKEINFODIRS= \
-       $(prefix) \
-       $(infodir)
+       $(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
+#      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
 
 etags tags: TAGS
 
-TAGS: FORCE
+TAGS:
        etags `$(MAKE) ls`
 
 ls:
@@ -1775,8 +1243,8 @@ 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
+       config.sub config configure.man move-if-change
+GDB_SUPPORT_DIRS= bfd include libiberty mmalloc readline glob
 GDB_SUPPORT_FILES= $(GDB_SUPPORT_DIRS) texinfo/fsf/texinfo.tex
 
 setup-dirs: force_update
@@ -1812,13 +1280,13 @@ make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/fsf/texinfo.tex
        sed '/^configdirs=/s/texinfo //' <configure.in >proto-toplev/configure.in
        # Take out glob from buildable dirs
        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 '/^SUBDIRS =/s/glob //' \
+           -e '/^all\.normal: /s/\all-texinfo //' \
+           -e '/^clean: /s/clean-texinfo //' \
+           -e '/^install\.all: /s/install-texinfo //' \
+       <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/
This page took 0.150219 seconds and 4 git commands to generate.