X-Git-Url: https://git.grml.org/?p=grml-live.git;a=blobdiff_plain;f=grml-live;h=50872acb343dbc3d96142c3b485a6a761b01b4fb;hp=2694a25e37379c65d7b41dd290362f5aa59ef654;hb=1370165b4b9780c2a0a46d72dc12fae343d9f67e;hpb=8e73764ca7533f8250a1611756c13c54c7059da1 diff --git a/grml-live b/grml-live index 2694a25..50872ac 100755 --- a/grml-live +++ b/grml-live @@ -14,7 +14,7 @@ export LC_ALL=C # exit on any error: set -e -GRML_LIVE_VERSION='0.9.4' +GRML_LIVE_VERSION='0.9.6' PN="$(basename $0)" CMDLINE="$0 $@" ISO_DATE="$(date +%Y-%m-%d)" @@ -112,16 +112,15 @@ LIVE_CONF=/etc/grml/grml-live.conf # clean exit {{{ bailout() { - [ -n "$MIRROR_DIRECTORY" ] && umount "${CHROOT_OUTPUT}/${MIRROR_DIRECTORY}" rm -f /var/run/fai/fai_softupdate_is_running \ /var/run/fai/FAI_INSTALLATION_IN_PROGRESS + [ -n "$MIRROR_DIRECTORY" ] && umount "${CHROOT_OUTPUT}/${MIRROR_DIRECTORY}" [ -n "$1" ] && EXIT="$1" || EXIT="1" [ -n "$2" ] && eerror "$2">&2 log "------------------------------------------------------------------------------" exit "$EXIT" } -# trap bailout 1 2 3 6 9 14 15 -trap bailout 1 2 3 15 +trap bailout 1 2 3 3 6 9 14 15 # }}} # check for important variables {{{ @@ -209,7 +208,7 @@ fi # }}} # command line parsing {{{ -while getopts "a:C:c:g:i:o:r:s:t:v:bFhuVz" opt; do +while getopts "a:C:c:g:i:o:r:s:t:v:bFuVz" opt; do case "$opt" in a) ARCH="$OPTARG" ;; b) BUILD_ONLY=1 ;; @@ -227,7 +226,6 @@ while getopts "a:C:c:g:i:o:r:s:t:v:bFhuVz" opt; do t) TEMPLATE_DIRECTORY="$OPTARG";; v) VERSION="$OPTARG" ;; F) FORCE=1 ;; - h) usage ; bailout 0 ;; u) UPDATE=1 ;; V) VERBOSE="-v" ;; z) SQUASHFS_ZLIB="-nolzma" ;; @@ -431,13 +429,6 @@ else # make sure new /etc/grml_version reaches the initramfs: chroot $CHROOT_OUTPUT update-initramfs -u -t eend $? - # get rid of unnecessary files when building grml-small: - if echo "$CLASSES" | grep -q GRML_SMALL ; then - einfo "Removing initrd and vmlinuz files in $CHROOT_OUTPUT/boot" - rm -f "$CHROOT_OUTPUT"/boot/initrd.img-* - rm -f "$CHROOT_OUTPUT"/boot/vmlinuz-* - eend $? - fi fi # Remove all FAI logs from chroot if class RELEASE is used: @@ -445,8 +436,12 @@ else rm -rf "$CHROOT_OUTPUT"/var/log/fai/* fi + # make sure we don't leave any mounts - FAI doesn't remove them always umount $CHROOT_OUTPUT/proc 2>/dev/null || /bin/true umount $CHROOT_OUTPUT/sys 2>/dev/null || /bin/true + umount $CHROOT_OUTPUT/dev/pts 2>/dev/null || /bin/true + umount $CHROOT_OUTPUT/dev 2>/dev/null || /bin/true + [ -n "$MIRROR_DIRECTORY" ] && umount "${CHROOT_OUTPUT}/${MIRROR_DIRECTORY}" # notice: 'fai dirinstall' does not seem to exit appropriate, so: @@ -635,6 +630,16 @@ else fi fi + # support exclusion of files via exclude-file: + if [ -n "$SQUASHFS_EXCLUDES_FILE" -a "$SQUASHFS_EXCLUDES_FILE" ] ; then + SQUASHFS_OPTIONS="$SQUASHFS_OPTIONS -ef $SQUASHFS_EXCLUDES_FILE" + fi + + # get rid of unnecessary files when building grml-small for final release: + if echo "$CLASSES" | grep -q GRML_SMALL ; then + SQUASHFS_OPTIONS="$SQUASHFS_OUTPUT -e initrd.img* vmlinuz*" + fi + SQUASHFS_OUTPUT="$(mktemp -t grml-live.XXXXXX)" log "mksquashfs $CHROOT_OUTPUT/* $BUILD_OUTPUT/live/${GRML_NAME}.squashfs -noappend $SQUASHFS_OPTIONS $SQUASHFS_ZLIB" if mksquashfs $CHROOT_OUTPUT/* $BUILD_OUTPUT/live/"${GRML_NAME}".squashfs \