manjaro-tools/lib/util-pkg.sh

189 lines
4.4 KiB
Bash
Raw Normal View History

2014-12-08 23:50:56 +01:00
#!/bin/bash
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
2015-06-09 01:14:58 +02:00
check_build(){
[[ ! -f $1/PKGBUILD ]] && die "Directory must contain a PKGBUILD!"
}
2015-06-06 19:27:22 +02:00
check_requirements(){
2015-06-06 23:13:37 +02:00
if ${is_buildset};then
2015-06-09 01:14:58 +02:00
for p in $(cat ${sets_dir_pkg}/${buildset_pkg}.set);do
[[ -z $(find . -type d -name "${p}") ]] && die "${buildset_pkg} is not a valid buildset!"
check_build "$p"
2015-06-06 23:13:37 +02:00
done
else
[[ -z $(find . -type d -name "${buildset_pkg}") ]] && die "${buildset_pkg} is not a valid package!"
2015-06-09 01:14:58 +02:00
check_build "${buildset_pkg}"
2015-06-06 23:13:37 +02:00
fi
2015-06-05 16:43:09 +02:00
}
2015-10-22 12:24:46 +02:00
load_group(){
local _multi \
2015-10-22 20:43:25 +02:00
_space="s| ||g" \
_clean=':a;N;$!ba;s/\n/ /g' \
_com_rm="s|#.*||g" \
devel_packages='' \
2015-10-22 20:43:25 +02:00
file=${PKGDATADIR}/base-devel-udev
2015-10-22 20:43:25 +02:00
msg3 "Loading Group [$file] ..."
if ${is_multilib}; then
_multi="s|>multilib||g"
else
_multi="s|>multilib.*||g"
fi
devel_packages=$(sed "$_com_rm" "$file" \
| sed "$_space" \
| sed "$_multi" \
| sed "$_clean")
echo ${devel_packages}
}
init_base_devel(){
2015-10-22 20:43:25 +02:00
if ${udev_root};then
base_packages=( "$(load_group)" )
else
if ${is_multilib};then
base_packages=('base-devel' 'multilib-devel')
else
base_packages=('base-devel')
fi
fi
}
2014-12-08 23:50:56 +01:00
chroot_create(){
2015-02-13 15:17:00 +01:00
msg "Creating chroot for [${branch}] (${arch})..."
mkdir -p "${work_dir}"
2015-10-22 20:43:25 +02:00
setarch "${arch}" \
mkchroot ${mkchroot_args[*]} \
"${work_dir}/root" \
${base_packages[*]} || abort
2014-12-08 23:50:56 +01:00
}
chroot_clean(){
2015-06-11 21:37:46 +02:00
msg "Creating chroot for [${branch}] (${arch})..."
2015-02-13 15:17:00 +01:00
for copy in "${work_dir}"/*; do
[[ -d ${copy} ]] || continue
msg2 "Deleting chroot copy '$(basename "${copy}")'..."
2014-12-08 23:50:56 +01:00
2015-02-13 15:17:00 +01:00
lock 9 "${copy}.lock" "Locking chroot copy '${copy}'"
2014-12-08 23:50:56 +01:00
2015-02-13 15:17:00 +01:00
if [[ "$(stat -f -c %T "${copy}")" == btrfs ]]; then
{ type -P btrfs && btrfs subvolume delete "${copy}"; } &>/dev/null
fi
rm -rf --one-file-system "${copy}"
done
exec 9>&-
2015-02-13 15:17:00 +01:00
rm -rf --one-file-system "${work_dir}"
2014-12-08 23:50:56 +01:00
}
chroot_update(){
2015-02-13 15:17:00 +01:00
msg "Updating chroot for [${branch}] (${arch})..."
chroot-run ${mkchroot_args[*]} \
2015-02-13 15:17:00 +01:00
"${work_dir}/${OWNER}" \
pacman -Syu --noconfirm || abort
2014-12-08 23:50:56 +01:00
}
clean_up(){
2015-02-13 15:17:00 +01:00
msg "Cleaning up ..."
2015-06-14 20:11:10 +02:00
msg2 "Cleaning [${cache_dir_pkg}]"
2015-02-13 15:17:00 +01:00
find ${cache_dir_pkg} -maxdepth 1 -name "*.*" -delete #&> /dev/null
2015-06-14 20:11:10 +02:00
if [[ -z $SRCDEST ]];then
msg2 "Cleaning [source files]"
find $PWD -maxdepth 1 -name '*.?z?' -delete #&> /dev/null
fi
2014-12-08 23:50:56 +01:00
}
prepare_cachedir(){
2015-02-16 19:07:19 +01:00
prepare_dir "${cache_dir_pkg}"
2015-02-13 15:17:00 +01:00
chown -R "${OWNER}:users" "${cache_dir_pkg}"
2014-12-08 23:50:56 +01:00
}
2015-05-07 22:41:56 +02:00
sign_pkg(){
su ${OWNER} -c "signpkg ${cache_dir_pkg}/$1"
}
run_post_build(){
2015-05-07 23:10:13 +02:00
local _arch=${arch}
2015-05-07 22:41:56 +02:00
source PKGBUILD
local ext='pkg.tar.xz' pinfo loglist=() lname
if [[ ${arch} == "any" ]]; then
pinfo=${pkgver}-${pkgrel}-any
else
2015-05-07 23:10:13 +02:00
pinfo=${pkgver}-${pkgrel}-${_arch}
2015-05-07 22:41:56 +02:00
fi
2015-02-13 15:17:00 +01:00
if [[ -n $PKGDEST ]];then
2015-05-07 22:41:56 +02:00
if [[ -n ${pkgbase} ]];then
2015-02-13 15:17:00 +01:00
for p in ${pkgname[@]};do
2015-05-07 22:41:56 +02:00
mv $PKGDEST/${p}-${pinfo}.${ext} ${cache_dir_pkg}/
${sign} && sign_pkg ${p}-${pinfo}.${ext}
loglist+=("*$p*.log")
lname=${pkgbase}
2015-02-13 15:17:00 +01:00
done
else
2015-05-07 22:41:56 +02:00
mv $PKGDEST/${pkgname}-${pinfo}.${ext} ${cache_dir_pkg}/
${sign} && sign_pkg ${pkgname}-${pinfo}.${ext}
loglist+=("*${pkgname}*.log")
lname=${pkgname}
2015-02-13 15:17:00 +01:00
fi
else
mv *.${ext} ${cache_dir_pkg}
2015-05-07 22:41:56 +02:00
${sign} && sign_pkg ${pkgname}-${pinfo}.${ext}
loglist+=("*${pkgname}*.log")
lname=${pkgname}
2015-02-13 15:17:00 +01:00
fi
chown -R "${OWNER}:users" "${cache_dir_pkg}"
2015-05-07 22:41:56 +02:00
if [[ -z $LOGDEST ]];then
tar -cjf ${lname}-${pinfo}.log.tar.xz ${loglist[@]}
find $PWD -maxdepth 1 -name '*.log' -delete #&> /dev/null
2015-02-13 15:17:00 +01:00
fi
2015-05-07 23:10:13 +02:00
arch=$_arch
}
make_pkg(){
msg "Start building [$1]"
cd $1
setarch "${arch}" \
mkchrootpkg ${mkchrootpkg_args[*]} -- ${makepkg_args[*]} || eval "$2"
2015-05-07 22:41:56 +02:00
run_post_build
cd ..
2015-02-20 11:57:04 +01:00
msg "Finished building [$1]"
msg3 "Time ${FUNCNAME}: $(elapsed_time ${timer_start}) minutes"
}
2014-12-08 23:50:56 +01:00
chroot_build(){
2015-02-13 15:17:00 +01:00
if ${is_buildset};then
local list=$(read_set ${sets_dir_pkg}/${buildset_pkg}.set)
for pkg in ${list[@]}; do
make_pkg "$pkg" "break"
2015-02-13 15:17:00 +01:00
done
else
2015-02-16 21:25:23 +01:00
make_pkg "${buildset_pkg}" "abort"
2015-02-13 15:17:00 +01:00
fi
2014-12-08 23:50:56 +01:00
}
chroot_init(){
2015-02-23 19:33:11 +01:00
local timer=$(get_timer)
2015-02-13 15:17:00 +01:00
if ${clean_first}; then
chroot_clean
chroot_create
elif [[ ! -d "${work_dir}" ]]; then
chroot_create
else
chroot_update
fi
2015-02-23 19:33:11 +01:00
msg3 "Time ${FUNCNAME}: $(elapsed_time ${timer}) minutes"
2014-12-08 23:50:56 +01:00
}