Cut 2. Subdirs.
authorK. Richard Pixley <rich@cygnus>
Wed, 10 Apr 1991 22:56:51 +0000 (22:56 +0000)
committerK. Richard Pixley <rich@cygnus>
Wed, 10 Apr 1991 22:56:51 +0000 (22:56 +0000)
bfd/Makefile.in
bfd/configure
binutils/configure
ld/Makefile.in
ld/configure

index 861edd349e85902735358e8de8a920df1466cf44..b483c0c437d2fa0624dcd9eacbe6ade7b06affd8 100644 (file)
@@ -162,4 +162,6 @@ make:
        sed "s/^#__$(HOST)__#//" < Makefile.old                 >>Makefile
 
 Makefile: $(srcdir)/Makefile.in $(srcdir)/configure
-       (cd $(srcdir) ; ./configure -host=$(host) $(target))
+       (cd $(srcdir) ; \
+               ./configure `if [ "$(srcdir)" != "." ] ; then echo +f; fi` -host=$(host) $(target))
+
index 8e53d4e686f49989229c6dcc4e8c8e8306c83965..d0b1680fd2b93917f9229ee00d5778a354b0b237 100755 (executable)
@@ -49,12 +49,14 @@ symbolic_link='ln -s'
 #symbolic_link="echo ln -s"
 
 # clear some things potentially inherited from environment.
-target=
-template=
-removing=
-norecurse=
 ansi=
+hostsubdir=
+norecurse=
+removing=
 srcdir=
+target=
+targetsubdir=
+template=
 
 for arg in $*;
 do
@@ -62,17 +64,8 @@ do
        -ansi | +ansi)
                ansi=true
                ;;
-       -template=* | +template=*)
-               template=`echo $arg | sed 's/[+-]template=//'`
-               ;;
-       -norecurse | +norecurse)
-               norecurse=true
-               ;;
-       -rm | +rm)
-               removing=$arg
-               ;;
-       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
-               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+       -forcesubdirs | +f*)
+               forcesubdirs=${arg}
                ;;
        -host=* | +host=* | +hos=* | +ho=* | +h=*)
                host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
@@ -88,6 +81,18 @@ do
        -nfp | +nfp | +nf | +n)
                nfp=yes
                ;;
+       -norecurse | +norecurse)
+               norecurse=true
+               ;;
+       -rm | +rm)
+               removing=$arg
+               ;;
+       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
+               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+               ;;
+       -template=* | +template=*)
+               template=`echo $arg | sed 's/[+-]template=//'`
+               ;;
        *)
 # Allow configure HOST TARGET
                if [ x$host = x ] ; then host=$target ; fi
@@ -96,7 +101,7 @@ do
        esac
 done
 
-# process host and target only if not rebuilding configure itself.
+# process host and target only if not rebuilding configure itself or removing.
 if [ -z "$template" -a -z "$removing" ]
 then
        # Complain if an arg is missing
@@ -111,13 +116,12 @@ then
                fi
                exit 1
        fi
+fi
 
-       # Default other arg
-       if [ -z "$host" ]
-       then
-               host=$target
-       fi
-
+# Default other arg
+if [ -z "$host" ]
+then
+       host=$target
 fi
 
 #### configure.in files come in here.
@@ -190,28 +194,47 @@ then
 fi
 
 # Temporarily, we support only direct subdir builds.
-hostsubdir=Host-$host
-targetsubdir=Target-$target
+hostsubdir=Host-${host}
+targetsubdir=Target-${target}
 
-if [ -n "$removing" ]
+if [ -n "${removing}" ]
 then
-#      rm -rf $hostsubdir/$targetsubdir
-#
-#      if [ -z "`(ls $hostsubdir) 2>&1 | grep Target-`" ]
-#      then
-#              rm -rf $hostsubdir
-#      fi
-
-       rm -f .gdbinit Makefile config.status $links
+       if [ -d "${hostsubdir}/${targetsubdir}" ]
+       then
+               rm -rf ${hostsubdir}/${targetsubdir}
 
+               if [ -z "`(ls ${hostsubdir}) 2>&1 | grep Target-`" ]
+               then
+                       rm -rf ${hostsubdir}
+               fi
+       else
+               rm -f .gdbinit Makefile config.status $links
+       fi
 else
-#      if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
-#      cd $hostsubdir
-#
-#      if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
-#      cd $targetsubdir
-#
-#      srcdir=../..
+       if [ -n "$forcesubdirs" ]
+       then
+               # check for existing status before allowing forced subdirs.
+               if [ -f Makefile ]
+               then
+                       echo "Makefile already exists in source directory.  `pwd` not configured."
+                       exit 1
+               fi
+
+               if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
+               cd $hostsubdir
+       
+               if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
+               cd $targetsubdir
+       
+               srcdir=../..
+       else
+               # if not subdir builds, then make sure none exist.
+               if [ -n "`(ls .) 2>&1 | grep Host-`" ]
+               then
+                       echo "Configured subdirs exist.  `pwd` not configured."
+                       exit 1
+               fi
+       fi
 
        # Find the source files, if location was not specified.
        if [ x$srcdir = x ]
@@ -265,73 +288,84 @@ else
                echo "Linked \"$link\" to \"${srcdir}/${file}\"."
        done
 
-       # Install a makefile, and make it set VPATH
-       # if necessary so that the sources are found.
-       # Also change its value of srcdir.
-       # Also create a .gdbinit file which runs the one in srcdir
+       # Create a .gdbinit file which runs the one in srcdir
        # and tells GDB to look there for source files.
+
        case $srcdir in
        .)
                ;;
        *)
-               echo "VPATH = ${srcdir}" > x
-               cat x ${srcdir}/Makefile.in | sed "s@^srcdir = \.@srcdir = ${srcdir}@" > Makefile.in
-               rm x
                echo "dir ." > .gdbinit
                echo "dir ${srcdir}" >> .gdbinit
                echo "source ${srcdir}/.gdbinit" >> .gdbinit
                ;;
        esac
 
+       # Install a makefile, and make it set VPATH
+       # if necessary so that the sources are found.
+       # Also change its value of srcdir.
+
+# FIXME-someday: This business of always writing to .tem and mv back
+# is so that I don't screw things up while developing.  Once this
+# template is stable, these should be optimized. xoxorich.
+
+       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
+       if [ x$host != x$target ]
+       then
+               echo "CROSS=-DCROSS_COMPILE" > Makefile
+               echo "ALL=start.encap" >> Makefile
+       else
+               echo "ALL=all.internal" > Makefile
+       fi
+
+       # set target, host, VPATH
+       echo "host = $host" >> Makefile
+       echo "target = $target" >> Makefile
+
+       if [ -n "${forcesubdirs}" ]
+       then
+               echo "subdir = /${hostsubdir}/${targetsubdir}" >> Makefile
+       else
+               echo "subdir =" >> Makefile
+       fi
+
+#      echo "workdir = `pwd`" >> Makefile
+       echo "VPATH = ${srcdir}" >> Makefile
+
+       # add Makefile.in
+       cat ${srcdir}/Makefile.in >> Makefile
+
+       # and shake thoroughly.
        host_var_file=hmake-${host}
        target_var_file=tmake-${target}
 
        # Conditionalize the makefile for this machine.
        if [ -f ${srcdir}/config/${host_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile.in > Makefile.tem
-       else
-               cp Makefile.in Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
        if [ -f ${srcdir}/config/${target_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile.tem > Makefile.tem1
-               mv Makefile.tem1 Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
+       sed "s@^srcdir = \.@srcdir = ${srcdir}@" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
+
        # Remove all formfeeds, since some Makes get confused by them.
-       sed "s/\f//" Makefile.tem >> Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s/\f//" Makefile >> Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset SUBDIRS
-       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset NONSUBDIRS
-       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
-
-       # Delete the intermediate files
-       if [ x$srcdir != x. ] ; then rm Makefile.in ; fi
-
-       rm -f Makefile
-
-       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
-       if [ x$host != x$target ]
-       then
-               echo "CROSS=-DCROSS_COMPILE" > Makefile
-               echo "ALL=start.encap" >> Makefile
-       else
-               echo "ALL=all.internal" > Makefile
-       fi
-
-       # set target and host
-       echo "host = $host" >> Makefile
-       echo "target = $target" >> Makefile
-
-       cat Makefile.tem >> Makefile
-       rm Makefile.tem
+       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        using=
        if [ -f ${srcdir}/config/${host_var_file} ]
@@ -364,6 +398,7 @@ else
 #                      | tee ${srcdir}/config.status
        fi
 
+       originaldir=`pwd`
        cd ${srcdir}
 fi
 
@@ -384,12 +419,8 @@ do
        fi
 
        echo Configuring ${configdir}...
-#      (cd ${configdir} ;
-#              configure +host=${host} ${target} ${removing}) \
-#              | sed 's/^/     /'
-
        (cd ${configdir} ;
-               ./configure +host=${host} ${target} ${removing}) \
+               ./configure ${forcesubdirs} ${removing} +host=${host} ${target}) \
                | sed 's/^/     /'
 done
 
@@ -397,8 +428,8 @@ exit 0
 
 #
 # $Log$
-# Revision 1.2  1991/04/09 23:20:12  rich
-# First minimally usable checkin.
+# Revision 1.3  1991/04/10 22:56:14  rich
+# Cut 2.  Subdirs.
 #
 #
 #
index 1c764aa300e5a63780a88d00c366189faa8401d5..c0473fa53e224608767569424428230c6b585e4d 100755 (executable)
@@ -49,12 +49,14 @@ symbolic_link='ln -s'
 #symbolic_link="echo ln -s"
 
 # clear some things potentially inherited from environment.
-target=
-template=
-removing=
-norecurse=
 ansi=
+hostsubdir=
+norecurse=
+removing=
 srcdir=
+target=
+targetsubdir=
+template=
 
 for arg in $*;
 do
@@ -62,17 +64,8 @@ do
        -ansi | +ansi)
                ansi=true
                ;;
-       -template=* | +template=*)
-               template=`echo $arg | sed 's/[+-]template=//'`
-               ;;
-       -norecurse | +norecurse)
-               norecurse=true
-               ;;
-       -rm | +rm)
-               removing=$arg
-               ;;
-       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
-               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+       -forcesubdirs | +f*)
+               forcesubdirs=${arg}
                ;;
        -host=* | +host=* | +hos=* | +ho=* | +h=*)
                host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
@@ -88,6 +81,18 @@ do
        -nfp | +nfp | +nf | +n)
                nfp=yes
                ;;
+       -norecurse | +norecurse)
+               norecurse=true
+               ;;
+       -rm | +rm)
+               removing=$arg
+               ;;
+       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
+               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+               ;;
+       -template=* | +template=*)
+               template=`echo $arg | sed 's/[+-]template=//'`
+               ;;
        *)
 # Allow configure HOST TARGET
                if [ x$host = x ] ; then host=$target ; fi
@@ -96,7 +101,7 @@ do
        esac
 done
 
-# process host and target only if not rebuilding configure itself.
+# process host and target only if not rebuilding configure itself or removing.
 if [ -z "$template" -a -z "$removing" ]
 then
        # Complain if an arg is missing
@@ -111,13 +116,12 @@ then
                fi
                exit 1
        fi
+fi
 
-       # Default other arg
-       if [ -z "$host" ]
-       then
-               host=$target
-       fi
-
+# Default other arg
+if [ -z "$host" ]
+then
+       host=$target
 fi
 
 #### configure.in files come in here.
@@ -191,28 +195,47 @@ then
 fi
 
 # Temporarily, we support only direct subdir builds.
-hostsubdir=Host-$host
-targetsubdir=Target-$target
+hostsubdir=Host-${host}
+targetsubdir=Target-${target}
 
-if [ -n "$removing" ]
+if [ -n "${removing}" ]
 then
-#      rm -rf $hostsubdir/$targetsubdir
-#
-#      if [ -z "`(ls $hostsubdir) 2>&1 | grep Target-`" ]
-#      then
-#              rm -rf $hostsubdir
-#      fi
-
-       rm -f .gdbinit Makefile config.status $links
+       if [ -d "${hostsubdir}/${targetsubdir}" ]
+       then
+               rm -rf ${hostsubdir}/${targetsubdir}
 
+               if [ -z "`(ls ${hostsubdir}) 2>&1 | grep Target-`" ]
+               then
+                       rm -rf ${hostsubdir}
+               fi
+       else
+               rm -f .gdbinit Makefile config.status $links
+       fi
 else
-#      if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
-#      cd $hostsubdir
-#
-#      if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
-#      cd $targetsubdir
-#
-#      srcdir=../..
+       if [ -n "$forcesubdirs" ]
+       then
+               # check for existing status before allowing forced subdirs.
+               if [ -f Makefile ]
+               then
+                       echo "Makefile already exists in source directory.  `pwd` not configured."
+                       exit 1
+               fi
+
+               if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
+               cd $hostsubdir
+       
+               if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
+               cd $targetsubdir
+       
+               srcdir=../..
+       else
+               # if not subdir builds, then make sure none exist.
+               if [ -n "`(ls .) 2>&1 | grep Host-`" ]
+               then
+                       echo "Configured subdirs exist.  `pwd` not configured."
+                       exit 1
+               fi
+       fi
 
        # Find the source files, if location was not specified.
        if [ x$srcdir = x ]
@@ -266,73 +289,84 @@ else
                echo "Linked \"$link\" to \"${srcdir}/${file}\"."
        done
 
-       # Install a makefile, and make it set VPATH
-       # if necessary so that the sources are found.
-       # Also change its value of srcdir.
-       # Also create a .gdbinit file which runs the one in srcdir
+       # Create a .gdbinit file which runs the one in srcdir
        # and tells GDB to look there for source files.
+
        case $srcdir in
        .)
                ;;
        *)
-               echo "VPATH = ${srcdir}" > x
-               cat x ${srcdir}/Makefile.in | sed "s@^srcdir = \.@srcdir = ${srcdir}@" > Makefile.in
-               rm x
                echo "dir ." > .gdbinit
                echo "dir ${srcdir}" >> .gdbinit
                echo "source ${srcdir}/.gdbinit" >> .gdbinit
                ;;
        esac
 
+       # Install a makefile, and make it set VPATH
+       # if necessary so that the sources are found.
+       # Also change its value of srcdir.
+
+# FIXME-someday: This business of always writing to .tem and mv back
+# is so that I don't screw things up while developing.  Once this
+# template is stable, these should be optimized. xoxorich.
+
+       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
+       if [ x$host != x$target ]
+       then
+               echo "CROSS=-DCROSS_COMPILE" > Makefile
+               echo "ALL=start.encap" >> Makefile
+       else
+               echo "ALL=all.internal" > Makefile
+       fi
+
+       # set target, host, VPATH
+       echo "host = $host" >> Makefile
+       echo "target = $target" >> Makefile
+
+       if [ -n "${forcesubdirs}" ]
+       then
+               echo "subdir = /${hostsubdir}/${targetsubdir}" >> Makefile
+       else
+               echo "subdir =" >> Makefile
+       fi
+
+#      echo "workdir = `pwd`" >> Makefile
+       echo "VPATH = ${srcdir}" >> Makefile
+
+       # add Makefile.in
+       cat ${srcdir}/Makefile.in >> Makefile
+
+       # and shake thoroughly.
        host_var_file=hmake-${host}
        target_var_file=tmake-${target}
 
        # Conditionalize the makefile for this machine.
        if [ -f ${srcdir}/config/${host_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile.in > Makefile.tem
-       else
-               cp Makefile.in Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
        if [ -f ${srcdir}/config/${target_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile.tem > Makefile.tem1
-               mv Makefile.tem1 Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
+       sed "s@^srcdir = \.@srcdir = ${srcdir}@" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
+
        # Remove all formfeeds, since some Makes get confused by them.
-       sed "s/\f//" Makefile.tem >> Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s/\f//" Makefile >> Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset SUBDIRS
-       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset NONSUBDIRS
-       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
-
-       # Delete the intermediate files
-       if [ x$srcdir != x. ] ; then rm Makefile.in ; fi
-
-       rm -f Makefile
-
-       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
-       if [ x$host != x$target ]
-       then
-               echo "CROSS=-DCROSS_COMPILE" > Makefile
-               echo "ALL=start.encap" >> Makefile
-       else
-               echo "ALL=all.internal" > Makefile
-       fi
-
-       # set target and host
-       echo "host = $host" >> Makefile
-       echo "target = $target" >> Makefile
-
-       cat Makefile.tem >> Makefile
-       rm Makefile.tem
+       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        using=
        if [ -f ${srcdir}/config/${host_var_file} ]
@@ -365,6 +399,7 @@ else
 #                      | tee ${srcdir}/config.status
        fi
 
+       originaldir=`pwd`
        cd ${srcdir}
 fi
 
@@ -385,12 +420,8 @@ do
        fi
 
        echo Configuring ${configdir}...
-#      (cd ${configdir} ;
-#              configure +host=${host} ${target} ${removing}) \
-#              | sed 's/^/     /'
-
        (cd ${configdir} ;
-               ./configure +host=${host} ${target} ${removing}) \
+               ./configure ${forcesubdirs} ${removing} +host=${host} ${target}) \
                | sed 's/^/     /'
 done
 
@@ -398,8 +429,8 @@ exit 0
 
 #
 # $Log$
-# Revision 1.2  1991/04/09 23:44:28  rich
-# First cut config hits binutils.
+# Revision 1.3  1991/04/10 22:56:51  rich
+# Cut 2.  Subdirs.
 #
 #
 #
index 388b00a0d3a3a6d9a61054a6a2a58e2c9d9884a3..a8f81c1d39d2274ef0052cbfb770226673e3fda5 100644 (file)
@@ -40,7 +40,7 @@ PROGS = $(HOSTDIR)/ld.new
 # for self hosting
 GNUTARGET=a.out-generic-big
 LDEMULATION=gld
-BFDLIB=$(srcdir)/../bfd/libbfd.a
+BFDLIB=$(srcdir)/../bfd$(subdir)/libbfd.a
 
 OBJS= ldgram.o ldlex.o ldlang.o ldmain.o ldwrite.o ldexp.o ld-lnk960.o ld-gld68k.o \
        ld-gld.o ld-gld960.o ld-emul.o ldversion.o ldmisc.o ldsym.o ldfile.o
@@ -113,7 +113,7 @@ ldmisc.o: ldmisc.c
 ldsym.o: ldsym.c 
 
 clean:
-       - rm -f $(OBJS) $(GENERATED_SOURCES) $(GENERATED_HEADERS)
+       - rm -f TAGS $(OBJS) $(GENERATED_SOURCES) $(GENERATED_HEADERS)
        - rm -f ld ld1 ld2 ld3 ld.new
 
 
@@ -194,7 +194,8 @@ make:
 #\f
 
 Makefile: $(srcdir)/Makefile.in $(srcdir)/configure
-       (cd $(srcdir) ; ./configure -host=$(host) $(target))
+       (cd $(srcdir) ; \
+               ./configure `if [ "$(srcdir)" != "." ] ; then echo +f; fi` -host=$(host) $(target))
 
 ### Local Variables: ***
 ### mode:fundamental ***
index 3dbbb470f640bc2a608330ad7525ebde671f2547..103106c9484c246a5b52b7f9849ab835c8c95edb 100755 (executable)
@@ -49,12 +49,14 @@ symbolic_link='ln -s'
 #symbolic_link="echo ln -s"
 
 # clear some things potentially inherited from environment.
-target=
-template=
-removing=
-norecurse=
 ansi=
+hostsubdir=
+norecurse=
+removing=
 srcdir=
+target=
+targetsubdir=
+template=
 
 for arg in $*;
 do
@@ -62,17 +64,8 @@ do
        -ansi | +ansi)
                ansi=true
                ;;
-       -template=* | +template=*)
-               template=`echo $arg | sed 's/[+-]template=//'`
-               ;;
-       -norecurse | +norecurse)
-               norecurse=true
-               ;;
-       -rm | +rm)
-               removing=$arg
-               ;;
-       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
-               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+       -forcesubdirs | +f*)
+               forcesubdirs=${arg}
                ;;
        -host=* | +host=* | +hos=* | +ho=* | +h=*)
                host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
@@ -88,6 +81,18 @@ do
        -nfp | +nfp | +nf | +n)
                nfp=yes
                ;;
+       -norecurse | +norecurse)
+               norecurse=true
+               ;;
+       -rm | +rm)
+               removing=$arg
+               ;;
+       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
+               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+               ;;
+       -template=* | +template=*)
+               template=`echo $arg | sed 's/[+-]template=//'`
+               ;;
        *)
 # Allow configure HOST TARGET
                if [ x$host = x ] ; then host=$target ; fi
@@ -96,7 +101,7 @@ do
        esac
 done
 
-# process host and target only if not rebuilding configure itself.
+# process host and target only if not rebuilding configure itself or removing.
 if [ -z "$template" -a -z "$removing" ]
 then
        # Complain if an arg is missing
@@ -111,13 +116,12 @@ then
                fi
                exit 1
        fi
+fi
 
-       # Default other arg
-       if [ -z "$host" ]
-       then
-               host=$target
-       fi
-
+# Default other arg
+if [ -z "$host" ]
+then
+       host=$target
 fi
 
 #### configure.in files come in here.
@@ -191,28 +195,47 @@ then
 fi
 
 # Temporarily, we support only direct subdir builds.
-hostsubdir=Host-$host
-targetsubdir=Target-$target
+hostsubdir=Host-${host}
+targetsubdir=Target-${target}
 
-if [ -n "$removing" ]
+if [ -n "${removing}" ]
 then
-#      rm -rf $hostsubdir/$targetsubdir
-#
-#      if [ -z "`(ls $hostsubdir) 2>&1 | grep Target-`" ]
-#      then
-#              rm -rf $hostsubdir
-#      fi
-
-       rm -f .gdbinit Makefile config.status $links
+       if [ -d "${hostsubdir}/${targetsubdir}" ]
+       then
+               rm -rf ${hostsubdir}/${targetsubdir}
 
+               if [ -z "`(ls ${hostsubdir}) 2>&1 | grep Target-`" ]
+               then
+                       rm -rf ${hostsubdir}
+               fi
+       else
+               rm -f .gdbinit Makefile config.status $links
+       fi
 else
-#      if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
-#      cd $hostsubdir
-#
-#      if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
-#      cd $targetsubdir
-#
-#      srcdir=../..
+       if [ -n "$forcesubdirs" ]
+       then
+               # check for existing status before allowing forced subdirs.
+               if [ -f Makefile ]
+               then
+                       echo "Makefile already exists in source directory.  `pwd` not configured."
+                       exit 1
+               fi
+
+               if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
+               cd $hostsubdir
+       
+               if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
+               cd $targetsubdir
+       
+               srcdir=../..
+       else
+               # if not subdir builds, then make sure none exist.
+               if [ -n "`(ls .) 2>&1 | grep Host-`" ]
+               then
+                       echo "Configured subdirs exist.  `pwd` not configured."
+                       exit 1
+               fi
+       fi
 
        # Find the source files, if location was not specified.
        if [ x$srcdir = x ]
@@ -266,73 +289,84 @@ else
                echo "Linked \"$link\" to \"${srcdir}/${file}\"."
        done
 
-       # Install a makefile, and make it set VPATH
-       # if necessary so that the sources are found.
-       # Also change its value of srcdir.
-       # Also create a .gdbinit file which runs the one in srcdir
+       # Create a .gdbinit file which runs the one in srcdir
        # and tells GDB to look there for source files.
+
        case $srcdir in
        .)
                ;;
        *)
-               echo "VPATH = ${srcdir}" > x
-               cat x ${srcdir}/Makefile.in | sed "s@^srcdir = \.@srcdir = ${srcdir}@" > Makefile.in
-               rm x
                echo "dir ." > .gdbinit
                echo "dir ${srcdir}" >> .gdbinit
                echo "source ${srcdir}/.gdbinit" >> .gdbinit
                ;;
        esac
 
+       # Install a makefile, and make it set VPATH
+       # if necessary so that the sources are found.
+       # Also change its value of srcdir.
+
+# FIXME-someday: This business of always writing to .tem and mv back
+# is so that I don't screw things up while developing.  Once this
+# template is stable, these should be optimized. xoxorich.
+
+       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
+       if [ x$host != x$target ]
+       then
+               echo "CROSS=-DCROSS_COMPILE" > Makefile
+               echo "ALL=start.encap" >> Makefile
+       else
+               echo "ALL=all.internal" > Makefile
+       fi
+
+       # set target, host, VPATH
+       echo "host = $host" >> Makefile
+       echo "target = $target" >> Makefile
+
+       if [ -n "${forcesubdirs}" ]
+       then
+               echo "subdir = /${hostsubdir}/${targetsubdir}" >> Makefile
+       else
+               echo "subdir =" >> Makefile
+       fi
+
+#      echo "workdir = `pwd`" >> Makefile
+       echo "VPATH = ${srcdir}" >> Makefile
+
+       # add Makefile.in
+       cat ${srcdir}/Makefile.in >> Makefile
+
+       # and shake thoroughly.
        host_var_file=hmake-${host}
        target_var_file=tmake-${target}
 
        # Conditionalize the makefile for this machine.
        if [ -f ${srcdir}/config/${host_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile.in > Makefile.tem
-       else
-               cp Makefile.in Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
        if [ -f ${srcdir}/config/${target_var_file} ]
        then
-               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile.tem > Makefile.tem1
-               mv Makefile.tem1 Makefile.tem
+               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile > Makefile.tem
+               mv Makefile.tem Makefile
        fi
 
+       sed "s@^srcdir = \.@srcdir = ${srcdir}@" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
+
        # Remove all formfeeds, since some Makes get confused by them.
-       sed "s/\f//" Makefile.tem >> Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s/\f//" Makefile >> Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset SUBDIRS
-       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
+       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        # reset NONSUBDIRS
-       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile.tem > Makefile.tem1
-       mv Makefile.tem1 Makefile.tem
-
-       # Delete the intermediate files
-       if [ x$srcdir != x. ] ; then rm Makefile.in ; fi
-
-       rm -f Makefile
-
-       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
-       if [ x$host != x$target ]
-       then
-               echo "CROSS=-DCROSS_COMPILE" > Makefile
-               echo "ALL=start.encap" >> Makefile
-       else
-               echo "ALL=all.internal" > Makefile
-       fi
-
-       # set target and host
-       echo "host = $host" >> Makefile
-       echo "target = $target" >> Makefile
-
-       cat Makefile.tem >> Makefile
-       rm Makefile.tem
+       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile > Makefile.tem
+       mv Makefile.tem Makefile
 
        using=
        if [ -f ${srcdir}/config/${host_var_file} ]
@@ -365,6 +399,7 @@ else
 #                      | tee ${srcdir}/config.status
        fi
 
+       originaldir=`pwd`
        cd ${srcdir}
 fi
 
@@ -385,12 +420,8 @@ do
        fi
 
        echo Configuring ${configdir}...
-#      (cd ${configdir} ;
-#              configure +host=${host} ${target} ${removing}) \
-#              | sed 's/^/     /'
-
        (cd ${configdir} ;
-               ./configure +host=${host} ${target} ${removing}) \
+               ./configure ${forcesubdirs} ${removing} +host=${host} ${target}) \
                | sed 's/^/     /'
 done
 
@@ -398,8 +429,8 @@ exit 0
 
 #
 # $Log$
-# Revision 1.2  1991/04/09 23:21:17  rich
-# First minimally usable config checkin.
+# Revision 1.3  1991/04/10 22:55:43  rich
+# Cut 2.  Subdirs.
 #
 #
 #