use relative paths for configure and srcdir when possible

This commit is contained in:
K. Richard Pixley 1992-03-11 05:50:05 +00:00
parent 7fcfdcf774
commit c1e4672ca0
2 changed files with 378 additions and 339 deletions

View File

@ -1,4 +1,57 @@
Mon Feb 24 17:08:01 1992 K. Richard Pixley (rich@rtl.cygnus.com)
Tue Mar 10 21:49:18 1992 K. Richard Pixley (rich@mars.cygnus.com)
* configure: use relative paths for configure and srcdir whenever
possible.
Tue Mar 10 18:01:55 1992 Per Bothner (bothner@cygnus.com)
* Makefile.in: Fix libg++ rule to check for gcc directory
before using gcc/gcc. Also pass XTRAFLAGS.
Thu Mar 5 21:45:07 1992 K. Richard Pixley (rich@sendai)
* Makefile.in: added stmp-files so that directories aren't polled
when they are already built.
* configure.texi: fixed a node pointer problem.
Thu Mar 5 12:05:58 1992 Stu Grossman (grossman at cygnus.com)
* config.sub configure.in config/.Sanitize config/mh-irix4
gdb/.Sanitize gdb/configure.in gdb/mips-tdep.c gdb/mipsread.c
gdb/procfs.c gdb/signame.h gdb/tm-irix3.h gdb/tm-mips.h
gdb/xm-irix4.h gdb/config/.Sanitize gdb/config/mt-irix3
gdb/config/mh-irix4 texinfo/configure.in: Port to SGI Irix-4.x.
Wed Mar 4 02:57:46 1992 K. Richard Pixley (rich@rtl.cygnus.com)
* configure: -recurring becomes -silent. corrected help message
for -site= option.
* Makefile.in: mkdir $(exec_prefix) and $(tooldir).
Tue Mar 3 14:51:21 1992 K. Richard Pixley (rich@rtl.cygnus.com)
* configure: when building Makefile for crosses, replace
tooldir and program_prefix. default srcdir from location of
config.sub. remove "for host in hosts" and "for target in
targets" loops.
Wed Feb 26 19:48:25 1992 K. Richard Pixley (rich@rtl.cygnus.com)
* Makefile.in: Do not pass bindir or mandir to cvs.
Wed Feb 26 18:04:40 1992 K. Richard Pixley (rich@cygnus.com)
* Makefile.in, configure.in: removed traces of namesubdir,
-subdirs, $(subdir), $(unsubdir), some rcs triggers. Forced
copyrights to '92, changed some from Cygnus to FSF.
* configure.texi: remove most references to multiple hosts,
multiple targets, subdirs, etc.
* configure.man: removed rcsid. reference config.sub not
config.subr.
* Makefile.in: mkdir $(infodir) on install-info.

222
configure vendored
View File

@ -3,8 +3,6 @@
# Configuration script
# Copyright (C) 1988, 1990, 1991, 1992 Free Software Foundation, Inc.
#This file is part of GNU.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
@ -22,6 +20,8 @@
# Please email any bugs, comments, and/or additions to this file to:
# configure@cygnus.com
# This file was written by K. Richard Pixley.
#
# Shell script to create proper links to machine-dependent files in
# preparation for compilation.
@ -31,9 +31,6 @@
# config.status is removed.
#
# NOTE: This script contains support for a Cygnus experimental feature, called
# +subdirs, which is currently, tentatively, de-supported.
export PATH || (echo "OOPS, this isn't sh. Desperation time. I will feed myself to sh."; sh $0 $argv; kill $$)
remove=rm
@ -50,16 +47,14 @@ symbolic_link='ln -s'
Makefile=Makefile
Makefile_in=Makefile.in
arguments=$*
commontargets=
configdirs=
datadir=
datadiroption=
defaulttargets=
exec_prefix=
exec_prefixoption=
fatal=
floating_point=default
gas=default
host_alias=
host_makefile_frag=
hosts=
next_host=
next_prefix=
next_site=
@ -69,14 +64,14 @@ next_tmpdir=
norecursion=
prefix=/usr/local
progname=
recurring=
removing=
program_prefix=
program_prefix_option=
silent=
site_makefile_frag=
srcdir=
srctrigger=
target=
target_alias=
target_makefile_frag=
targets=
undefinedargs=
verbose=
version="$Revision$"
@ -86,40 +81,43 @@ NO_EDIT="This file was generated automatically by configure. Do not edit."
## this is a little touchy and won't always work, but...
##
## if the argv[0] starts with a slash then it is an absolute name that can be
## used as is.
## if the argv[0] starts with a slash then it is an absolute name that can (and
## must) be used as is.
##
## otherwise, if argv[0] has no slash in it, we can assume that it is on the
## path. Since PATH might include "." we also add `pwd` to the end of PATH.
##
## otherwise we prepend `pwd` to $0 and hope that will give us an absolute
## path.
##
PWD=`pwd`
progname=$0
if echo $0 | grep '^/' > /dev/null ; then
progname=$0
elif echo $0 | grep '/' > /dev/null ; then
progname=${PWD}/$0
else
progname=$0
case "${progname}" in
/*) ;;
*/*) ;;
*)
PATH=$PATH:${PWD} ; export PATH
fi
;;
esac
for arg in $*;
do
# handle things that might have args following as separate words
if [ -n "${next_prefix}" ] ; then prefix=${arg} ; prefixoption="-prefix=${prefix}" ; next_prefix=
elif [ -n "${next_datadir}" ] ; then datadir=${arg} ; datadiroption="-datadir=${datadir}" ; next_datadir=
elif [ -n "${next_exec_prefix}" ] ; then
exec_prefix=${arg}
exec_prefixoption="-exec_prefix=${exec_prefix}"
next_exec_prefix=
elif [ -n "${next_site}" ] ; then site=${arg} ; next_site=
elif [ -n "${next_srcdir}" ] ; then srcdir=${arg} ; next_srcdir=
elif [ -n "${next_program_prefix}" ] ; then
program_prefix=${arg}
program_prefixoption="-program_prefix=${program_prefix}"
next_program_prefix=
elif [ -n "${next_target}" ] ; then
next_target=
case "${targets}" in
case "${target_alias}" in
"")
newtargets="${targets} ${arg}"
targets="${newtargets}"
target_alias="${arg}"
;;
*)
echo '***' Can only configure for one target at a time.
@ -133,12 +131,12 @@ do
else
case ${arg} in
-datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* | --da=* | --d=*)
datadir=`echo ${arg} | sed 's/^[-a-z]*=//'`
datadiroption=${arg}
-exec_prefix=* | --exec_prefix=* | --exec_prefi=* | --exec_pref=* | --exec_pre=* | --exec_pr=* | --exec_p=* | --exec_=* | --exec=* | --exe=* | --ex=* | --e=*)
exec_prefix=`echo ${arg} | sed 's/^[-a-z_]*=//'`
exec_prefixoption=${arg}
;;
-datadir | --datadir | --datadi | --datad | --data | --dat | --da | --d)
next_datadir=yes
-exec_prefix | --exec_prefix | --exec_prefi | --exec_pref | --exec_pre | --exec_pr | --exec_p | --exec_ | --exec | --exe | --ex | --e)
next_exec_prefix=yes
;;
-gas | --g*)
gas=yes
@ -147,10 +145,9 @@ do
fatal=true
;;
-host=* | --host=* | --hos=* | --ho=*)
case "${hosts}" in
case "${host_alias}" in
"")
newhosts="${hosts} `echo ${arg} | sed 's/^[-a-z]*=//'`"
hosts="${newhosts}"
host_alias="`echo ${arg} | sed 's/^[-a-z]*=//'`"
;;
*)
echo '***' Can only configure for one host at a time.
@ -164,24 +161,28 @@ do
-norecursion | --no*)
norecursion=true
;;
-prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*)
-prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=*)
prefix=`echo ${arg} | sed 's/^[-a-z]*=//'`
prefixoption=${arg}
;;
-prefix | --prefix | --prefi | --pref | --pre | --pr | --p)
-prefix | --prefix | --prefi | --pref | --pre)
next_prefix=yes
;;
-recurring | --recurring | --recurrin | --recurri | --recurr | --recur | --recu | --rec | --re)
recurring=true
arguments=`echo ${arguments} | sed "s:${arg}::"`
-program_prefix=* | --program_prefix=* | --program_prefi=* | --program_pref=* | --program_pre=* | --program_pr=* | --program_p=* | --program_=* | --program=* | --progra=* | --progr=* | --prog=* | --pro=*)
program_prefix=`echo ${arg} | sed 's/^[-a-z]*=//'`
program_prefixoption=${arg}
;;
-rm | --rm)
removing=${arg}
-program_prefix | --program_prefix | --program_prefi | --program_pref | --program_pre | --program_pr | --program_p | --program_ | --program | --progra | --progr | --prog | --pro)
next_program_prefix=yes
;;
-s | -silent | --silent | --silen | --sile | --sil)
silent=true
arguments=`echo ${arguments} | sed "s:${arg}::"`
;;
-site=* | --site=* | --sit=* | --si=*)
site=`echo ${arg} | sed 's/^[-a-z]*=//'`
;;
-site | --site | --sit | --si)
-site | --site | --sit)
next_site=yes
;;
-srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*)
@ -191,11 +192,8 @@ do
next_srcdir=yes
;;
-target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=*)
case "${targets}" in
"")
newtargets="${targets} `echo ${arg} | sed 's/^[-a-z]*=//'`"
targets="${newtargets}"
;;
case "${target_alias}" in
"") target_alias="`echo ${arg} | sed 's/^[-a-z]*=//'`" ;;
*)
echo '***' Can only configure for one target at a time.
fatal=yes
@ -229,8 +227,7 @@ do
*)
case "${undefs}" in
"")
newundefs="${undefs} ${arg}"
undefs=${newundefs}
undefs="${arg}"
;;
*)
echo '***' Can only configure for one host and one target at a time.
@ -246,7 +243,7 @@ done
case "${fatal}" in
"")
# # Complain if an arg is missing
# if [ -z "${hosts}" ] ; then
# if [ -z "${host_alias}" ] ; then
# (echo ;
# echo "configure: No HOST specified." ;
# echo) 1>&2
@ -261,23 +258,23 @@ case "${fatal}" in
### * if no targets are specified, then the unadorned args are targets, but if
### there were no unadorned args, then the hosts are also targets.
if [ -n "${hosts}" -a -n "${targets}" -a -n "${undefs}" ] ; then
if [ -n "${host_alias}" -a -n "${target_alias}" -a -n "${undefs}" ] ; then
echo '***' Can only configure for one host and one target at a time.
fatal=yes
elif [ -z "${hosts}" -a -z "${undefs}" ] ; then
elif [ -z "${host_alias}" -a -z "${undefs}" ] ; then
echo '***' You must tell me for which host you want to configure.
fatal=yes
else
case "${hosts}" in
"") hosts=${undefs} ;;
case "${host_alias}" in
"") host_alias=${undefs} ;;
*) ;;
esac
case "${targets}" in
case "${target_alias}" in
"")
case "${undefs}" in
"") targets=${hosts} ;;
*) targets=${undefs} ;;
"") target_alias=${host_alias} ;;
*) target_alias=${undefs} ;;
esac
;;
*) ;;
@ -287,19 +284,19 @@ case "${fatal}" in
*) ;;
esac
if [ -n "${fatal}" -o "${hosts}" = "help" ] ; then
if [ -n "${fatal}" -o "${host_alias}" = "help" ] ; then
(echo "Usage: configure HOST" ;
echo ;
echo "Options: [defaults in brackets]" ;
echo " -datadir=MYDIR configure for installation of host dependent files into MYDIR. [\"/usr/local\"]" ;
echo " -exec_prefix=MYDIR configure for installation of host dependent files into MYDIR. [\"/usr/local\"]" ;
echo " -gas configure the compilers for use with gas. [native as]" ;
echo " -help print this message. [normal config]" ;
echo " -lang=LANG configure to build LANG. [gcc]" ;
echo " -nfp configure the compilers default to soft floating point. [hard float]" ;
echo " -norecursion configure this directory only. [recurse]" ;
echo " -prefix=MYDIR configure for installation of host dependent files into MYDIR. [\"/usr/local\"]" ;
echo " -rm remove this configuration. [build a configuration]" ;
echo " -site configure with site specific makefile" ;
echo " -program_prefix=FOO install programs with FOO prepended to their names. [ \"\" ]" ;
echo " -site=SITE configure with site specific makefile for SITE" ;
echo " -srcdir=DIR find the sources in DIR. [\".\" or \"..\"]" ;
echo " -target=TARGET configure for TARGET. [TARGET = HOST]" ;
echo " -tmpdir=TMPDIR create temporary files in TMPDIR. [ TMPDIR = \"/tmp\" ]" ;
@ -316,7 +313,7 @@ fi
configsub=`echo ${progname} | sed 's/configure$/config.sub/'`
if ${configsub} `echo ${hosts} | sed -e 's/ .*//'` >/dev/null 2>&1 ; then
if ${configsub} `echo ${host_alias} | sed -e 's/ .*//'` >/dev/null 2>&1 ; then
true
else
echo '***' cannot find config.sub.
@ -327,18 +324,22 @@ case "${srcdir}" in
"")
if [ -r configure.in ] ; then
srcdir=.
else
if [ -r ${progname}.in ] ; then
srcdir=`echo ${progname} | sed 's:/configure$::'`
else
echo '***' "Can't find configure.in. Try using -srcdir=some_dir"
exit 1
fi
fi
;;
*) ;;
esac
# default datadir
case "${datadir}" in
"") datadir="$(prefix)/lib" ;;
# default exec_prefix
case "${exec_prefix}" in
"") exec_prefix="${prefix}" ;;
*) ;;
esac
@ -393,16 +394,7 @@ case "${srctrigger}" in
*) ;;
esac
for host in ${hosts} ; do
# Default other arg
if [ -z "${targets}" -o -n "${defaulttargets}" ] ; then
targets=${host}
defaulttargets=true
fi
host_alias=${host}
result=`${configsub} ${host}`
result=`${configsub} ${host_alias}`
host_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'`
host_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'`
host_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'`
@ -410,10 +402,7 @@ for host in ${hosts} ; do
. ${tmpfile}.hst
for target in ${targets} ; do
target_alias=${target}
result=`${configsub} ${target}`
result=`${configsub} ${target_alias}`
target_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'`
target_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'`
target_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'`
@ -421,18 +410,6 @@ for host in ${hosts} ; do
. ${tmpfile}.tgt
case "${host_alias}" in
"${target_alias}") subdirname=H-${host_alias} ;;
*) subdirname=X-${host_alias}-${target_alias} ;;
esac
case "${namesubdir}" in
"") ;;
*) subdirname=${namesubdir} ;;
esac
case "${removing}" in
"")
# Find the source files, if location was not specified.
case "${srcdir}" in
"")
@ -459,6 +436,7 @@ for host in ${hosts} ; do
# ${links} is the list of link names, and ${files} is the list of names to link to.
# Make the links.
configlinks="${links}"
while [ -n "${files}" ] ; do
# set file to car of files, files to cdr of files
set ${files}; file=$1; shift; files=$*
@ -522,7 +500,7 @@ EOF
if [ -f ${site_makefile_frag} ] ; then
sed -e "/^####/ r ${site_makefile_frag}" ${srcdir}/${Makefile_in} \
>> Makefile.tem
> Makefile.tem
else
cp ${srcdir}/${Makefile_in} Makefile.tem
site_makefile_frag=
@ -552,7 +530,7 @@ EOF
*)
target_makefile_frag=${srcdir}/${target_makefile_frag}
if [ -f ${target_makefile_frag} ] ; then
sed -e "/^####/ r ${target_makefile_frag}" ${Makefile} >> Makefile.tem
sed -e "/^####/ r ${target_makefile_frag}" ${Makefile} > Makefile.tem
else
mv ${Makefile} Makefile.tem
target_makefile_frag=
@ -562,7 +540,6 @@ EOF
# real copy now in Makefile.tem
# prepend warning about editting, and a bunch of variables.
# fixme-someday: remove the subdir/unsubdir lines.
cat > ${Makefile} <<EOF
# ${NO_EDIT}
host_alias = ${host_alias}
@ -576,34 +553,45 @@ target_os = ${target_os}
target_makefile_frag = ${target_makefile_frag}
host_makefile_frag = ${host_makefile_frag}
site_makefile_frag = ${site_makefile_frag}
links = ${configlinks}
VPATH = ${srcdir}
subdir =
unsubdir = .
EOF
# fixme: this shouldn't be in configure.
# Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
case "${host}" in
"${target}") echo "ALL=all.internal" >> ${Makefile} ;;
case "${host_alias}" in
"${target_alias}")
tooldir="$(libdir)"
echo "ALL=all.internal" >> ${Makefile}
;;
*)
echo "CROSS=-DCROSS_COMPILE" >> ${Makefile}
echo "ALL=all.cross" >> ${Makefile}
case "${program_prefix}" in
"") program_prefix=${target_alias}- ;;
*) ;;
esac
tooldir="$(libdir)/${target_alias}"
;;
esac
# reset prefix, datadir, srcdir, SUBDIRS, NONSUBDIRS, remove any form
# reset prefix, exec_prefix, srcdir, SUBDIRS, NONSUBDIRS, remove any form
# feeds.
sed -e "s:^prefix[ ]*=.*$:prefix = ${prefix}:" \
-e "s:^datadir[ ]*=.*$:datadir = ${datadir}:" \
-e "s:^exec_prefix[ ]*=.*$:exec_prefix = ${exec_prefix}:" \
-e "s:^srcdir[ ]*=.*$:srcdir = ${srcdir}:" \
-e "s:^SUBDIRS[ ]*=.*$:SUBDIRS = ${configdirs}:" \
-e "s:^NONSUBDIRS[ ]*=.*$:NONSUBDIRS = ${noconfigdirs}:" \
-e "s/ //" Makefile.tem >> ${Makefile}
-e "s/ //" \
-e "s:^program_prefix[ ]*=.*$:program_prefix = ${program_prefix}:" \
-e "s:^tooldir[ ]*=.*$:tooldir = ${tooldir}:" \
Makefile.tem >> ${Makefile}
# final copy now in ${Makefile}
rm Makefile.tem
if [ -n "${verbose}" -o -z "${recurring}" ] ; then
if [ -n "${verbose}" -o -z "${silent}" ] ; then
case "${host_makefile_frag}" in
"") using= ;;
*) using="and \"${host_makefile_frag}\"" ;;
@ -640,9 +628,6 @@ EOF
${progname}" ${arguments} "
# ${using}" > config.status
chmod a+x config.status
;;
*) rm -f ${Makefile} config.status ${links} ;;
esac
# If there are subdirectories, then recur.
if [ -z "${norecursion}" -a -n "${configdirs}" ] ; then
@ -665,7 +650,7 @@ ${progname}" ${arguments} "
POPDIR=${PWD}
cd ${configdir}
### figure out what to do with srcdir & guest configure
### figure out what to do with srcdir
case "${srcdir}" in
".") newsrcdir=${srcdir} ;; # no -srcdir option. We're building in place.
/*) # absolute path
@ -678,17 +663,20 @@ ${progname}" ${arguments} "
;;
esac
### The recursion line is here.
### check for guested configure, otherwise fix possibly relative progname
if [ -f ${newsrcdir}/configure ] ; then
recprog=${newsrcdir}/configure
else
recprog=${progname}
case "${progname}" in
/*) recprog=${progname} ;;
*) recprog=../${progname} ;;
esac
fi
if ${recprog} -recurring ${host_alias} -target=${target_alias} \
${verbose} ${subdirs} ${removing} ${prefixoption} \
${tmpdiroption} ${namesubdiroption} ${datadiroption} \
${srcdiroption} ; then
### The recursion line is here.
if ${recprog} -s ${host_alias} -target=${target_alias} \
${verbose} ${prefixoption} ${tmpdiroption} ${exec_prefixoption} \
${srcdiroption} ${program_prefixoption} ; then
true
else
exit 1
@ -703,8 +691,6 @@ ${progname}" ${arguments} "
fi
done
fi
done # for each target
done # for each host
### clean up.