aboutsummaryrefslogtreecommitdiff
path: root/ld/configure
diff options
context:
space:
mode:
Diffstat (limited to 'ld/configure')
-rwxr-xr-xld/configure137
1 files changed, 81 insertions, 56 deletions
diff --git a/ld/configure b/ld/configure
index 103106c..a7adce0 100755
--- a/ld/configure
+++ b/ld/configure
@@ -50,30 +50,35 @@ symbolic_link='ln -s'
# clear some things potentially inherited from environment.
ansi=
+destdir=
hostsubdir=
norecurse=
removing=
srcdir=
+srctrigger=
target=
targetsubdir=
template=
for arg in $*;
do
- case $arg in
+ case ${arg} in
-ansi | +ansi)
ansi=true
;;
+ -destdir=* | +destdir=* | +destdi=* | +destd=* | +dest=* | +des=* | +de=* | +d=*)
+ destdir=`echo ${arg} | sed 's/[+-]d[a-z]*=//'`
+ ;;
-forcesubdirs | +f*)
forcesubdirs=${arg}
;;
-host=* | +host=* | +hos=* | +ho=* | +h=*)
- host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
+ host=`echo ${arg} | sed 's/[+-]h[a-z]*=//'`
;;
-languages=* | +languages=* | +language=* | +languag=* \
| +langua=* | +langu=* | +lang=* | +lan=* | +la=* \
| +l=*)
- languages="$languages `echo $arg | sed 's/[+-]l[a-z]*=//'`"
+ languages="${languages} `echo ${arg} | sed 's/[+-]l[a-z]*=//'`"
;;
-gas | +gas | +ga | +g)
gas=yes
@@ -85,29 +90,29 @@ do
norecurse=true
;;
-rm | +rm)
- removing=$arg
+ removing=${arg}
;;
-srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
- srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+ srcdir=`echo ${arg} | sed 's/[+-]s[a-z]*=//'`
;;
-template=* | +template=*)
- template=`echo $arg | sed 's/[+-]template=//'`
+ template=`echo ${arg} | sed 's/[+-]template=//'`
;;
*)
# Allow configure HOST TARGET
- if [ x$host = x ] ; then host=$target ; fi
- target=$arg
+ if [ -z "${host}" ] ; then host=${target} ; fi
+ target=${arg}
;;
esac
done
# process host and target only if not rebuilding configure itself or removing.
-if [ -z "$template" -a -z "$removing" ]
+if [ -z "${template}" -a -z "${removing}" ]
then
# Complain if an arg is missing
- if [ -z "$target" ]
+ if [ -z "${target}" ]
then
- echo "Usage: $progname [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET"
+ echo "Usage: ${progname} [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET"
echo -n "Where HOST and TARGET are something like "
echo "\`vax', \`sun3', \`encore', etc."
if [ -r config.status ]
@@ -119,9 +124,9 @@ then
fi
# Default other arg
-if [ -z "$host" ]
+if [ -z "${host}" ]
then
- host=$target
+ host=${target}
fi
#### configure.in files come in here.
@@ -138,9 +143,9 @@ links=
### end of configure.in
# are we rebuilding config itself?
-if [ -n "$template" ]
+if [ -n "${template}" ]
then
- if [ ! -r $template ]
+ if [ ! -r ${template} ]
then
echo "Can't find template ${template}."
exit 1
@@ -155,21 +160,22 @@ then
if [ -r configure.in ]
then
- sed -e "/^####/ r configure.in" $template >> configure
+ sed -e "/^####/ r configure.in" ${template} >> configure
else
- cat $template >> configure
+ echo Warning: no configure.in in `pwd`
+ cat ${template} >> configure
fi
chmod a+x configure
rm configure.old
echo Rebuilt configure in `pwd`
- if [ x$norecurse = x ]
+ if [ -z "${norecurse}" ]
then
- while [ -n "$configdirs" ]
+ while [ -n "${configdirs}" ]
do
# set configdir to car of configdirs, configdirs to cdr of configdirs
- set $configdirs; configdir=$1; shift; configdirs=$*
+ set ${configdirs}; configdir=$1; shift; configdirs=$*
if [ "`echo ${configdir}.*`" != "${configdir}.*" ]
then
@@ -194,6 +200,13 @@ then
exit 0
fi
+# some sanity checks on configure.in
+if [ -z "${srctrigger}" ]
+then
+ echo srctrigger not set in configure.in. `pwd` not configured.
+ exit 1
+fi
+
# Temporarily, we support only direct subdir builds.
hostsubdir=Host-${host}
targetsubdir=Target-${target}
@@ -209,10 +222,10 @@ then
rm -rf ${hostsubdir}
fi
else
- rm -f .gdbinit Makefile config.status $links
+ rm -f .gdbinit Makefile config.status ${links}
fi
else
- if [ -n "$forcesubdirs" ]
+ if [ -n "${forcesubdirs}" ]
then
# check for existing status before allowing forced subdirs.
if [ -f Makefile ]
@@ -221,11 +234,11 @@ else
exit 1
fi
- if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
- cd $hostsubdir
+ if [ ! -d ${hostsubdir} ] ; then mkdir ${hostsubdir} ; fi
+ cd ${hostsubdir}
- if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
- cd $targetsubdir
+ if [ ! -d ${targetsubdir} ] ; then mkdir ${targetsubdir} ; fi
+ cd ${targetsubdir}
srcdir=../..
else
@@ -238,61 +251,61 @@ else
fi
# Find the source files, if location was not specified.
- if [ x$srcdir = x ]
+ if [ -z "${srcdir}" ]
then
srcdirdefaulted=1
srcdir=.
- if [ ! -r ${srctrigger} ]
+ if [ -n "${srctrigger}" -a ! -r ${srctrigger} ]
then
srcdir=..
fi
fi
- if [ ! -r ${srcdir}/${srctrigger} ]
+ if [ -n "${srctrigger}" -a ! -r ${srcdir}/${srctrigger} ]
then
- if [ -z "$srcdirdefaulted" ]
+ if [ -z "${srcdirdefaulted}" ]
then
- echo "$progname: Can't find ${srcname} sources in \`${srcdir}'." 1>&2
+ echo "${progname}: Can't find ${srcname} sources in \`${srcdir}'." 1>&2
else
- echo "$progname: Can't find ${srcname} sources in \`.' or \`..'." 1>&2
+ echo "${progname}: Can't find ${srcname} sources in \`.' or \`..'." 1>&2
fi
exit 1
fi
# Set up the list of links to be made.
- # $links is the list of link names, and $files is the list of names to link to.
+ # ${links} is the list of link names, and ${files} is the list of names to link to.
# Make the links.
- while [ -n "$files" ]
+ while [ -n "${files}" ]
do
# set file to car of files, files to cdr of files
- set $files; file=$1; shift; files=$*
- set $links; link=$1; shift; links=$*
+ set ${files}; file=$1; shift; files=$*
+ set ${links}; link=$1; shift; links=$*
if [ ! -r ${srcdir}/${file} ]
then
- echo "$progname: cannot create a link \"${link}\"," 1>&2
- echo "since the file \"$file\" does not exist." 1>&2
+ echo "${progname}: cannot create a link \"${link}\"," 1>&2
+ echo "since the file \"${file}\" does not exist." 1>&2
exit 1
fi
- $remove -f $link
+ ${remove} -f ${link}
rm -f config.status
# Make a symlink if possible, otherwise try a hard link
- $symbolic_link ${srcdir}/$file $link 2>/dev/null || $hard_link ${srcdir}/$file $link
+ ${symbolic_link} ${srcdir}/${file} ${link} 2>/dev/null || ${hard_link} ${srcdir}/${file} ${link}
- if [ ! -r $link ]
+ if [ ! -r ${link} ]
then
- echo "$progname: unable to link \"$link\" to \"${srcdir}/$file\"." 1>&2
+ echo "${progname}: unable to link \"${link}\" to \"${srcdir}/${file}\"." 1>&2
exit 1
fi
- echo "Linked \"$link\" to \"${srcdir}/${file}\"."
+ echo "Linked \"${link}\" to \"${srcdir}/${file}\"."
done
# Create a .gdbinit file which runs the one in srcdir
# and tells GDB to look there for source files.
- case $srcdir in
+ case ${srcdir} in
.)
;;
*)
@@ -311,7 +324,7 @@ else
# 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 ]
+ if [ "${host}" != "${target}" ]
then
echo "CROSS=-DCROSS_COMPILE" > Makefile
echo "ALL=start.encap" >> Makefile
@@ -320,8 +333,8 @@ else
fi
# set target, host, VPATH
- echo "host = $host" >> Makefile
- echo "target = $target" >> Makefile
+ echo "host = ${host}" >> Makefile
+ echo "target = ${target}" >> Makefile
if [ -n "${forcesubdirs}" ]
then
@@ -340,22 +353,31 @@ else
host_var_file=hmake-${host}
target_var_file=tmake-${target}
- # Conditionalize the makefile for this machine.
+ # Conditionalize the makefile for this host.
if [ -f ${srcdir}/config/${host_var_file} ]
then
sed -e "/^####/ r ${srcdir}/config/${host_var_file}" Makefile > Makefile.tem
mv Makefile.tem Makefile
fi
+ # Conditionalize the makefile for this target.
if [ -f ${srcdir}/config/${target_var_file} ]
then
sed -e "/^####/ r ${srcdir}/config/${target_var_file}" Makefile > Makefile.tem
mv Makefile.tem Makefile
fi
+ # set srcdir
sed "s@^srcdir = \.@srcdir = ${srcdir}@" Makefile > Makefile.tem
mv Makefile.tem Makefile
+ # set destdir
+ if [ -n "${destdir}" ]
+ then
+ sed "s:^destdir =.*$:destdir = ${destdir}:" Makefile > Makefile.tem
+ mv Makefile.tem Makefile
+ fi
+
# Remove all formfeeds, since some Makes get confused by them.
sed "s/ //" Makefile >> Makefile.tem
mv Makefile.tem Makefile
@@ -388,13 +410,13 @@ else
echo "Created \"Makefile\""${andusing}.
- if [ x$host = x$target ]
+ if [ "${host}" = "${target}" ]
then
- echo "Links are now set up for use with a $target." \
+ echo "Links are now set up for use with a ${target}." \
> config.status
# | tee ${srcdir}/config.status
else
- echo "Links are now set up for host $host and target $target." \
+ echo "Links are now set up for host ${host} and target ${target}." \
> config.status
# | tee ${srcdir}/config.status
fi
@@ -405,12 +427,12 @@ fi
# If there are subdirectories, then recurse.
-if [ -n "$norecurse" ] ; then exit 0 ; fi
+if [ -n "${norecurse}" ] ; then exit 0 ; fi
-while [ -n "$configdirs" ]
+while [ -n "${configdirs}" ]
do
# set configdir to car of configdirs, configdirs to cdr of configdirs
- set $configdirs; configdir=$1; shift; configdirs=$*
+ set ${configdirs}; configdir=$1; shift; configdirs=$*
# check for target override
targetspecificdir=${configdir}.${target}
@@ -429,8 +451,11 @@ exit 0
#
# $Log$
-# Revision 1.3 1991/04/10 22:55:43 rich
-# Cut 2. Subdirs.
+# Revision 1.4 1991/04/13 02:07:08 rich
+# Config cut 3. We now almost install a29k.
+#
+# Revision 1.3 1991/04/11 02:41:54 rich
+# Cut 2 config. Subdirs.
#
#
#