#!/bin/sh -e # Create/destroy temporary chroots case "$1" in --help|-h) printf '\033[1;33m-> \033[m%s\n' "usage: ${0##*/} [pkg...]"; exit 0 esac log() { printf '\033[31;1m->\033[m %s.\n' "$@" ;} die() { rm -f carbs-rootfs.tar.xz carbs-rootfs.tar.xz.sum log "$@" log "Re-run 'kiss-chbuild' to try again." exit 1 } sh256() { # There's no standard utility to generate sha256 checksums. # This is a simple wrapper around sha256sum, sha256, shasum # and openssl which will use whatever is available. # # All utilities must match 'sha256sum' output. # # Example: '<checksum> <file>' [ -e "$1" ] || return 0 hash=$(sha256sum "$1" || sha256 -r "$1" || openssl dgst -sha256 -r "$1" || shasum -a 256 "$1") printf '%s %s\n' "${hash%% *}" "$1" } 2>/dev/null case "$(uname -m)" in i*86) arch=i686; esac url="https://dl.carbslinux.org/releases/${arch:-$(uname -m)}/carbs-rootfs.tar.xz" pid=$$ cd "${cac_dir:=$KISS_ROOT${XDG_CACHE_HOME:-$HOME/.cache}/kiss}" [ -f carbs-rootfs.tar.xz ] || { log "Downloading chroot tarball" curl -fLO "$url" } [ -f carbs-rootfs.tar.xz.sum ] || { log "Downloading checksums" curl -fLo- "${url%/*}/sha256sums.txt" | grep ' carbs-rootfs.tar.xz$' > carbs-rootfs.tar.xz.sum } log "Verifying checksums" sh256 carbs-rootfs.tar.xz | diff - carbs-rootfs.tar.xz.sum || die "Checksum verification failed" [ -d carbs-chroot ] || { log "Extracting chroot" mkdir -p carbs-chroot ( cd carbs-chroot; tar xf ../carbs-rootfs.tar.xz ) } log "Creating temporary chroot" cp -a carbs-chroot "chroot-$pid" [ "$1" ] && { log "Installing extra packages" KISS_ROOT=$PWD/chroot-$pid kiss i "$@" } log "Entering chroot" su -c "kiss-chroot chroot-$pid; rm -rf chroot-$pid"