2011-01-25 03:01:05 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
abuild_ver=@VERSION@
|
|
|
|
sysconfdir=@sysconfdir@
|
|
|
|
abuildrepo=/var/lib/buildlab/result
|
|
|
|
datadir=@datadir@
|
|
|
|
|
|
|
|
BUILD_BASE="build-base"
|
|
|
|
SUDO=${SUDO:-"sudo"}
|
|
|
|
FAKEROOT=${FAKEROOT:-"fakeroot"}
|
|
|
|
APK=${APK:-apk}
|
|
|
|
|
2011-01-25 03:06:04 +00:00
|
|
|
# read config
|
|
|
|
ABUILD_CONF=${ABUILD_CONF:-"$sysconfdir/abuild.conf"}
|
|
|
|
[ -f "$ABUILD_CONF" ] && . "$ABUILD_CONF"
|
|
|
|
|
2011-01-25 03:01:05 +00:00
|
|
|
default_colors() {
|
|
|
|
NORMAL="\033[1;0m"
|
|
|
|
STRONG="\033[1;1m"
|
|
|
|
RED="\033[1;31m"
|
|
|
|
GREEN="\033[1;32m"
|
|
|
|
YELLOW="\033[1;33m"
|
|
|
|
BLUE="\033[1;34m"
|
|
|
|
}
|
|
|
|
|
|
|
|
default_colors
|
|
|
|
|
|
|
|
is_local() {
|
|
|
|
case "$1" in
|
|
|
|
http://*|ftp://*|https://*|saveas-*://*)
|
|
|
|
return 1;;
|
|
|
|
esac
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
msg() {
|
|
|
|
local prompt="$GREEN>>>${NORMAL}"
|
|
|
|
[ -z "$quiet" ] && printf "${prompt} $@\n" >&2
|
|
|
|
}
|
|
|
|
|
|
|
|
error() {
|
|
|
|
local prompt="$RED>>>${NORMAL}"
|
|
|
|
printf "${prompt} $@\n" >&2
|
|
|
|
}
|
|
|
|
|
|
|
|
die() {
|
|
|
|
error "$@"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
runpart() {
|
|
|
|
local part=$1
|
|
|
|
msg "Running part $part"
|
|
|
|
$part || die "$part failed"
|
|
|
|
}
|
|
|
|
|
2011-09-30 06:42:58 +00:00
|
|
|
is_vserver() {
|
|
|
|
egrep -q '^VxID:[[:space:]]*[0-9]+' /proc/self/status
|
|
|
|
}
|
|
|
|
|
|
|
|
do_chroot_open() {
|
|
|
|
local path="$1"
|
|
|
|
if is_vserver; then
|
|
|
|
# vserver does not allow us mount or create devices
|
|
|
|
# but we can create hard links as long as chroot is
|
|
|
|
# on same filesystem as real root
|
|
|
|
rmdir "$path"/proc "$path"/sys "$path"/dev 2>/dev/null
|
|
|
|
ln /dev "$path"/dev
|
|
|
|
ln /proc "$path"/proc
|
|
|
|
ln /sys "$path"/sys
|
|
|
|
|
|
|
|
else
|
|
|
|
mkdir -p "$path"/dev "$path"/proc "$path"/sys
|
|
|
|
mount -o bind /dev "$path"/dev || return 1
|
|
|
|
mount -o bind /proc "$path"/proc
|
|
|
|
mount -o bind /sys "$path"/sys
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
do_chroot_close() {
|
|
|
|
local path="$1"
|
|
|
|
if is_vserver; then
|
|
|
|
rmdir "$path"/dev "$path"/proc "$path"/sys
|
|
|
|
else
|
|
|
|
umount "$path"/dev "$path"/proc "$path"/sys
|
|
|
|
fi
|
|
|
|
}
|
2011-06-22 14:51:41 +00:00
|
|
|
|
2011-01-25 03:01:05 +00:00
|
|
|
do_chroot_action() {
|
|
|
|
local path="$1"
|
|
|
|
local command="$2"
|
|
|
|
|
|
|
|
msg "Doing chroot action '$command' in '$path'..."
|
|
|
|
|
2011-09-30 06:42:58 +00:00
|
|
|
do_chroot_open "$path" || return 1
|
2011-01-25 03:01:05 +00:00
|
|
|
shift;
|
|
|
|
|
|
|
|
# XXX: we have to do this because busybox clobbers us, bleah.
|
|
|
|
echo $* > "$path"/.chroot-action.sh
|
|
|
|
chroot "$path" /bin/sh /.chroot-action.sh
|
|
|
|
rm "$path"/.chroot-action.sh
|
|
|
|
|
2011-09-30 06:42:58 +00:00
|
|
|
do_chroot_close
|
2011-01-25 03:01:05 +00:00
|
|
|
}
|
|
|
|
|
2011-01-25 03:06:04 +00:00
|
|
|
update_chroot() {
|
|
|
|
local path="$1"
|
|
|
|
|
|
|
|
apk --root $path --repositories "$path"/etc/apk/repositories update
|
|
|
|
apk --root $path --repositories "$path"/etc/apk/repositories upgrade -a
|
|
|
|
}
|
|
|
|
|
2011-01-25 03:01:05 +00:00
|
|
|
prepare_chroot() {
|
|
|
|
local path="$1"
|
|
|
|
local version="$2"
|
|
|
|
local mirror="$3"
|
|
|
|
local arch="$4"
|
2011-03-30 02:46:37 +00:00
|
|
|
local enablecache="$5"
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Setting up repositories for mirror $mirror with version $version at $path..."
|
|
|
|
|
|
|
|
mkdir -p "$path"/etc/apk
|
2011-06-22 15:12:43 +00:00
|
|
|
echo "http://$mirror/alpine/$version/main" >> "$path"/etc/apk/repositories
|
|
|
|
echo "http://$mirror/alpine/$version/testing" >> "$path"/etc/apk/repositories
|
2011-01-25 03:01:05 +00:00
|
|
|
|
2011-03-30 02:46:37 +00:00
|
|
|
if [ ! -z "$enablecache" ]; then
|
|
|
|
mkdir -p "$path"/var/cache/apk
|
|
|
|
ln -s /var/cache/apk "$path"/etc/apk/cache
|
|
|
|
fi
|
|
|
|
|
2011-06-22 15:12:43 +00:00
|
|
|
echo "alpine-base" > "$path"/etc/apk/world
|
|
|
|
mkdir -p "$path"/lib/apk/db
|
|
|
|
mkdir -p "$path"/var/lock
|
|
|
|
mkdir -p "$path"/var/cache/apk
|
|
|
|
mkdir -p "$path"/tmp
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
mkdir -p "$path"/etc
|
|
|
|
cp /etc/resolv.conf "$path"/etc/resolv.conf
|
|
|
|
|
|
|
|
msg "Updating package lists..."
|
|
|
|
|
2011-06-22 15:12:43 +00:00
|
|
|
apk --arch $buildarch --root $path --repositories "$path"/etc/apk/repositories update
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Installing alpine-base..."
|
|
|
|
|
2011-06-22 15:12:43 +00:00
|
|
|
apk --arch $buildarch --root $path --repositories "$path"/etc/apk/repositories add --initdb alpine-base
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Installing abuild..."
|
|
|
|
|
2011-06-22 15:12:43 +00:00
|
|
|
apk --arch $buildarch --root $path --repositories "$path"/etc/apk/repositories add --initdb abuild
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Installing build-base..."
|
|
|
|
|
2011-06-22 15:12:43 +00:00
|
|
|
apk --arch $buildarch --root $path --repositories "$path"/etc/apk/repositories add --initdb build-base
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Adding abuild user..."
|
|
|
|
|
|
|
|
do_chroot_action "$path" adduser -D -G abuild abuild
|
|
|
|
echo "abuild ALL=NOPASSWD: ALL" >> "$path"/etc/sudoers
|
2011-06-22 15:12:43 +00:00
|
|
|
chmod 440 "$path"/etc/sudoers
|
2011-01-25 03:01:05 +00:00
|
|
|
|
|
|
|
msg "Generating buildlab signing keys..."
|
|
|
|
do_chroot_action "$path" su abuild -c "'abuild-keygen -ai'"
|
|
|
|
|
|
|
|
msg "Setting up repository symlink..."
|
|
|
|
mkdir -p "$path"/home/abuild/.cache/apks
|
|
|
|
do_chroot_action "$path" chown abuild:abuild /home/abuild/${src}
|
|
|
|
do_chroot_action "$path" ln -sf .cache/apks /home/abuild/repo
|
|
|
|
|
|
|
|
msg "Build chroot is ready!"
|
|
|
|
}
|
|
|
|
|
|
|
|
build_package() {
|
|
|
|
local path="$1"
|
|
|
|
local apkbuild="$2"
|
|
|
|
srcdir="$(dirname $apkbuild)"
|
|
|
|
|
|
|
|
msg "Parsing $apkbuild..."
|
|
|
|
. "$apkbuild"
|
|
|
|
|
|
|
|
msg "Copying local sources..."
|
|
|
|
|
|
|
|
mkdir -p "$path"/home/abuild/src
|
|
|
|
chmod 666 "$path"/home/abuild/src
|
|
|
|
|
|
|
|
for src in $source $install; do
|
|
|
|
is_local $src || continue
|
|
|
|
|
|
|
|
msg "${srcdir}/${src} -> ${path}/home/abuild/src/${src} ..."
|
|
|
|
cp ${srcdir}/${src} "${path}"/home/abuild/${src}
|
|
|
|
do_chroot_action "$path" chown abuild:abuild /home/abuild/${src}
|
|
|
|
done
|
|
|
|
|
2011-06-22 14:50:43 +00:00
|
|
|
for i in $triggers; do
|
2011-06-27 21:05:01 +00:00
|
|
|
src=${i%=*}
|
2011-06-22 14:50:43 +00:00
|
|
|
is_local $src || continue
|
|
|
|
|
|
|
|
msg "${srcdir}/${src} -> ${path}/home/abuild/src/${src} ..."
|
|
|
|
cp ${srcdir}/${src} "${path}"/home/abuild/${src}
|
|
|
|
do_chroot_action "$path" chown abuild:abuild /home/abuild/${src}
|
|
|
|
done
|
|
|
|
|
2011-01-25 03:01:05 +00:00
|
|
|
cp $apkbuild "$path"/home/abuild
|
|
|
|
do_chroot_action "$path" chown abuild:abuild /home/abuild/$(basename $apkbuild)
|
|
|
|
|
|
|
|
msg "Invoking abuild..."
|
|
|
|
do_chroot_action "$path" su abuild -c "'cd /home/abuild; abuild -r'"
|
|
|
|
|
|
|
|
msg "Copying back results to ${abuildrepo}..."
|
|
|
|
mkdir -p ${abuildrepo}
|
|
|
|
for papk in "${path}"/home/abuild/*.apk; do
|
|
|
|
apk=$(basename $papk)
|
|
|
|
msg "$papk -> ${abuildrepo}/${apk}"
|
|
|
|
cp $papk ${abuildrepo}/${apk}
|
|
|
|
done
|
|
|
|
|
|
|
|
msg "Cleaning up..."
|
|
|
|
rm -rf "$path"/home/abuild/src
|
|
|
|
rm -rf "$path"/home/abuild/pkg
|
|
|
|
rm -f "$path"/home/abuild/APKBUILD
|
|
|
|
}
|
|
|
|
|
|
|
|
usage() {
|
|
|
|
echo "buildlab $abuild_ver"
|
|
|
|
echo " "
|
|
|
|
echo "Common options:"
|
|
|
|
echo " "
|
|
|
|
echo " -q Quiet operation"
|
|
|
|
echo " -p Path to buildroot"
|
|
|
|
echo " "
|
|
|
|
echo "Creating build roots (buildlab -C):"
|
|
|
|
echo " "
|
|
|
|
echo " -m APK repository mirror"
|
|
|
|
echo " -v APK distribution version"
|
|
|
|
echo " -a APK repository architecture"
|
2011-03-30 02:46:37 +00:00
|
|
|
echo " -k Enable APK caching"
|
2011-01-25 03:01:05 +00:00
|
|
|
echo " "
|
|
|
|
echo "Updating build roots (buildlab -u):"
|
|
|
|
echo " "
|
|
|
|
echo " No special options."
|
|
|
|
echo " "
|
|
|
|
echo "Building packages (buildlab -b):"
|
|
|
|
echo " "
|
|
|
|
echo " -b APKBUILD file"
|
|
|
|
echo " "
|
|
|
|
echo "Examples:"
|
|
|
|
echo " "
|
|
|
|
echo "sudo ./buildlab -C -p /home/nenolod/buildroot -m dl-3.alpinelinux.org -v edge -a x86_64"
|
|
|
|
echo "sudo ./buildlab -b /home/nenolod/aports/main/gnome-panel/APKBUILD -p /home/nenolod/buildroot"
|
2011-01-25 03:06:04 +00:00
|
|
|
echo "sudo ./buildlab -u -p /home/nenolod/buildroot"
|
2011-01-25 03:01:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
unset force
|
|
|
|
unset recursive
|
2011-03-30 02:46:37 +00:00
|
|
|
while getopts "chqCkp:v:m:a:b:u" opt; do
|
2011-01-25 03:01:05 +00:00
|
|
|
case $opt in
|
|
|
|
'c') default_colors
|
|
|
|
color_opt="-c";;
|
|
|
|
'h') usage;;
|
|
|
|
'q') quiet="-q";;
|
|
|
|
'C') create="-c";;
|
|
|
|
'p') buildpath="$OPTARG";;
|
|
|
|
'm') buildmirror="$OPTARG";;
|
|
|
|
'v') buildver="$OPTARG";;
|
2011-03-30 02:46:37 +00:00
|
|
|
'a') buildarch="$OPTARG";;
|
|
|
|
'k') enablecache=1;;
|
2011-01-25 03:01:05 +00:00
|
|
|
'b') buildpkg="$OPTARG";;
|
2011-01-25 03:06:04 +00:00
|
|
|
'u') update="-u";;
|
2011-01-25 03:01:05 +00:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
shift $(( $OPTIND - 1 ))
|
|
|
|
|
|
|
|
if [ ! -z "$create" ]; then
|
|
|
|
msg "Creating new chroot at $buildpath..."
|
2011-03-30 02:46:37 +00:00
|
|
|
prepare_chroot $buildpath $buildver $buildmirror $buildarch $enablecache
|
2011-01-25 03:01:05 +00:00
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -z "$buildpkg" ]; then
|
|
|
|
msg "Building APKBUILD $buildpkg in chroot $buildpath..."
|
|
|
|
build_package $buildpath $buildpkg
|
|
|
|
exit 0
|
|
|
|
fi
|
2011-01-25 03:06:04 +00:00
|
|
|
|
|
|
|
if [ ! -z "$update" ]; then
|
|
|
|
msg "Updating chroot at $buildpath..."
|
|
|
|
update_chroot $buildpath
|
|
|
|
exit 0
|
|
|
|
fi
|