-# unmount all filesystems in chroot, make sure nothing is left...
-umount -a 1>/dev/null 2>/dev/null || true
-umount /proc 1>/dev/null 2>/dev/null || true
-umount /proc 1>/dev/null 2>/dev/null || true
-umount -a 1>/dev/null 2>/dev/null || true
+ # finally install grub
+ if [ -x /usr/sbin/update-grub ] ; then
+ UPDATEGRUB='/usr/sbin/update-grub'
+ else
+ UPDATEGRUB='/sbin/update-grub'
+ fi
+
+ # grub2:
+ $UPDATEGRUB
+ fi
+}
+# }}}
+
+# execute all scripts present in /etc/debootstrap/chroot-scripts/ {{{
+custom_scripts() {
+ [ -d /etc/debootstrap/chroot-scripts/ ] || return 0
+
+ for script in /etc/debootstrap/chroot-scripts/* ; do
+ echo "Executing script $script"
+ $script && echo "done" || echo "failed"
+ done
+}
+# }}}
+
+# make sure we don't have any running processes left {{{
+services() {
+ for service in ssh mdadm mdadm-raid ; do
+ if [ -x /etc/init.d/"$service" ] ; then
+ /etc/init.d/"$service" stop || /bin/true
+ fi
+ done
+}
+# }}}
+
+# unmount all filesystems in chroot, make sure nothing is left {{{
+finalize() {
+ # make sure we don't leave any sensible data
+ rm -f /etc/debootstrap/variables
+ [ -n "$POLICYRCD" ] && rm -f /usr/sbin/policy-rc.d
+ umount -a 1>/dev/null 2>/dev/null || true
+ umount /proc 1>/dev/null 2>/dev/null || true
+ umount /proc 1>/dev/null 2>/dev/null || true
+ umount -a 1>/dev/null 2>/dev/null || true
+}
+# }}}
+
+# execute the functions {{{
+ for i in chrootmirror grmlrepos kernelimg_conf makedev install_policy_rcd \
+ kernel packages extrapackages reconfigure hosts interfaces \
+ timezone fstab hostname initrd grub_config passwords custom_scripts \
+ services ; do
+ if stage $i ; then
+ $i && stage $i done || exit 1
+ fi
+ done
+ # always execute the finalize stage:
+ finalize
+# }}}