summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Baumann <mail@daniel-baumann.ch>2013-06-20 11:21:32 +0200
committerDaniel Baumann <mail@daniel-baumann.ch>2013-06-20 11:24:12 +0200
commit966afa2d6418e8f2bd542cce0cda492a598cf32e (patch)
treee75b24fc2d46d30e9edd9cd0430529e07149f3f5
parent001612cdc71267ca46b8fadabd03e86e3c708f36 (diff)
downloadvyos-live-build-966afa2d6418e8f2bd542cce0cda492a598cf32e.tar.gz
vyos-live-build-966afa2d6418e8f2bd542cce0cda492a598cf32e.zip
Splitting out preseed handling from main installer script.
-rwxr-xr-xscripts/build/installer1
-rwxr-xr-xscripts/build/installer_debian-installer16
-rwxr-xr-xscripts/build/installer_preseed64
3 files changed, 73 insertions, 8 deletions
diff --git a/scripts/build/installer b/scripts/build/installer
index 093a79360..8ba37d583 100755
--- a/scripts/build/installer
+++ b/scripts/build/installer
@@ -55,6 +55,7 @@ fi
# Building installer
lb installer_debian-installer ${@}
+lb installer_preseed ${@}
if [ "${LB_BUILD_WITH_CHROOT}" = "true" ]
then
diff --git a/scripts/build/installer_debian-installer b/scripts/build/installer_debian-installer
index 9cd11f721..3606b76f8 100755
--- a/scripts/build/installer_debian-installer
+++ b/scripts/build/installer_debian-installer
@@ -791,12 +791,6 @@ EOF
ln -s . binary/debian
;;
esac
-
- # Including preseeding files
- if Find_files config/debian-installer/*.cfg
- then
- cp config/debian-installer/*.cfg binary/install
- fi
fi
Repack_initrd()
@@ -820,7 +814,13 @@ Repack_initrd()
if [ ! -d "${INCLUDE_PATH}" ]
then
# Invoked the old way, just copy the preseeds
- cp ../config/debian-installer/*.cfg .
+ for _FILE in ../config/preseed/*.cfg ../config/preseed/*.cfg.installer
+ do
+ if [ -e "${_FILE}" ]
+ then
+ cp "${_FILE}" .
+ fi
+ done
else
# New way, include target directory content in the initrd
REPACK_TMPDIR_ABS="${PWD}"
@@ -835,7 +835,7 @@ Repack_initrd()
}
# Preseed d-i by repacking the initrd in certain situations
-if [ "${DI_IMAGE_TYPE}" = "netboot" ] && [ -e config/debian-installer/preseed.cfg ]
+if [ "${DI_IMAGE_TYPE}" = "netboot" ] && ( ls config/preseed/*.cfg > /dev/null 2>&1 || ls config/preseed/*.cfg.installer > /dev/null 2>&1 )
then
Repack_initrd "${DESTDIR}"/"${INITRD_DI}"
diff --git a/scripts/build/installer_preseed b/scripts/build/installer_preseed
new file mode 100755
index 000000000..766dae28d
--- /dev/null
+++ b/scripts/build/installer_preseed
@@ -0,0 +1,64 @@
+#!/bin/sh
+
+## live-build(7) - System Build Scripts
+## Copyright (C) 2006-2013 Daniel Baumann <mail@daniel-baumann.ch>
+##
+## This program comes with ABSOLUTELY NO WARRANTY; for details see COPYING.
+## This is free software, and you are welcome to redistribute it
+## under certain conditions; see COPYING for details.
+
+
+set -e
+
+# Including common functions
+[ -e "${LIVE_BUILD}/scripts/build.sh" ] && . "${LIVE_BUILD}/scripts/build.sh" || . /usr/lib/live/build.sh
+
+# Setting static variables
+DESCRIPTION="$(Echo 'include local preseed in installer')"
+HELP=""
+USAGE="${PROGRAM} [--force]"
+
+Arguments "${@}"
+
+# Reading configuration files
+Read_conffiles config/all config/common config/bootstrap config/chroot config/binary config/source
+Set_defaults
+
+Echo_message "Begin including local preseeds..."
+
+# Checking stage file
+Check_stagefile .build/installer_preseed
+
+# Checking lock file
+Check_lockfile .lock
+
+# Creating lock file
+Create_lockfile .lock
+
+if ls config/preseed/*.cfg > /dev/null 2>&1 || \
+ ls config/preseed/*.cfg.installer > /dev/null 2>&1 || \
+ ls chroot/root/packages.installer > /dev/null 2>&1
+then
+ case "${LB_MODE}" in
+ progress-linux)
+ _DIRECTORY="binary/installer"
+ ;;
+
+ *)
+ _DIRECTORY="binary/install"
+ ;;
+ esac
+
+ rm -f "${_DIRECTORY}/preseed.cfg"
+
+ for _FILE in config/preseed/*.cfg config/preseed/*.cfg.installer chroot/root/packages.installer
+ do
+ if [ -e "${_FILE}" ]
+ then
+ cat "${_FILE}" >> "${_DIRECTORY}/preseed.cfg"
+ fi
+ done
+
+ # Creating stage file
+ Create_stagefile .build/installer_preseed
+fi