From 0ccb5f6e037bcbb0817cdb76274a37624c28cb5a Mon Sep 17 00:00:00 2001 From: Dave Reisner Date: Thu, 17 May 2012 22:01:28 -0400 Subject: mkinitcpio: write image config after install hooks Break this out of install/base into a separate function. We need to be able to read from the RUNHOOKS array to accurately specify which hooks to execute at runtime. Signed-off-by: Dave Reisner --- functions | 20 ++++++++++++++++++++ install/base | 15 --------------- mkinitcpio | 2 ++ 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/functions b/functions index a6c7163..ed6d78d 100644 --- a/functions +++ b/functions @@ -547,4 +547,24 @@ find_in_dirs() { return 1 } +write_image_config() { + # write a config file. re-source the config as we can't guarantee the + # environment hasn't been modified, but subshell it so it doesn't disturb + # anyone else. + ( + . "$CONFIG" + + # sanitize of any extra whitespace + read -r -a modules <<< "$MODULES" + (( ${#modules[*]} )) && printf 'MODULES="%s"\n' "${modules[*]%\?}" + + printf '%s="%s"\n' \ + 'EARLYHOOKS' "${RUNHOOKS['early']# }" \ + 'HOOKS' "${RUNHOOKS['hooks']# }" \ + 'LATEHOOKS' "${RUNHOOKS['late']# }" \ + 'CLEANUPHOOKS' "${RUNHOOKS['cleanup']% }" + + ) >"$BUILDROOT/config" +} + # vim: set ft=sh ts=4 sw=4 et: diff --git a/install/base b/install/base index 7eff431..1df209b 100644 --- a/install/base +++ b/install/base @@ -37,21 +37,6 @@ build() { add_file "/usr/lib/initcpio/init_functions" "/init_functions" add_file "/usr/lib/initcpio/init" "/init" add_file "/usr/lib/modprobe.d/usb-load-ehci-first.conf" - - # write a new config file. re-source the config as we can't guarantee the - # environment hasn't been modified, but subshell it so it doesn't disturb - # anyone else. - ( - . "$CONFIG" - - # sanitize of any extra whitespace - read -r -a modules <<< "$MODULES" - - { - (( ${#modules[*]} )) && printf 'MODULES="%s"\n' "${modules[*]%\?}" - (( ${#hooks[*]} )) && printf 'HOOKS="%s"\n' "${hooks[*]}" - } >"$BUILDROOT/config" - ) } help() { diff --git a/mkinitcpio b/mkinitcpio index e346169..4804a67 100755 --- a/mkinitcpio +++ b/mkinitcpio @@ -399,6 +399,8 @@ for var in cfg_{MODULES,BINARIES,FILES}; do done parse_hook +write_image_config + # switch out the error handler to catch all errors trap -- RETURN trap '(( ++builderrors ))' ERR -- cgit v1.2.3-24-g4f1b