# HG changeset patch # User "Yann E. MORIN" # Date 1232483863 0 # Node ID df32ef8825f9a64d788f49519479d0322850b6dc # Parent 081205fd37901f767eaf45072e20c709cf84da9c On 20090115.0012+0100, "Andy Johnson" wrote: ... I added a step after "debug" called "finish", and moved the code in crosstool.sh after the loop that processes the steps from crosstool.sh into a do_finish function in functions. Thus, it is now possible to restart after the "debug" step to re-do the final few things (clean and compress). /trunk/scripts/crosstool-NG.sh | 38 0 38 0 -------------------------------------- /trunk/scripts/functions | 42 42 0 0 ++++++++++++++++++++++++++++++++++++++++++ /trunk/steps.mk | 3 2 1 0 ++- 3 files changed, 44 insertions(+), 39 deletions(-) diff -r 081205fd3790 -r df32ef8825f9 scripts/crosstool-NG.sh --- a/scripts/crosstool-NG.sh Tue Jan 20 20:10:50 2009 +0000 +++ b/scripts/crosstool-NG.sh Tue Jan 20 20:37:43 2009 +0000 @@ -456,44 +456,6 @@ fi prev_step="${step}" done - - CT_DoLog INFO "=================================================================" - - CT_DoLog DEBUG "Removing access to the build system tools" - find "${CT_PREFIX_DIR}/bin" -name "${CT_BUILD}-"'*' -exec rm -fv {} \; |CT_DoLog DEBUG - find "${CT_PREFIX_DIR}/bin" -name "${CT_HOST}-"'*' -exec rm -fv {} \; |CT_DoLog DEBUG - CT_DoExecLog DEBUG rm -fv "${CT_PREFIX_DIR}/bin/makeinfo" - - if [ "${CT_BARE_METAL}" != "y" ]; then - CT_DoLog EXTRA "Installing the populate helper" - sed -r -e 's|@@CT_TARGET@@|'"${CT_TARGET}"'|g;' \ - "${CT_LIB_DIR}/scripts/populate.in" \ - >"${CT_PREFIX_DIR}/bin/${CT_TARGET}-populate" - CT_DoExecLog ALL chmod 755 "${CT_PREFIX_DIR}/bin/${CT_TARGET}-populate" - fi - - # Create the aliases to the target tools - CT_DoLog EXTRA "Creating toolchain aliases" - CT_Pushd "${CT_PREFIX_DIR}/bin" - for t in "${CT_TARGET}-"*; do - if [ -n "${CT_TARGET_ALIAS}" ]; then - _t=$(echo "$t" |sed -r -e 's/^'"${CT_TARGET}"'-/'"${CT_TARGET_ALIAS}"'-/;') - CT_DoExecLog ALL ln -sv "${t}" "${_t}" - fi - if [ -n "${CT_TARGET_ALIAS_SED_EXPR}" ]; then - _t=$(echo "$t" |sed -r -e "${CT_TARGET_ALIAS_SED_EXPR}") - CT_DoExecLog ALL ln -sv "${t}" "${_t}" - fi - done - CT_Popd - - # Remove the generated documentation files - if [ "${CT_REMOVE_DOCS}" = "y" ]; then - CT_DoLog INFO "Removing installed documentation" - CT_DoForceRmdir "${CT_PREFIX_DIR}/"{,usr/}{man,info} - CT_DoForceRmdir "${CT_SYSROOT_DIR}/"{,usr/}{man,info} - CT_DoForceRmdir "${CT_DEBUG_INSTALL_DIR}/"{,usr/}{man,info} - fi fi CT_DoEnd INFO diff -r 081205fd3790 -r df32ef8825f9 scripts/functions --- a/scripts/functions Tue Jan 20 20:10:50 2009 +0000 +++ b/scripts/functions Tue Jan 20 20:37:43 2009 +0000 @@ -891,3 +891,45 @@ rm -f "${state_dir}/tail.log" fi } + +do_finish() { + CT_DoStep INFO "Cleaning-up the toolchain's directory" + + CT_DoLog EXTRA "Removing access to the build system tools" + find "${CT_PREFIX_DIR}/bin" -name "${CT_BUILD}-"'*' -exec rm -fv {} \; |CT_DoLog DEBUG + find "${CT_PREFIX_DIR}/bin" -name "${CT_HOST}-"'*' -exec rm -fv {} \; |CT_DoLog DEBUG + CT_DoExecLog DEBUG rm -fv "${CT_PREFIX_DIR}/bin/makeinfo" + + if [ "${CT_BARE_METAL}" != "y" ]; then + CT_DoLog EXTRA "Installing the populate helper" + sed -r -e 's|@@CT_TARGET@@|'"${CT_TARGET}"'|g;' \ + "${CT_LIB_DIR}/scripts/populate.in" \ + >"${CT_PREFIX_DIR}/bin/${CT_TARGET}-populate" + CT_DoExecLog ALL chmod 755 "${CT_PREFIX_DIR}/bin/${CT_TARGET}-populate" + fi + + # Create the aliases to the target tools + CT_DoLog EXTRA "Creating toolchain aliases" + CT_Pushd "${CT_PREFIX_DIR}/bin" + for t in "${CT_TARGET}-"*; do + if [ -n "${CT_TARGET_ALIAS}" ]; then + _t=$(echo "$t" |sed -r -e 's/^'"${CT_TARGET}"'-/'"${CT_TARGET_ALIAS}"'-/;') + CT_DoExecLog ALL ln -sv "${t}" "${_t}" + fi + if [ -n "${CT_TARGET_ALIAS_SED_EXPR}" ]; then + _t=$(echo "$t" |sed -r -e "${CT_TARGET_ALIAS_SED_EXPR}") + CT_DoExecLog ALL ln -sv "${t}" "${_t}" + fi + done + CT_Popd + + # Remove the generated documentation files + if [ "${CT_REMOVE_DOCS}" = "y" ]; then + CT_DoLog EXTRA "Removing installed documentation" + CT_DoForceRmdir "${CT_PREFIX_DIR}/"{,usr/}{man,info} + CT_DoForceRmdir "${CT_SYSROOT_DIR}/"{,usr/}{man,info} + CT_DoForceRmdir "${CT_DEBUG_INSTALL_DIR}/"{,usr/}{man,info} + fi + + CT_EndStep +} diff -r 081205fd3790 -r df32ef8825f9 steps.mk --- a/steps.mk Tue Jan 20 20:10:50 2009 +0000 +++ b/steps.mk Tue Jan 20 20:37:43 2009 +0000 @@ -14,7 +14,7 @@ # ---------------------------------------------------------- # The steps list -# Please keep the last line with a '\' and keep the folowing empy line: +# Please keep the last line with a '\' and keep the following empy line: # it helps when diffing and merging. CT_STEPS := libc_check_config \ kernel_headers \ @@ -33,6 +33,7 @@ binutils_target \ tools \ debug \ + finish \ # Make the list available to sub-processes (scripts/crosstool-NG.sh needs it) export CT_STEPS