configure
author "Antony N. Pavlov" <antony@niisi.msk.ru>
Sun Jul 17 16:53:40 2011 +0200 (2011-07-17)
changeset 2564 5d4e91c0343e
parent 2540 158702c9f65a
child 2591 491d62ac2017
child 2598 0ef8c2469c8f
permissions -rwxr-xr-x
misc: fix more typos here and there...

Reported-by: "Antony N. Pavlov" <antony@niisi.msk.ru>
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
     1 #!/bin/sh
     2 
     3 myname="${0##*/}"
     4 
     5 VERSION=$( cat .version )
     6 DATE=$( date +%Y%m%d )
     7 
     8 PREFIX_DEFAULT=/usr/local
     9 
    10 BINDIR_set=
    11 LIBDIR_set=
    12 DOCDIR_set=
    13 MANDIR_set=
    14 LOCAL_set=
    15 FORCE=
    16 
    17 do_quit=
    18 
    19 # Simply print the error message, and exit. Obvious, he?
    20 do_error() {
    21     printf "${myname}: ${@}\n"
    22     exit 1
    23 }
    24 
    25 # Given an option string and the following argument,
    26 # echoes the value of the option.
    27 # If --var=val => echoes val and returns 0, meaning second arg was not consumed
    28 # If --var val => echoes val and returns non null, meaning second arg was used
    29 get_optval(){
    30     case "$1" in
    31         --*=?*)
    32             printf "${1#*=}"
    33             return 0
    34             ;;
    35         *)
    36             printf "${2}"
    37             return 1
    38             ;;
    39     esac
    40 }
    41 
    42 # The set_xxx functions will set the corresponding configuration variable
    43 # They return 0 if second arg was not consumed, and non-zero if it was consumed.
    44 set_prefix() {
    45     PREFIX="$( get_optval "$1" "$2" )"
    46 }
    47 set_bindir() {
    48     BINDIR_set=1
    49     BINDIR="$( get_optval "$1" "$2" )"
    50 }
    51 set_libdir() {
    52     LIBDIR_set=1
    53     LIBDIR="$( get_optval "$1" "$2" )"
    54 }
    55 set_docdir() {
    56     DOCDIR_set=1
    57     DOCDIR="$( get_optval "$1" "$2" )"
    58 }
    59 set_mandir() {
    60     MANDIR_set=1
    61     MANDIR="$( get_optval "$1" "$2" )"
    62 }
    63 set_tool() {
    64     local var_name="${1%%=*}"
    65     var_name="${var_name#--with-}"
    66     eval ${var_name}="\$( get_optval "$1" "$2" )"
    67 }
    68 
    69 # var_list is a list of variables, each one holding a path to a
    70 # tool, either detected by ./configure, or specified by the user.
    71 var_list=""
    72 kconfig_list=""
    73 
    74 # This function adds a variable name to the above list of variable names.
    75 # $1: the name of the variable to add to the list
    76 add_to_var_list() {
    77     local v
    78     for v in ${var_list}; do
    79         [ "${v}" = "${1}" ] && return 0
    80     done
    81     var_list="${var_list} ${1}"
    82 }
    83 add_to_kconfig_list() {
    84     local k
    85     for k in ${kconfig_list}; do
    86         [ "${k}" = "${1}" ] && return 0
    87     done
    88     kconfig_list="${kconfig_list} ${1}"
    89 }
    90 
    91 # A function to test for required tools/headers/libraries
    92 # Return 0 (true) if found, !0 (false) if not found
    93 #
    94 # $*: [prog|inc|lib]=<name[ name...]>
    95 #     the name(s) of tool(s) to test for
    96 #     mandatory
    97 #       eg: prog=bash   prog="curl wget"
    98 # $*: var=<var_name>
    99 #     the name of the variable to test and set
   100 #     optional
   101 #       eg: var=bash    if ${bash} is set and non-null, use that,
   102 #                       else check for bash and set bash=$(which bash)
   103 # $*: ver=<regexp>
   104 #     for each 'prog', test if $(prog --version) matches 'regexp'
   105 #     optional
   106 #       eg: ver='^GNU bash, version [34]\.'
   107 # $*: lib_exts=<extension[ extension...]>
   108 #     the list of allowed library extension
   109 #     mandatory
   110 #       eg: lib_exts="so dylib"     lib_exts="so dylib a"
   111 # $*: err=<error_message>
   112 #     the error message to print if tool is missing
   113 #     optional, defaults to: '${prog}: none found'
   114 #       eg: err="'bash' 3.x or above was not found"
   115 #     Note: err may be printed by caller, not us
   116 # $*: kconfig=<var_name>
   117 #     the name of a variable to pass down to kconfig if
   118 #     the prog/inc/lib was found
   119 #     optional, defaults to none
   120 #       eg: kconfig=has_libncurses
   121 # $*: skip=[y|n|]
   122 #     if set to 'y', skip the test, but still register the
   123 #     kconfig and var variables; if 'n' or empty, do the
   124 #     test.
   125 #     optional, default to 'n'
   126 #       eg: skip="${static_link_ko}"
   127 check_for() {
   128     local lib_exts
   129     local skip
   130     local val
   131     local item
   132     local where
   133     local status
   134     local ext
   135 
   136     # Note: prog/inc/lib and var/kconfig/ver/err are set here,
   137     # but declared by the caller (because it needs it)
   138     for item in "${@}"; do
   139         case "${item}" in
   140             prog=*|inc=*|lib=*|var=*|ver=*|err=*|kconfig=*|lib_exts=*|skip=*)
   141                 eval ${item%%=*}=\"${item#*=}\"
   142                 ;;
   143             *)  do_error "check_for: incorrect parameters: '${item}'";;
   144         esac
   145     done
   146 
   147     case "${prog}:${inc}:${lib}" in
   148         ?*:?*:|?*::?*|:?*:?*|?*:?*:?*)
   149             if [ -n "${var}" ]; then
   150                 do_error "check_for: the use of var is not compatible with passing several of [prog|inc|lib] at once"
   151             fi
   152             ;;
   153         ::) do_error "check_for: [prog|inc|lib] is mandatory";;
   154     esac
   155 
   156     if [ -n "${var}" ]; then
   157         add_to_var_list "${var}"
   158     fi
   159     if [ -n "${kconfig}" ]; then
   160         add_to_kconfig_list "${kconfig}"
   161     fi
   162 
   163     if [ "${skip}" = "y" ]; then
   164         return 0
   165     fi
   166 
   167     if [ -n "${prog}" ]; then
   168         for item in ${prog}; do
   169             printf "Checking for '${item}'... "
   170             if [ -n "${var}" ]; then
   171                 eval val="\${${var}}"
   172                 if [ -n "${val}" ]; then
   173                     status="${val} (cached)\n"
   174                     break
   175                 fi
   176             fi
   177             where="$( which "${item}" 2>/dev/null )"
   178             if [ -z "${where}" ]; then
   179                 printf "no\n"
   180                 continue
   181             elif [ -n "${ver}" ]; then
   182                 str=$( LC_ALL=C "${where}" --version 2>&1   \
   183                        |grep -E "${ver}"                    \
   184                        |head -n 1
   185                      )
   186                 if [ -z "${str}" ]; then
   187                     printf "no\n"
   188                     unset where
   189                     continue
   190                 fi
   191             fi
   192             status="${where}"
   193             break
   194         done
   195         if [ -z "${status}" ]; then
   196             return 1
   197         fi
   198         printf "${status}\n"
   199         unset status
   200     fi
   201 
   202     if [ -n "${inc}" ]; then
   203         for item in ${inc}; do
   204             printf "Checking for '${item}'... "
   205             if printf "#include \"${item}\"" |gcc -x c -c - -o /dev/null >/dev/null 2>&1; then
   206                 where="${item}"
   207                 status=yes
   208                 break;
   209             fi
   210             printf "no\n"
   211         done
   212         if [ -z "${status}" ]; then
   213             return 1
   214         fi
   215         printf "${status}\n"
   216         unset status
   217     fi
   218 
   219     if [ -n "${lib}" ]; then
   220         if [ -z "${lib_exts}" ]; then
   221             do_error "check_for: no library extension specified for '${lib}'"
   222         fi
   223         for item in ${lib}; do
   224             for ext in ${lib_exts}; do
   225                 printf "Checking for '${item}.${ext}'... "
   226                 where="$( gcc -print-file-name="${item}.${ext}" )"
   227                 if [ "${where}" != "${item}.${ext}" ]; then
   228                     where="$( readlink "${where}" )"
   229                     status=yes
   230                     break 2;
   231                 fi
   232                 printf "no\n"
   233             done
   234         done
   235         if [ -z "${status}" ]; then
   236             return 1
   237         fi
   238         printf "${status}\n"
   239         unset status
   240     fi
   241 
   242     if [ -n "${var}" ]; then
   243         eval ${var}='"'"${where}"'"'
   244     fi
   245     if [ -n "${kconfig}" ]; then
   246         eval ${kconfig}=y
   247     fi
   248 }
   249 
   250 # This function checks for a tool, and aborts if not found
   251 # See check_for(), above, for how to call has_or_abort
   252 has_or_abort() {
   253     # We declare these 6 variables here, although they are
   254     # set in check_for(), called below
   255     local prog inc lib
   256     local var ver err kconfig
   257 
   258     if ! check_for "$@"; then
   259         printf " * A mandatory dependency is missing, or version mis-match:\n"
   260         printf " * - ${err:-${prog}${inc}${lib}: none found}\n"
   261         if [ -n "${var}" ]; then
   262             printf " * --> You can give the path to this tool using: --with-${var}=PATH\n"
   263         fi
   264         printf "\n"
   265         # Bail out if --force is not specified
   266         [ -z "${FORCE}" ] && do_error "Bailing out..."
   267         printf "<*                                          *>\n"
   268         printf "<*            FORCE in action:              *>\n"
   269         printf "<* Continuing despite missing pre-requisite *>\n"
   270         printf "<*          Prepare for breakage            *>\n"
   271         printf "<*                                          *>\n"
   272         printf "\n"
   273     fi
   274 }
   275 
   276 # This function checks for a tool, and warns if not found
   277 # See check_for(), above, for how to call has_or_abort
   278 # Note: if err is not set, then no error message is printed
   279 has_or_warn() {
   280     # We declare these 6 variables here, although they are
   281     # set in check_for(), called below
   282     local prog inc lib
   283     local var ver err kconfig
   284 
   285     if ! check_for "$@"; then
   286         printf " * An optional dependency is missing, some features will be disabled"
   287         printf "${err:+:\n * - ${err}}\n"
   288         if [ -n "${var}" ]; then
   289             printf " * --> You can give the path to this tool using: --with-${var}=PATH\n"
   290         fi
   291     fi
   292 }
   293 
   294 do_help() {
   295     cat <<__EOF__
   296 \`configure' configures crosstool-NG-${VERSION} to adapt to many kind of systems.
   297 
   298 USAGE: ./configure [OPTION]...
   299 
   300 Defaults for the options are specified in brackets.
   301 
   302 Configuration:
   303   -h, --help              display this help and exit
   304       --force             force configure to continue, even in case
   305                           some pre-requisites are missing
   306 
   307 Installation directories:
   308   --prefix=PREFIX         install files in PREFIX [${PREFIX_DEFAULT}]
   309   --local                 don't install, and use current directory
   310 
   311 By default, \`make install' will install all the files in
   312 \`${PREFIX_DEFAULT}/bin', \`${PREFIX_DEFAULT}/lib' etc.  You can specify
   313 an installation prefix other than \`${PREFIX_DEFAULT}' using \`--prefix',
   314 for instance \`--prefix=\${HOME}'.
   315 
   316 For better control, use the options below.
   317 
   318 Fine tuning of the installation directories:
   319   --bindir=DIR            user executables [PREFIX/bin]
   320   --libdir=DIR            object code libraries [PREFIX/lib]
   321   --docdir=DIR            info documentation [PREFIX/share/doc]
   322   --mandir=DIR            man documentation [PREFIX/share/man]
   323 
   324 Optional Features:
   325   --with-install=PATH     Specify the full PATH to GNU install
   326   --with-make=PATH        Specify the full PATH to GNU make >= 3.80
   327   --with-grep=PATH        Specify the full PATH to GNU grep
   328   --with-sed=PATH         Specify the full PATH to GNU sed
   329   --with-bash=PATH        Specify the full PATH to bash >= 3.0
   330 __EOF__
   331 }
   332 
   333 #---------------------------------------------------------------------
   334 # Set user's options
   335 
   336 while [ $# -ne 0 ]; do
   337     case "$1" in
   338         --local)    LOCAL_set="y"; shift;;
   339         --prefix*)  set_prefix "$1" "$2" && shift || shift 2;;
   340         --bindir*)  set_bindir "$1" "$2" && shift || shift 2;;
   341         --libdir*)  set_libdir "$1" "$2" && shift || shift 2;;
   342         --docdir*)  set_docdir "$1" "$2" && shift || shift 2;;
   343         --mandir*)  set_mandir "$1" "$2" && shift || shift 2;;
   344         --with-*)   set_tool   "$1" "$2" && shift || shift 2;;
   345         --force)    FORCE=1; shift;;
   346         --help|-h)  do_help; exit 0;;
   347         # Skip, auto-stuff compatibility
   348         --build=*|--host=*|--infodir=*|--datadir=*|--sysconfdir=*|--localstatedir=*) shift;;
   349         --build|--host|--infodir|--datadir|--sysconfdir|--localstatedir)             shift 2;;
   350         --enable-shared|--disable-shared|--enable-static|--disable-static)           shift;;
   351         *)          printf "Unrecognised option: '${1}'\n"; do_help; exit 1;;
   352     esac
   353 done
   354 
   355 # Use defaults
   356 [ -z "${PREFIX}" ] && set_prefix "" "${PREFIX_DEFAULT}"
   357 
   358 # Special case when installing locally
   359 if [ "${LOCAL_set}" = "y" ]; then
   360     set_prefix "" "$( pwd )"
   361     set_bindir "" "$( pwd )"
   362     set_libdir "" "$( pwd )"
   363     set_docdir "" "$( pwd )/docs"
   364     set_mandir "" "$( pwd )/docs"
   365 fi
   366 
   367 #---------------------------------------------------------------------
   368 # Some sanity checks, now
   369 
   370 # We check for grep and sed manually, because they are used in check_for()
   371 printf "Checking for 'grep'... "
   372 if [ -n "${grep}" ]; then
   373     printf "${grep} (cached)\n"
   374 else
   375     grep="$( which grep 2>/dev/null )"
   376     if [ -z "${grep}" ]; then
   377         printf "not found\n"
   378     else
   379         printf "${grep}\n"
   380         printf "Checking whether '${grep}' supports -E... "
   381         if echo 'foo' |"${grep}" -E 'foo' >/dev/null 2>&1; then
   382             printf "yes\n"
   383         else
   384             printf "no\n"
   385             grep=
   386         fi
   387     fi
   388 fi
   389 if [ -z "${grep}" ]; then
   390     printf "Either you are missing entirely the needed tool,\n"
   391     printf "or the version you have is too old.\n"
   392     printf "You can give the path to this tool using: --with-grep=PATH\n"
   393     do_error "Bailing out..."
   394 fi
   395 add_to_var_list grep
   396 
   397 printf "Checking for 'sed'... "
   398 if [ -n "${sed}" ]; then
   399     printf "${sed} (cached)\n"
   400 else
   401     sed="$( which sed 2>/dev/null )"
   402     if [ -z "${sed}" ]; then
   403         printf "not found\n"
   404     else
   405         printf "${sed}\n"
   406         printf "Checking whether '${sed}' supports -i and -e... "
   407         touch .ct-ng.sed.test
   408         if "${sed}" -r -i -e 's/foo/bar/' .ct-ng.sed.test >/dev/null 2>&1; then
   409             printf "yes\n"
   410         else
   411             printf "no\n"
   412             sed=
   413         fi
   414         rm -f .ct-ng.sed.test
   415     fi
   416 fi
   417 if [ -z "${sed}" ]; then
   418     printf "Either you are missing entirely the needed tool,\n"
   419     printf "or the version you have is too old.\n"
   420     printf "You can give the path to this tool using: --with-sed=PATH\n"
   421     do_error "Bailing out..."
   422 fi
   423 add_to_var_list sed
   424 
   425 # The regular list of tools we can now easily check for
   426 has_or_abort prog=bash                              \
   427              var=bash                               \
   428              ver='^GNU bash, version (3\.[1-9]|4)'  \
   429              err="'bash' 3.1 or above was not found"
   430 has_or_abort prog=cut
   431 has_or_abort prog=install var=install
   432 has_or_abort prog=make                                  \
   433              var=make                                   \
   434              ver='^GNU Make (3.[89][[:digit:]]|[4-9])'  \
   435              err="GNU 'make' 3.80 or above was not found"
   436 has_or_abort prog=gcc
   437 has_or_abort prog="awk gawk" ver='^GNU Awk' err="GNU 'awk' was not found"
   438 has_or_abort prog=bison
   439 has_or_abort prog=flex
   440 has_or_abort prog=makeinfo
   441 has_or_abort prog=automake                                                      \
   442              ver='\(GNU automake\) (1\.[[:digit:]]{2,}|[2-9][[:digit:]]*\.)'    \
   443              err="'automake' 1.10 or above was not found"
   444 has_or_abort prog=libtool                                                                           \
   445              var=libtool                                                                            \
   446              ver='\(GNU libtool.*\) (2[[:digit:]]*\.|1\.6[[:digit:]]*\.|1\.5\.[2-9][[:digit:]]+)'   \
   447              err="'libtool' 1.5.26 or above was not found"
   448 has_or_abort prog=stat
   449 has_or_abort prog="curl wget"
   450 has_or_abort prog=patch
   451 has_or_abort prog=tar
   452 has_or_abort prog=gzip
   453 has_or_abort prog=bzip2
   454 has_or_abort prog=lzma
   455 has_or_abort prog=readlink
   456 has_or_abort prog=objcopy var=objcopy
   457 has_or_abort prog=objdump var=objdump
   458 has_or_abort prog=readelf var=readelf
   459 has_or_abort prog=patch var=patch
   460 has_or_warn  prog=cvs                                                   \
   461              kconfig=has_cvs                                            \
   462              err="it will not be possible to use newlib cvs snapshots"
   463 has_or_abort prog=svn                               \
   464              kconfig=has_svn                        \
   465              err="subversion is required to download eglibc"
   466 
   467 # Host system checks
   468 
   469 printf "Checking for host system... "
   470 host="$( uname -s )"
   471 printf "%s\n" "${host}"
   472 case "${host}" in
   473     Linux)  ;;
   474     Cygwin) ;;
   475     *)
   476         printf " * Runing under %s is not fully tested\n" "${host}"
   477         printf " * You may encounter some weird behavior\n"
   478         ;;
   479 esac
   480 
   481 printf "Checking if static linking is possible... "
   482 static_link_ok=""
   483 case "${host}" in
   484     Darwin) ;;
   485     *)  tmp=.static.tmp
   486         if gcc -xc - -static -o "${tmp}" >/dev/null 2>&1 <<-_EOF_
   487 				int main() { return 0; }
   488 			_EOF_
   489         then
   490             static_link_ok="y"
   491         fi
   492         rm -f "${tmp}"
   493         ;;
   494 esac
   495 if [ "${static_link_ok}" = "y" ]; then
   496     static_link_ko=""
   497     printf "yes\n"
   498 else
   499     static_link_ko="y"
   500     printf "no\n"
   501     printf " * An optional host feature is missing, some features will be disabled:\n"
   502     printf " * - It will not be possible to statically link toolchain's binaries\n"
   503 fi
   504 add_to_kconfig_list static_link_ok
   505 
   506 # Library checks
   507 libs_exts="so dylib"
   508 if [ "${static_link_ok}" = "y" ]; then
   509     libs_exts="${libs_exts} a"
   510 fi
   511 
   512 ncurses_hdrs="ncurses/ncurses.h ncurses/curses.h ncurses.h curses.h"
   513 ncurses_libs="libncursesw libncurses libcurses"
   514 has_or_abort lib="${ncurses_libs}"                                          \
   515              lib_exts="${libs_exts}"                                        \
   516              inc="${ncurses_hdrs}"                                          \
   517              err="The 'ncurses' library is needed fo the menuconfig frontend"
   518 
   519 has_or_abort lib="libstdc++"            \
   520              lib_exts="${libs_exts}"    \
   521              err="The 'libstdc++' library is needed to build gcc"
   522 
   523 # Yes, we may be checking twice for libstdc++.a
   524 # The first is because we need one instance of libstdc++ (shared or static)
   525 # because it is needed for PPL; the second is because the static version is
   526 # required for static-linking, and if missing, the option is removed.
   527 has_or_warn  lib="libstdc++"                \
   528              lib_exts="a"                   \
   529              err="static 'libstdc++' is needed to statically link the toolchain's executables" \
   530              kconfig=has_static_libstdcxx   \
   531              skip="${static_link_ko}"
   532 
   533 has_or_warn  inc="expat.h"              \
   534              lib="libexpat"             \
   535              lib_exts="${libs_exts}"    \
   536              err="The 'expat' header file and library are needed to link cross-gdb's executables" \
   537              kconfig=has_expat
   538 
   539 # Yes, we may be checking twice for libexpat.a
   540 # The first is because we need one instance of libexpat (shared or static)
   541 # because it is needed for cross-gdb; the second is because the static version
   542 # is required for static-linking, and if missing, the option is removed.
   543 has_or_warn  lib="libexpat"             \
   544              lib_exts="a"               \
   545              err="static 'expat' is needed to statically link cross-gdb's executables" \
   546              kconfig=has_static_expat   \
   547              skip="${static_link_ko}"
   548 
   549 for v in 7 6 5 4; do
   550     python_incs="${python_incs} python2.${v}/Python.h"
   551     python_libs="${python_libs} libpython2.${v}"
   552 done
   553 has_or_warn  inc="${python_incs}"       \
   554              lib="${python_libs}"       \
   555              lib_exts="${libs_exts}"    \
   556              err="The 'python' header file and library are needed for some features of cross-gdb"
   557 
   558 #---------------------------------------------------------------------
   559 # Compute the version string
   560 
   561 # If this version is n hg clone, try to get the revision number
   562 # If we can't get the revision number, use date
   563 printf "\nComputing version string... "
   564 case "${VERSION}" in
   565     *+hg|hg)
   566         REVISION="$( hg id -n 2>/dev/null || true )"
   567         case "${REVISION}" in
   568             "")
   569                 VERSION="${VERSION}_unknown@$( date +%Y%m%d.%H%M%S )";;
   570             *)
   571                 VERSION="${VERSION}_$( hg id -b )@${REVISION%%+}_$( hg id -i )"
   572                 ;;
   573         esac
   574         # Arrange to have no / in the directory name, no need to create an
   575         # arbitrarily deep directory structure
   576         VERSION="$( printf "${VERSION}\n" |"${sed}" -r -e 's|/+|_|g;' )"
   577         ;;
   578 esac
   579 printf "${VERSION}\n"
   580 
   581 #---------------------------------------------------------------------
   582 # Compute and check install paths
   583 
   584 # Now we have the version string, we can build up the paths
   585 [ -z "${BINDIR_set}" ] && BINDIR="${PREFIX}/bin"
   586 [ -z "${LIBDIR_set}" ] && LIBDIR="${PREFIX}/lib"
   587 [ -z "${DOCDIR_set}" ] && DOCDIR="${PREFIX}/share/doc"
   588 [ -z "${MANDIR_set}" ] && MANDIR="${PREFIX}/share/man"
   589 
   590 # Install support files in our own sub-dir, so as not to mangle (system)
   591 # files and dirs, but only if not --local
   592 if [ -z "${LOCAL_set}" ]; then
   593     LIBDIR="${LIBDIR}/ct-ng-${VERSION}"
   594     DOCDIR="${DOCDIR}/ct-ng-${VERSION}"
   595 fi
   596 
   597 # Check that install PATHs are absolute
   598 for p in BIN LIB DOC MAN; do
   599     var="${p}DIR"
   600     eval v='"${'"${var}"'}"'
   601     case "${v}" in
   602         /*) ;;
   603         *)  do_error "'${var}' is not an absolute path: '${v}'"
   604     esac
   605 done
   606 
   607 #---------------------------------------------------------------------
   608 # That's all, folks!
   609 
   610 printf "Building up Makefile... "
   611 var_sed="$( for var_name in ${var_list}; do
   612                 eval echo 's,@@${var_name}@@,${'"${var_name}"'},g'
   613             done
   614           )"
   615 kconfig_sed="s/@@KCONFIG@@/$( for k_name in ${kconfig_list}; do
   616                                   eval printf \"${k_name}=\${${k_name}} \"
   617                               done
   618                             )/"
   619 "${sed}" -r -e "s,@@BINDIR@@,${BINDIR},g"       \
   620             -e "s,@@LIBDIR@@,${LIBDIR},g"       \
   621             -e "s,@@DOCDIR@@,${DOCDIR},g"       \
   622             -e "s,@@MANDIR@@,${MANDIR},g"       \
   623             -e "s,@@VERSION@@,${VERSION},g"     \
   624             -e "s,@@DATE@@,${DATE},g"           \
   625             -e "s,@@LOCAL@@,${LOCAL_set},g"     \
   626             -e "${var_sed}"                     \
   627             -e "${kconfig_sed}"                 \
   628          Makefile.in                            \
   629          >Makefile
   630 echo "done"
   631 
   632 cat <<__EOF__
   633 
   634 crosstool-NG configured as follows:
   635   PREFIX='${PREFIX}'
   636   BINDIR='${BINDIR}'
   637   LIBDIR='${LIBDIR}'
   638   DOCDIR='${DOCDIR}'
   639   MANDIR='${MANDIR}'
   640 
   641 Now run:
   642   make
   643 __EOF__
   644 if [ "${LOCAL_set}" != "y" ]; then
   645     printf "  make install\n"
   646 fi