diff options
author | Daniel Baumann <daniel@debian.org> | 2011-06-11 19:36:46 +0200 |
---|---|---|
committer | Daniel Baumann <daniel@debian.org> | 2011-06-11 19:36:46 +0200 |
commit | df7b3d934f2b31f9e8a783bd1653ab06521a2547 (patch) | |
tree | f3f08ae77dffc9c83a95c3b3fb6331ac353d98fe /scripts/build | |
parent | 48e2af1ab9aebb974b718568f6c3060cfeb72cee (diff) | |
download | vyos-live-build-df7b3d934f2b31f9e8a783bd1653ab06521a2547.tar.gz vyos-live-build-df7b3d934f2b31f9e8a783bd1653ab06521a2547.zip |
Moving installation of live packages to second pass.
Diffstat (limited to 'scripts/build')
-rwxr-xr-x | scripts/build/lb_chroot | 1 | ||||
-rwxr-xr-x | scripts/build/lb_chroot_linux-image | 31 | ||||
-rwxr-xr-x | scripts/build/lb_chroot_live-packages | 83 |
3 files changed, 86 insertions, 29 deletions
diff --git a/scripts/build/lb_chroot b/scripts/build/lb_chroot index aeb3629c5..d015c0425 100755 --- a/scripts/build/lb_chroot +++ b/scripts/build/lb_chroot @@ -70,6 +70,7 @@ do fi done +lb chroot_live-packages ${*} lb chroot_local-includes ${*} lb chroot_local-patches ${*} lb chroot_local-hooks ${*} diff --git a/scripts/build/lb_chroot_linux-image b/scripts/build/lb_chroot_linux-image index 39ee0fae5..e060ff3e6 100755 --- a/scripts/build/lb_chroot_linux-image +++ b/scripts/build/lb_chroot_linux-image @@ -52,34 +52,7 @@ then echo ${PACKAGE}-${FLAVOUR} >> chroot/root/chroot_packages done done -fi - -# Queue installation of linux-image and ${LB_INITRAMFS} -if [ "${LB_INITRAMFS}" != "none" ] -then - echo ${LB_INITRAMFS} >> chroot/root/chroot_packages -fi -# Queue installation of live-config -if [ "${LB_INITSYSTEM}" != "none" ] -then - echo "live-config live-config-${LB_INITSYSTEM}" >> chroot/root/chroot_packages + # Creating stage file + Create_stagefile .stage/chroot_linux-image fi - -# Do initsystem specific hacks -if [ "${LB_INITSYSTEM}" != "sysvinit" ] -then - # lets see if we still need the squeeze's "pre init system policy discussion" hack: - - IS_SYSVINIT_ESSENTIAL="$(Chroot chroot dpkg-query --show --showformat='${Essential}\n' sysvinit)" - RC="$?" - - if [ "${IS_SYSVINIT_ESSENTIAL}" != "no" ] && [ "${RC}" = "0" ] - then - # sysvinit is both installed and essential, ugly hack to remove it - Chroot chroot dpkg --force-remove-essential --remove sysvinit || true - fi -fi - -# Creating stage file -Create_stagefile .stage/chroot_linux-image diff --git a/scripts/build/lb_chroot_live-packages b/scripts/build/lb_chroot_live-packages new file mode 100755 index 000000000..31734a8d8 --- /dev/null +++ b/scripts/build/lb_chroot_live-packages @@ -0,0 +1,83 @@ +#!/bin/sh + +## live-build(7) - System Build Scripts +## Copyright (C) 2006-2011 Daniel Baumann <daniel@debian.org> +## +## live-build 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 +. "${LB_BASE:-/usr/share/live/build}"/scripts/build.sh + +# Setting static variables +DESCRIPTION="$(Echo 'schedule live packages for installation')" +HELP="" +USAGE="${PROGRAM} [--force]" + +Arguments "${@}" + +# Reading configuration files +Read_conffiles config/all config/common config/bootstrap config/chroot config/binary config/source +Set_defaults + +# Requiring stage file +Require_stagefile .stage/config .stage/bootstrap + +# Checking stage file +Check_stagefile .stage/chroot_live-packages + +# Checking lock file +Check_lockfile .lock + +# Creating lock file +Create_lockfile .lock + +_PACKAGES="" + +# Queue installation of linux-image and ${LB_INITRAMFS} +if [ "${LB_INITRAMFS}" != "none" ] +then + _PACKAGES="${LB_INITRAMFS}" +fi + +# Queue installation of live-config +if [ "${LB_INITSYSTEM}" != "none" ] +then + _PACKAGES="${_PACKAGES} live-config live-config-${LB_INITSYSTEM}" +fi + +# Do initsystem specific hacks +if [ "${LB_INITSYSTEM}" != "sysvinit" ] +then + # lets see if we still need the squeeze's "pre init system policy discussion" hack: + + IS_SYSVINIT_ESSENTIAL="$(Chroot chroot dpkg-query --show --showformat='${Essential}\n' sysvinit)" + RC="$?" + + if [ "${IS_SYSVINIT_ESSENTIAL}" != "no" ] && [ "${RC}" = "0" ] + then + # sysvinit is both installed and essential, ugly hack to remove it + Chroot chroot dpkg --force-remove-essential --remove sysvinit || true + fi +fi + +# Install live packages +if [ -n "${_PACKAGES}" ] +then + case "${LB_APT}" in + apt|apt-get) + Chroot chroot "apt-get ${APT_OPTIONS} install ${_PACKAGES}" + ;; + + aptitude) + Chroot chroot "aptitude ${APTITUDE_OPTIONS} install ${_PACKAGES}" + ;; + esac + + # Creating stage file + Create_stagefile .stage/chroot_live-packages +fi |