Skip to content
archbuild 1.18 KiB
Newer Older
base_packages='base base-devel sudo'

cmd="$(basename "${0%-build}")"
if [ "${cmd%-*}" == 'multilib' ]; then
Jan Steffens's avatar
Jan Steffens committed
	repo="${cmd}"
	arch='x86_64'
	base_packages+=' multilib-devel'
else
	repo=${cmd%-*}
chroots='/var/tmp/archbuild'
clean_first=false

usage() {
	echo "usage $(basename "$0")"
	echo '    -c         Recreate the chroot before building'
	echo '    -r <dir>   Create chroots in this directory'
	exit 1
}

while getopts 'cr:' arg; do
	case "${arg}" in
		c) clean_first=true ;;
		r) chroots="$OPTARG" ;;
		*) usage ;;
	esac
done

Jan Steffens's avatar
Jan Steffens committed
if [ "$EUID" != '0' ]; then
	echo 'This script must be run as root.'
	exit 1
fi

if ${clean_first} || [ ! -d "${chroots}/${repo}-${arch}" ]; then
	echo "Creating chroot for [${repo}] (${arch})..."
Jan Steffens's avatar
Jan Steffens committed
	rm -rf ${chroots}/${repo}-${arch}
	mkdir -p ${chroots}/${repo}-${arch}
	setarch ${arch} mkarchroot \
		-C /usr/share/devtools/pacman-${repo}.conf \
		-M /usr/share/devtools/makepkg-${arch}.conf \
		${chroots}/${repo}-${arch}/root \
Jan Steffens's avatar
Jan Steffens committed
	setarch ${arch} mkarchroot \
		-u \
		${chroots}/${repo}-${arch}/root
fi

echo "Building in chroot for [${repo}] (${arch})..."
Jan Steffens's avatar
Jan Steffens committed
setarch ${arch} makechrootpkg -c -r ${chroots}/${repo}-${arch}