From 41260b2bb817765667a4d816d56306574f5ca691 Mon Sep 17 00:00:00 2001 From: Michael Prokop Date: Tue, 5 Jun 2007 13:39:40 +0200 Subject: [PATCH] Support option -i/--iso: now it is possible to install packages from a normal Debian ISO --- chroot-script | 9 +++++++-- debian/changelog | 2 ++ grml-debootstrap | 29 ++++++++++++++++++++++++++--- 3 files changed, 35 insertions(+), 5 deletions(-) mode change 100644 => 100755 chroot-script diff --git a/chroot-script b/chroot-script old mode 100644 new mode 100755 index caafeaf..3cd2196 --- a/chroot-script +++ b/chroot-script @@ -45,8 +45,13 @@ stage() { # define chroot mirror {{{ chrootmirror() { - if [ -n "$CHROOTMIRROR" ] ; then - echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" > /etc/apt/sources.list + if [ -n "$ISO" ] ; then + echo "deb $ISO $RELEASE main contrib" > /etc/apt/sources.list + [ -n "$CHROOTMIRROR" ] && echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" >> /etc/apt/sources.list + else + if [ -n "$CHROOTMIRROR" ] ; then + echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" > /etc/apt/sources.list + fi fi } # }}} diff --git a/debian/changelog b/debian/changelog index 9158d62..cf20c81 100644 --- a/debian/changelog +++ b/debian/changelog @@ -2,6 +2,8 @@ grml-debootstrap (0.10) unstable; urgency=low * Add console-common to /etc/debootstrap/packages. Thanks for the feature request, Thorsten Strusch! + * Support option -i/--iso: now it's possible to install packages + from a normal Debian ISO. -- Michael Prokop Mon, 04 Jun 2007 10:13:32 +0200 diff --git a/grml-debootstrap b/grml-debootstrap index 277c3ac..de15471 100755 --- a/grml-debootstrap +++ b/grml-debootstrap @@ -10,7 +10,7 @@ set -e # exit on any error -VERSION='0.7' +VERSION='0.9' # source core functions {{{ . /etc/grml/lsb-functions @@ -47,6 +47,7 @@ usage() { -t|--target Target partition (/dev/...) or directory. -r|--release Specify release of new Debian system. Supported relases: sarge, etch, lenny and sid. -m|--mirror Specify mirror which should be used for apt-get/aptitude. + -i|--iso Specify mountpoint where Debian ISO is mounted to (instead of using mirror) -p|--mntpoint Specify mountpoint that should be used for mounting the target system. --groot Specify root device for usage in grub (corresponds with \$TARGET). --grub Where do you want to install grub to? Use grub syntax for specifying. @@ -93,6 +94,11 @@ while [ "$#" -gt "0" ] ; do MIRROR=$1 CHROOTMIRROR=$1 ;; + -i|--iso) + shift + [ -n "$MIRROR"] && unset MIRROR + ISO=$1 + ;; -h|--help) usage ; eend 0 eend 0 @@ -154,6 +160,15 @@ else ARCHINFO=" (${ARCH})" fi +# make sure we have the right syntax when using an iso image +case $ISO in + file*) # do nothing + ; + *) + ISO=file:$1 + ;; +esac + # provide variables to chroot system touch /etc/debootstrap/variables chmod 600 /etc/debootstrap/variables # make sure nobody except root can read it @@ -161,6 +176,7 @@ chmod 600 /etc/debootstrap/variables # make sure nobody except root can read it [ -n "$GRUB" ] && echo "GRUB=$GRUB" >> /etc/debootstrap/variables [ -n "$GROOT" ] && echo "GROOT=$GROOT" >> /etc/debootstrap/variables [ -n "$TARGET" ] && echo "TARGET=$TARGET" >> /etc/debootstrap/variables +[ -n "$ISO" ] && echo "ISO=$ISO" >> /etc/debootstrap/variables [ -n "$MIRROR" ] && echo "MIRROR=$MIRROR" >> /etc/debootstrap/variables [ -n "$MIRROR" ] && echo "CHROOTMIRROR=$MIRROR" >> /etc/debootstrap/variables [ -n "$ROOTPASSWORD" ] && echo "ROOTPASSWORD=$ROOTPASSWORD" >> /etc/debootstrap/variables @@ -186,6 +202,7 @@ bailout(){ [ -x "$MNTPOINT"/bin/umount ] && chroot "$MNTPOINT" umount -a 1>/dev/null 2>&1 [ -x "$MNTPOINT"/bin/umount ] && chroot "$MNTPOINT" umount /proc 1>/dev/null 2>&1 [ -x "$MNTPOINT"/bin/umount ] && chroot "$MNTPOINT" umount /proc 1>/dev/null 2>&1 + [ -d "$TARGET/$ISO" ] && umount "$TARGET/$ISO" einfo "Unmounting $MNTPOINT" ; umount "$MNTPOINT" ; eend $? fi fi @@ -232,6 +249,7 @@ else # if not running automatic installation display configuration and prompt fo case "$MNTPOINT" in "$TARGET") ;; *) echo " Mount-point: $MNTPOINT" ;; esac [ -n "$GRUB" ] && echo " Install grub to: $GROOT / $GRUB" [ -n "$MIRROR" ] && echo " Using mirror: $MIRROR" + [ -n "$ISO" ] && echo " Using iso: $ISO" case "$MNTPOINT" in "$TARGET") ;; *) echo " Important! Continuing will delete all data from ${TARGET}!" ;; esac echo einfon "Is this ok for you? [y/N] " @@ -278,6 +296,10 @@ mount_target() { eend $? fi fi + if [ -n "$ISO" ] ; then + mkdir "$TARGET/$ISO" + mount --bind "$ISO" "$TARGET/$ISO" + fi } # }}} @@ -287,8 +309,9 @@ debootstrap_system() { mount_target fi if grep -q $MNTPOINT /proc/mounts ; then - einfo "Running $DEBOOTSTRAP for release ${RELEASE}${ARCHINFO} using mirror $MIRROR" - $DEBOOTSTRAP $ARCHCMD $RELEASE $MNTPOINT $MIRROR + einfo "Running $DEBOOTSTRAP for release ${RELEASE}${ARCHINFO} using ${MIRROR}${ISO}" + [ -n "$MIRROR" ] && $DEBOOTSTRAP $ARCHCMD $RELEASE $MNTPOINT $MIRROR || \ + $DEBOOTSTRAP $ARCHCMD $RELEASE $MNTPOINT $ISO eend $? else eerror "Error: $MNTPOINT not mounted, can not continue." -- 2.1.4