scripts/build/debug.sh
author Daniel Price <daniel.price@gmail.com>
Tue Nov 20 16:59:17 2012 -0800 (2012-11-20)
changeset 3126 333d3e40cbd1
parent 483 99724e410693
permissions -rw-r--r--
scripts: refine static linking check to better guide the user

The current mechanism to check if static linking is possible, and the mesage
displayed on failure, can be puzzling to the unsuspecting user.

Also, the current implementation is not using the existing infrastructure,
and is thus difficult to enhance with new tests.

So, switch to using the standard CT_DoExecLog infra, and use four tests to
check for the host compiler:
- check we can run it
- check it can build a trivial program
- check it can statically link that program
- check if it statically link with libstdc++

That should cover most of the problems. Hopefully.

(At the same time, fix a typo in a comment)

Signed-off-by: Daniel Price <daniel.price@gmail.com>
[yann.morin.1998@free.fr: split original patch for self-contained changes]
[yann.morin.1998@free.fr: use steps to better see gcc's output]
[yann.morin.1998@free.fr: commit log]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Message-Id: <163f86b5216fc08c672a.1353459722@nipigon.dssd.com>
Patchwork-Id: 200536
yann@96
     1
# Wrapper to build the debug facilities
yann@96
     2
yann@96
     3
# List all debug facilities, and parse their scripts
yann@96
     4
CT_DEBUG_FACILITY_LIST=
yann@182
     5
for f in "${CT_LIB_DIR}/scripts/build/debug/"*.sh; do
yann@916
     6
    _f="$(basename "${f}" .sh)"
yann@916
     7
    _f="${_f#???-}"
yann@916
     8
    __f="CT_DEBUG_${_f}"
yann@916
     9
    if [ "${!__f}" = "y" ]; then
yann@916
    10
        CT_DoLog DEBUG "Enabling debug '${_f}'"
yann@916
    11
        . "${f}"
yann@916
    12
        CT_DEBUG_FACILITY_LIST="${CT_DEBUG_FACILITY_LIST} ${_f}"
yann@916
    13
    else
yann@916
    14
        CT_DoLog DEBUG "Disabling debug '${_f}'"
yann@96
    15
    fi
yann@96
    16
done
yann@96
    17
yann@96
    18
# Download the debug facilities
yann@96
    19
do_debug_get() {
yann@96
    20
    for f in ${CT_DEBUG_FACILITY_LIST}; do
yann@96
    21
        do_debug_${f}_get
yann@96
    22
    done
yann@96
    23
}
yann@96
    24
yann@96
    25
# Extract and patch the debug facilities
yann@96
    26
do_debug_extract() {
yann@96
    27
    for f in ${CT_DEBUG_FACILITY_LIST}; do
yann@96
    28
        do_debug_${f}_extract
yann@96
    29
    done
yann@96
    30
}
yann@96
    31
yann@96
    32
# Build the debug facilities
yann@96
    33
do_debug() {
yann@96
    34
    for f in ${CT_DEBUG_FACILITY_LIST}; do
yann@96
    35
        do_debug_${f}_build
yann@96
    36
    done
yann@96
    37
}
yann@96
    38