X-Git-Url: https://git.grml.org/?p=grml-debootstrap.git;a=blobdiff_plain;f=chroot-script;h=7fa771b45d2df38251857a710562c15f293765a7;hp=3b2ec68fff43a433b3401d2b433aa1da39c50524;hb=3e5f8f2863a824e35b3c70d5ec1b0edb24ee8647;hpb=bded4f66efbe14fc18367131b79465d540c77634;ds=sidebyside diff --git a/chroot-script b/chroot-script index 3b2ec68..7fa771b 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 23:30:04 CET 2006 [mika] +# Latest change: Mon Nov 06 11:52:24 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 "deb $CHROOTMIRROR $RELEASE main contrib non-free" /etc/apt/sources.list + echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" > /etc/apt/sources.list fi if ! [ -r /etc/kernel-img.conf ] ; then @@ -46,7 +46,7 @@ fi # sarge specific stuff if [ "$RELEASE" = 'sarge' ] ; then - sed -i "s/ROOT=probe/ROOT=$TARGET" /etc/mkinitrd/mkinitrd.conf + sed -i "s#ROOT=probe#ROOT=$TARGET#" /etc/mkinitrd/mkinitrd.conf fi if [ -n "$KERNEL" ] ; then @@ -69,8 +69,10 @@ fi echo "Activating shadow passwords." shadowconfig on echo "Setting password for user root:" +set +e # do not exit if passwd returns error due to missmatching passwords passwd echo "" +set -e # restore default behaviour again if ! [ -f /etc/hosts ] ; then echo "Setting up /etc/hosts" @@ -131,11 +133,15 @@ KERNELVER=${KERNELIMG#/boot/vmlinuz-} # generate initrd if [ -n "$INITRD" ] ; then - echo "Generating initrd." - update-initramfs -c -t -k $KERNELVER - if [ -f "/boot/initrd.img-$KERNELVER" ] ; then - GRUBINITRD="initrd /boot/initrd.img-$KERNELVER" - LILOINITRD=" initrd=/boot/initrd.img-$KERNELVER" + if [ "$RELEASE" = 'sarge' ] ; then + echo "Release sarge detected, will not create an initrd." + else + echo "Generating initrd." + update-initramfs -c -t -k $KERNELVER + if [ -f "/boot/initrd.img-$KERNELVER" ] ; then + GRUBINITRD="initrd /boot/initrd.img-$KERNELVER" + LILOINITRD=" initrd=/boot/initrd.img-$KERNELVER" + fi fi fi @@ -144,11 +150,16 @@ 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 - sed -i "s/groot=.*/groot=(${GROOT})/g" /boot/grub/menu.lst + sed -i "s/^# groot=.*/# groot=(${GROOT})/g" /boot/grub/menu.lst # not sure why savedefault does not work for me; any ideas? sed -i "s/^savedefault.*/# &/g" /boot/grub/menu.lst update-grub -y @@ -163,7 +174,9 @@ if [ -n "$GROOT" ] ; then fi # make sure we don't have any running processes left -[ -x /etc/init.d/ssh ] && /etc/init.d/ssh stop +for service in ssh mdadm mdadm-raid ; do + [ -x "/etc/init.d/$service" ] && "/etc/init.d/$service" stop +done # unmount all filesystems in chroot, make sure nothing is left... umount -a 1>/dev/null 2>/dev/null || true