configure
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Mon Jul 04 22:53:49 2011 +0200 (2011-07-04)
changeset 2535 e9e8cafaf412
parent 2534 06163d8f6474
child 2540 158702c9f65a
permissions -rwxr-xr-x
configure: do not require cvs

cvs is used to get newlib directly from its repository. Missing cvs
will only allow getting newlib from the released tarballs.

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         *)          printf "Unrecognised option: '${1}'\n"; do_help; exit 1;;
   351     esac
   352 done
   353 
   354 # Use defaults
   355 [ -z "${PREFIX}" ] && set_prefix "" "${PREFIX_DEFAULT}"
   356 
   357 # Special case when installing locally
   358 if [ "${LOCAL_set}" = "y" ]; then
   359     set_prefix "" "$( pwd )"
   360     set_bindir "" "$( pwd )"
   361     set_libdir "" "$( pwd )"
   362     set_docdir "" "$( pwd )/docs"
   363     set_mandir "" "$( pwd )/docs"
   364 fi
   365 
   366 #---------------------------------------------------------------------
   367 # Some sanity checks, now
   368 
   369 # We check for grep and sed manually, because they are used in check_for()
   370 printf "Checking for 'grep'... "
   371 if [ -n "${grep}" ]; then
   372     printf "${grep} (cached)\n"
   373 else
   374     grep="$( which grep 2>/dev/null )"
   375     if [ -z "${grep}" ]; then
   376         printf "not found\n"
   377     else
   378         printf "${grep}\n"
   379         printf "Checking whether '${grep}' supports -E... "
   380         if echo 'foo' |"${grep}" -E 'foo' >/dev/null 2>&1; then
   381             printf "yes\n"
   382         else
   383             printf "no\n"
   384             grep=
   385         fi
   386     fi
   387 fi
   388 if [ -z "${grep}" ]; then
   389     printf "Either you are missing entirely the needed tool,\n"
   390     printf "or the version you have is too old.\n"
   391     printf "You can give the path to this tool using: --with-grep=PATH\n"
   392     do_error "Bailing out..."
   393 fi
   394 add_to_var_list grep
   395 
   396 printf "Checking for 'sed'... "
   397 if [ -n "${sed}" ]; then
   398     printf "${sed} (cached)\n"
   399 else
   400     sed="$( which sed 2>/dev/null )"
   401     if [ -z "${sed}" ]; then
   402         printf "not found\n"
   403     else
   404         printf "${sed}\n"
   405         printf "Checking whether '${sed}' supports -i and -e... "
   406         touch .ct-ng.sed.test
   407         if "${sed}" -r -i -e 's/foo/bar/' .ct-ng.sed.test >/dev/null 2>&1; then
   408             printf "yes\n"
   409         else
   410             printf "no\n"
   411             sed=
   412         fi
   413         rm -f .ct-ng.sed.test
   414     fi
   415 fi
   416 if [ -z "${sed}" ]; then
   417     printf "Either you are missing entirely the needed tool,\n"
   418     printf "or the version you have is too old.\n"
   419     printf "You can give the path to this tool using: --with-sed=PATH\n"
   420     do_error "Bailing out..."
   421 fi
   422 add_to_var_list sed
   423 
   424 # The regular list of tools we can now easily check for
   425 has_or_abort prog=bash                              \
   426              var=bash                               \
   427              ver='^GNU bash, version (3\.[1-9]|4)'  \
   428              err="'bash' 3.1 or above was not found"
   429 has_or_abort prog=cut
   430 has_or_abort prog=install var=install
   431 has_or_abort prog=make                                  \
   432              var=make                                   \
   433              ver='^GNU Make (3.[89][[:digit:]]|[4-9])'  \
   434              err="GNU 'make' 3.80 or above was not found"
   435 has_or_abort prog=gcc
   436 has_or_abort prog="awk gawk" ver='^GNU Awk' err="GNU 'awk' was not found"
   437 has_or_abort prog=bison
   438 has_or_abort prog=flex
   439 has_or_abort prog=makeinfo
   440 has_or_abort prog=automake                                                      \
   441              ver='\(GNU automake\) (1\.[[:digit:]]{2,}|[2-9][[:digit:]]*\.)'    \
   442              err="'automake' 1.10 or above was not found"
   443 has_or_abort prog=libtool                                                                           \
   444              var=libtool                                                                            \
   445              ver='\(GNU libtool.*\) (2[[:digit:]]*\.|1\.6[[:digit:]]*\.|1\.5\.[2-9][[:digit:]]+)'   \
   446              err="'libtool' 1.5.26 or above was not found"
   447 has_or_abort prog=stat
   448 has_or_abort prog="curl wget"
   449 has_or_abort prog=patch
   450 has_or_abort prog=tar
   451 has_or_abort prog=gzip
   452 has_or_abort prog=bzip2
   453 has_or_abort prog=lzma
   454 has_or_abort prog=readlink
   455 has_or_abort prog=objcopy var=objcopy
   456 has_or_abort prog=objdump var=objdump
   457 has_or_abort prog=readelf var=readelf
   458 has_or_abort prog=patch var=patch
   459 has_or_warn  prog=cvs                                                   \
   460              kconfig=has_cvs                                            \
   461              err="it will not be possible to use newlib cvs snapshots"
   462 
   463 # Host system checks
   464 
   465 printf "Checking for host system... "
   466 host="$( uname -s )"
   467 printf "%s\n" "${host}"
   468 case "${host}" in
   469     Linux)  ;;
   470     Cygwin) ;;
   471     *)
   472         printf " * Runing under %s is not fully tested\n" "${host}"
   473         printf " * You may encounter some weird behavior\n"
   474         ;;
   475 esac
   476 
   477 printf "Checking if static linking is possible... "
   478 static_link_ok=""
   479 case "${host}" in
   480     Darwin) ;;
   481     *)  tmp=.static.tmp
   482         if gcc -xc - -static -o "${tmp}" >/dev/null 2>&1 <<-_EOF_
   483 				int main() { return 0; }
   484 			_EOF_
   485         then
   486             static_link_ok="y"
   487         fi
   488         rm -f "${tmp}"
   489         ;;
   490 esac
   491 if [ "${static_link_ok}" = "y" ]; then
   492     static_link_ko=""
   493     printf "yes\n"
   494 else
   495     static_link_ko="y"
   496     printf "no\n"
   497     printf " * An optional host feature is missing, some features will be disabled:\n"
   498     printf " * - It will not be possible to statically link toolchain's binaries\n"
   499 fi
   500 add_to_kconfig_list static_link_ok
   501 
   502 # Library checks
   503 libs_exts="so dylib"
   504 if [ "${static_link_ok}" = "y" ]; then
   505     libs_exts="${libs_exts} a"
   506 fi
   507 
   508 ncurses_hdrs="ncurses/ncurses.h ncurses/curses.h ncurses.h curses.h"
   509 ncurses_libs="libncursesw libncurses libcurses"
   510 has_or_abort lib="${ncurses_libs}"                                          \
   511              lib_exts="${libs_exts}"                                        \
   512              inc="${ncurses_hdrs}"                                          \
   513              err="The 'ncurses' library is needed fo the menuconfig frontend"
   514 
   515 has_or_abort lib="libstdc++"            \
   516              lib_exts="${libs_exts}"    \
   517              err="The 'libstdc++' library is needed to build gcc"
   518 
   519 # Yes, we may be checking twice for libstdc++.a
   520 # The first is because we need one instance of libstdc++ (shared or static)
   521 # because it is needed for PPL; the second is because the static version is
   522 # required for static-linking, and if missing, the option is removed.
   523 has_or_warn  lib="libstdc++"                \
   524              lib_exts="a"                   \
   525              err="static 'libstdc++' is needed to statically link the toolchain's executables" \
   526              kconfig=has_static_libstdcxx   \
   527              skip="${static_link_ko}"
   528 
   529 has_or_warn  inc="expat.h"              \
   530              lib="libexpat"             \
   531              lib_exts="${libs_exts}"    \
   532              err="The 'expat' header file and library are needed to link cross-gdb's executables" \
   533              kconfig=has_expat
   534 
   535 # Yes, we may be checking twice for libexpat.a
   536 # The first is because we need one instance of libexpat (shared or static)
   537 # because it is needed for cross-gdb; the second is because the static version
   538 # is required for static-linking, and if missing, the option is removed.
   539 has_or_warn  lib="libexpat"             \
   540              lib_exts="a"               \
   541              err="static 'expat' is needed to statically link cross-gdb's executables" \
   542              kconfig=has_static_expat   \
   543              skip="${static_link_ko}"
   544 
   545 for v in 7 6 5 4; do
   546     python_incs="${python_incs} python2.${v}/Python.h"
   547     python_libs="${python_libs} libpython2.${v}"
   548 done
   549 has_or_warn  inc="${python_incs}"       \
   550              lib="${python_libs}"       \
   551              lib_exts="${libs_exts}"    \
   552              err="The 'python' header file and library are needed for some features of cross-gdb"
   553 
   554 #---------------------------------------------------------------------
   555 # Compute the version string
   556 
   557 # If this version is n hg clone, try to get the revision number
   558 # If we can't get the revision number, use date
   559 printf "\nComputing version string... "
   560 case "${VERSION}" in
   561     *+hg|hg)
   562         REVISION="$( hg id -n 2>/dev/null || true )"
   563         case "${REVISION}" in
   564             "")
   565                 VERSION="${VERSION}_unknown@$( date +%Y%m%d.%H%M%S )";;
   566             *)
   567                 VERSION="${VERSION}_$( hg id -b )@${REVISION%%+}_$( hg id -i )"
   568                 ;;
   569         esac
   570         # Arrange to have no / in the directory name, no need to create an
   571         # arbitrarily deep directory structure
   572         VERSION="$( printf "${VERSION}\n" |"${sed}" -r -e 's|/+|_|g;' )"
   573         ;;
   574 esac
   575 printf "${VERSION}\n"
   576 
   577 #---------------------------------------------------------------------
   578 # Compute and check install paths
   579 
   580 # Now we have the version string, we can build up the paths
   581 [ -z "${BINDIR_set}" ] && BINDIR="${PREFIX}/bin"
   582 [ -z "${LIBDIR_set}" ] && LIBDIR="${PREFIX}/lib"
   583 [ -z "${DOCDIR_set}" ] && DOCDIR="${PREFIX}/share/doc"
   584 [ -z "${MANDIR_set}" ] && MANDIR="${PREFIX}/share/man"
   585 
   586 # Install support files in our own sub-dir, so as not to mangle (system)
   587 # files and dirs, but only if not --local
   588 if [ -z "${LOCAL_set}" ]; then
   589     LIBDIR="${LIBDIR}/ct-ng-${VERSION}"
   590     DOCDIR="${DOCDIR}/ct-ng-${VERSION}"
   591 fi
   592 
   593 # Check that install PATHs are absolute
   594 for p in BIN LIB DOC MAN; do
   595     var="${p}DIR"
   596     eval v='"${'"${var}"'}"'
   597     case "${v}" in
   598         /*) ;;
   599         *)  do_error "'${var}' is not an absolute path: '${v}'"
   600     esac
   601 done
   602 
   603 #---------------------------------------------------------------------
   604 # That's all, folks!
   605 
   606 printf "Building up Makefile... "
   607 var_sed="$( for var_name in ${var_list}; do
   608                 eval echo 's,@@${var_name}@@,${'"${var_name}"'},g'
   609             done
   610           )"
   611 kconfig_sed="s/@@KCONFIG@@/$( for k_name in ${kconfig_list}; do
   612                                   eval printf \"${k_name}=\${${k_name}} \"
   613                               done
   614                             )/"
   615 "${sed}" -r -e "s,@@BINDIR@@,${BINDIR},g"       \
   616             -e "s,@@LIBDIR@@,${LIBDIR},g"       \
   617             -e "s,@@DOCDIR@@,${DOCDIR},g"       \
   618             -e "s,@@MANDIR@@,${MANDIR},g"       \
   619             -e "s,@@VERSION@@,${VERSION},g"     \
   620             -e "s,@@DATE@@,${DATE},g"           \
   621             -e "s,@@LOCAL@@,${LOCAL_set},g"     \
   622             -e "${var_sed}"                     \
   623             -e "${kconfig_sed}"                 \
   624          Makefile.in                            \
   625          >Makefile
   626 echo "done"
   627 
   628 cat <<__EOF__
   629 
   630 crosstool-NG configured as follows:
   631   PREFIX='${PREFIX}'
   632   BINDIR='${BINDIR}'
   633   LIBDIR='${LIBDIR}'
   634   DOCDIR='${DOCDIR}'
   635   MANDIR='${MANDIR}'
   636 
   637 Now run:
   638   make
   639 __EOF__
   640 if [ "${LOCAL_set}" != "y" ]; then
   641     printf "  make install\n"
   642 fi