scripts/build/tools.sh
author Oron Peled <oron@actcom.co.il>
Mon Aug 03 00:49:25 2009 +0200 (2009-08-03)
branch1.4
changeset 1456 94fc77c37418
parent 483 99724e410693
permissions -rw-r--r--
[complib:mpfr] Fix building MPFR in some weird cases

The tmul test uses a compiled-in input file in $(srcdir).
The problem is that the Makefile passes it unquoted. The C code
tries to stringify it using clever macros, which may *usually* work.

In my case the source directory was named:
.../toolchain-powerpc-e500v2-linux-gnuspe-1.0-2.fc10/.../tests
And guess what? During testing I found out the program fails because
it tries to open:
.../toolchain-powerpc-e500v2-1-gnuspe-1.0-2.fc10/.../tests

Yes, CPP tokenized the macro before stringifying it and not surprisingly
the 'linux' part was converted to 1.
[on Fedora-10: cpp (GCC) 4.3.2 20081105 (Red Hat 4.3.2-7)]

So the attached patch simplify the macros and pass the path as string
from the Makefile.

Manually backported from 1449:8ad2773e7ae3
yann@148
     1
# Wrapper to build the tools facilities
yann@148
     2
yann@148
     3
# List all tools facilities, and parse their scripts
yann@148
     4
CT_TOOLS_FACILITY_LIST=
yann@182
     5
for f in "${CT_LIB_DIR}/scripts/build/tools/"*.sh; do
yann@916
     6
    _f="$(basename "${f}" .sh)"
yann@916
     7
    _f="${_f#???-}"
yann@916
     8
    __f="CT_TOOL_${_f}"
yann@916
     9
    if [ "${!__f}" = "y" ]; then
yann@916
    10
        CT_DoLog DEBUG "Enabling tool '${_f}'"
yann@916
    11
        . "${f}"
yann@916
    12
        CT_TOOLS_FACILITY_LIST="${CT_TOOLS_FACILITY_LIST} ${_f}"
yann@916
    13
    else
yann@916
    14
        CT_DoLog DEBUG "Disabling tool '${_f}'"
yann@148
    15
    fi
yann@148
    16
done
yann@148
    17
yann@148
    18
# Download the tools facilities
yann@148
    19
do_tools_get() {
yann@148
    20
    for f in ${CT_TOOLS_FACILITY_LIST}; do
yann@148
    21
        do_tools_${f}_get
yann@148
    22
    done
yann@148
    23
}
yann@148
    24
yann@148
    25
# Extract and patch the tools facilities
yann@148
    26
do_tools_extract() {
yann@148
    27
    for f in ${CT_TOOLS_FACILITY_LIST}; do
yann@148
    28
        do_tools_${f}_extract
yann@148
    29
    done
yann@148
    30
}
yann@148
    31
yann@148
    32
# Build the tools facilities
yann@148
    33
do_tools() {
yann@148
    34
    for f in ${CT_TOOLS_FACILITY_LIST}; do
yann@148
    35
        do_tools_${f}_build
yann@148
    36
    done
yann@148
    37
}
yann@148
    38