diff options
author | Daniel Baumann <daniel@debian.org> | 2010-02-05 17:10:44 +0100 |
---|---|---|
committer | Daniel Baumann <daniel@debian.org> | 2011-03-09 19:17:04 +0100 |
commit | 3b80c5c5d9c9d2eec91910b70a120da5943c7fac (patch) | |
tree | 31b5fef2977e7fabe669077041c569169c788a95 /helpers/bootstrap_debootstrap | |
parent | 59e9a93ad08c171fb0d22e965c56f91c5bd17615 (diff) | |
download | vyos-live-build-3b80c5c5d9c9d2eec91910b70a120da5943c7fac.tar.gz vyos-live-build-3b80c5c5d9c9d2eec91910b70a120da5943c7fac.zip |
Dropping lh_ prefix from internal helpers, this is not user visible.
Diffstat (limited to 'helpers/bootstrap_debootstrap')
-rwxr-xr-x | helpers/bootstrap_debootstrap | 161 |
1 files changed, 161 insertions, 0 deletions
diff --git a/helpers/bootstrap_debootstrap b/helpers/bootstrap_debootstrap new file mode 100755 index 000000000..b1a53493e --- /dev/null +++ b/helpers/bootstrap_debootstrap @@ -0,0 +1,161 @@ +#!/bin/sh + +# lh_bootstrap_debootstrap(1) - bootstrap a Debian system with debootstrap(8) +# Copyright (C) 2006-2009 Daniel Baumann <daniel@debian.org> +# +# live-helper 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 +. "${LH_BASE:-/usr/share/live-helper}"/live-helper.sh + +# Setting static variables +DESCRIPTION="$(Echo 'bootstrap a Debian system with debootstrap(8)')" +HELP="" +USAGE="${PROGRAM} [--force]" + +Arguments "${@}" + +# Reading configuration files +Read_conffiles config/all config/common config/bootstrap config/chroot config/binary config/source +Set_defaults + +if [ "${LH_BOOTSTRAP}" != "debootstrap" ] +then + exit 0 +fi + +# Check architecture +Check_crossarchitecture + +Echo_message "Begin bootstrapping system..." + +Check_package /usr/sbin/debootstrap debootstrap + +# Ensure that a system is built as root +lh testroot + +# Checking stage file +Check_stagefile .stage/bootstrap +Check_stagefile .stage/bootstrap_cache.restore + +# Checking lock file +Check_lockfile .lock + +# Creating lock file +Create_lockfile .lock + +# Creating chroot directory +mkdir -p chroot + +# Setting debootstrap options +if [ -n "${LH_ARCHITECTURE}" ] +then + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --arch ${LH_ARCHITECTURE}" +fi + +if [ "${LH_ARCHIVE_AREAS}" != "main" ] +then + # Modify archive areas to remove leading/trailing whitespaces and replace other whitepspace with commas + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --components $(echo ${LH_ARCHIVE_AREAS} | sed -e 's| |,|g')" +fi + +if [ -n "${LH_BOOTSTRAP_CONFIG}" ] +then + if [ -d "/usr/share/debootstrap/scripts/" ] + then + LH_DEBOOTSTRAP_SCRIPT="/usr/share/debootstrap/scripts/${LH_BOOTSTRAP_CONFIG}" + else + LH_DEBOOTSTRAP_SCRIPT="/usr/lib/debootstrap/scripts/${LH_BOOTSTRAP_CONFIG}" + fi +fi + +if [ -n "${LH_BOOTSTRAP_INCLUDE}" ] +then + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --include=$(echo ${LH_BOOTSTRAP_INCLUDE} | sed 's| *|,|g')" +fi + +if [ -n "${LH_BOOTSTRAP_EXCLUDE}" ] +then + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --exclude=$(echo ${LH_BOOTSTRAP_EXCLUDE} | sed 's| *|,|g')" +fi + +if [ "${LH_USE_FAKEROOT}" != "true" ] +then + if [ -z "${LH_BOOTSTRAP_FLAVOUR}" ] + then + if In_list "stripped minimal" "${LH_PACKAGES_LISTS}" + then + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --variant=minbase" + fi + else + case "${LH_BOOTSTRAP_FLAVOUR}" in + stripped|minimal) + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --variant=minbase" + ;; + standard) + ;; + + *) + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --variant=${LH_BOOTSTRAP_FLAVOUR}" + esac + fi +else + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --variant=fakechroot" +fi + +if [ "${_VERBOSE}" = "true" ] +then + DEBOOTSTRAP_OPTIONS="${DEBOOTSTRAP_OPTIONS} --verbose" +fi + +if [ -x "/usr/sbin/debootstrap" ] +then + if [ "${LH_CACHE_PACKAGES}" = "true" ] + then + if [ -d cache/packages_bootstrap ] + then + mkdir -p chroot/var/cache/apt/archives + cp cache/packages_bootstrap/*.deb chroot/var/cache/apt/archives + fi + + Echo_breakage "Running debootstrap (download-only)... " + ${LH_ROOT_COMMAND} debootstrap ${DEBOOTSTRAP_OPTIONS} --download-only "${LH_DISTRIBUTION}" chroot "${LH_MIRROR_BOOTSTRAP}" "${LH_DEBOOTSTRAP_SCRIPT}" + + if [ -n "${LH_ROOT_COMMAND}" ] + then + ${LH_ROOT_COMMAND} chown -R $(whoami):$(whoami) chroot + fi + + # Removing old cache + if [ -d cache/packages_bootstrap ] + then + rm -f cache/packages_bootstrap/*.deb + fi + + # Saving new cache + mkdir -p cache/packages_bootstrap + + cp chroot/var/cache/apt/archives/*.deb cache/packages_bootstrap + fi + + Echo_breakage "Running debootstrap... " + ${LH_ROOT_COMMAND} debootstrap ${DEBOOTSTRAP_OPTIONS} "${LH_DISTRIBUTION}" chroot "${LH_MIRROR_BOOTSTRAP}" "${LH_DEBOOTSTRAP_SCRIPT}" + + if [ -n "${LH_ROOT_COMMAND}" ] + then + ${LH_ROOT_COMMAND} chown -R $(whoami):$(whoami) chroot + fi + + # Removing bootstrap cache + rm -f chroot/var/cache/apt/archives/*.deb + + # Creating stage file + Create_stagefile .stage/bootstrap +else + Echo_error "Can't process file /usr/bin/debootstrap (FIXME)" + exit 1 +fi |