X-Git-Url: https://git.grml.org/?p=grml-debootstrap.git;a=blobdiff_plain;f=chroot-script;h=ea845d142c0c112074d8391d9be4dba9def64944;hp=9a2f8f56542d8572f421e4eaa9a28ddf9db7b05b;hb=687068e816c608239edf287210beb1d73f08efda;hpb=78bb1b7ce80abf38eb8f1d44cfd116680135f1c4 diff --git a/chroot-script b/chroot-script index 9a2f8f5..ea845d1 100644 --- a/chroot-script +++ b/chroot-script @@ -4,7 +4,7 @@ # Authors: grml-team (grml.org), (c) Michael Prokop # Bug-Reports: see http://grml.org/bugs/ # License: This file is licensed under the GPL v2. -# Latest change: Fre Nov 03 22:27:09 CET 2006 [mika] +# Latest change: Fre Nov 03 23:42:36 CET 2006 [mika] ################################################################################ set -e # exit on any error @@ -14,7 +14,7 @@ set -e # exit on any error [ -r /proc/1 ] || mount -t proc none /proc if [ -n "$CHROOTMIRROR" ] ; then - echo "$CHROOTMIRROR" > /etc/apt/sources.list + echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" > /etc/apt/sources.list fi if ! [ -r /etc/kernel-img.conf ] ; then @@ -27,6 +27,12 @@ do_symlinks = Yes EOF fi +# create default devices +if ! [ -r /dev/hda20 ] ; then + echo "Creating generic devices in /dev - this might take a while..." + cd /dev && MAKEDEV generic +fi + # install additional packages if [ "$PACKAGES" = 'yes' ] ; then if ! [ -r /etc/debootstrap/packages ] ; then @@ -34,10 +40,25 @@ if [ "$PACKAGES" = 'yes' ] ; then exit 1 else apt-get update - apt-get --force-yes -y $(cat /etc/debootstrap/packages) + apt-get --force-yes -y install $(cat /etc/debootstrap/packages) fi fi +# sarge specific stuff +if [ "$RELEASE" = 'sarge' ] ; then + sed -i "s#ROOT=probe#ROOT=$TARGET#" /etc/mkinitrd/mkinitrd.conf +fi + +if [ -n "$KERNEL" ] ; then + apt-get update + if [ "$RELEASE" = 'sarge' ] ; then + KERNELPACKAGES="kernel-image-$KERNEL kernel-headers-$KERNEL" + else + KERNELPACKAGES="linux-image-$KERNEL linux-headers-$KERNEL" + fi + apt-get --force-yes -y install $KERNELPACKAGES +fi + if [ -n "$RECONFIGURE" ] ; then for package in $RECONFIGURE ; do dpkg --list $package 1>/dev/null 2>/dev/null && dpkg-reconfigure $package || echo "Warning: $package does not exist, can not reconfigure it." @@ -48,6 +69,7 @@ fi echo "Activating shadow passwords." shadowconfig on echo "Setting password for user root:" +# TODO: typing the wrong password will exit chroot script passwd echo "" @@ -104,18 +126,16 @@ if [ -n "$HOSTNAME" ] ; then echo "$HOSTNAME" > /etc/hostname fi -# create default devices -if ! [ -r /dev/hda20 ] ; then - echo "Creating generic devices in /dev - this might take a while..." - cd /dev && MAKEDEV generic -fi - # assume the first available kernel as our main kernel KERNELIMG=$(ls -1 /boot/vmlinuz-* | head -1) KERNELVER=${KERNELIMG#/boot/vmlinuz-} # generate initrd if [ -n "$INITRD" ] ; then + if [ "$RELEASE" = 'sarge' ] ; then + echo "Release sarge detected, will not create an initrd." + return 0 + fi echo "Generating initrd." update-initramfs -c -t -k $KERNELVER if [ -f "/boot/initrd.img-$KERNELVER" ] ; then @@ -129,7 +149,12 @@ if [ -n "$GROOT" ] ; then # copy stage-files to /boot/grub/ [ -d /boot/grub/ ] || mkdir /boot/grub - cp /usr/lib/grub/i386-pc/* /boot/grub/ + if [ -d /usr/lib/grub/i386-pc/ ] ; then + cp /usr/lib/grub/i386-pc/* /boot/grub/ + else + # sarge ships grub files in another directory + cp /lib/grub/i386-pc/* /boot/grub/ + fi # finally install grub update-grub -y