summaryrefslogtreecommitdiff
path: root/librestage
diff options
context:
space:
mode:
authorNicolas Reynolds <fauno@kiwwwi.com.ar>2011-07-04 12:20:10 -0300
committerNicolas Reynolds <fauno@kiwwwi.com.ar>2011-07-04 12:20:10 -0300
commit7aa8921c81306d8bbd8d29d351a6e263ae1a5761 (patch)
tree676859ee5c678b615106e1d99833b595c186f294 /librestage
parent7171852c0e7564f75506f5018f81d71ed96d9363 (diff)
parent37013de11c60a9bbdb58bdc871d0c4b4fc899af3 (diff)
Merge branch 'master' of ssh://vparabola/srv/git/projects/libretoolsv20110708
Diffstat (limited to 'librestage')
-rwxr-xr-xlibrestage45
1 files changed, 38 insertions, 7 deletions
diff --git a/librestage b/librestage
index d1784ab..e851dd4 100755
--- a/librestage
+++ b/librestage
@@ -72,7 +72,7 @@ SRCPKGDEST=${SRCPKGDEST:-.}
PKGEXT=".pkg.tar.?z"
-staged='n'
+staged=false
# Copies the packages to the specified repos inside staging
for _arch in ${ARCHES[@]}; do
for pkg in ${pkgname[@]}; do
@@ -85,36 +85,67 @@ for _arch in ${ARCHES[@]}; do
pkgfile=$(basename ${pkgpath})
+ if [ ! -z "${SIGID}" ]; then
+ sigpath=${pkgpath}${SIGEXT}
+ sigfile=${pkgfile}${SIGEXT}
+
+ msg "Signing package with ID ${SIGID}"
+ gpg --default-key "${SIGID}" --output ${sigpath} --detach-sig ${pkgpath} || {
+ error "Couldn't sign ${pkgfile}, aborting..."
+ exit 1
+ }
+ fi
+
if [ -e "${pkgpath}" ]; then
msg "Found ${pkgfile}"
canonical=""
for _repo in ${repos[@]}; do
- [[ -z "$canonical" ]] && {
+ if [ -z "$canonical" ]; then
canonical="${WORKDIR}/staging/${_repo}/${pkgfile}"
+
cp "${pkgpath}" "${WORKDIR}/staging/${_repo}/" || {
error "Can't put ${pkgfile} on [staging]"
exit 1
} && {
msg2 "${pkg} staged on [${_repo}]"
- staged='y'
+ staged=true
}
- } || {
+
+ if [ ! -z "${SIGID}" ]; then
+ canonical_sig="${WORKDIR}/staging/${_repo}/${pkgfile}${SIGEXT}"
+ cp "${sigpath}" "${WORKDIR}/staging/${_repo}/" || {
+ error "Can't put ${sigfile} on [staging]"
+ exit 1
+ } && {
+ msg2 "${pkg} signature on [${_repo}]"
+ }
+ fi
+ else
ln "${canonical}" "${WORKDIR}/staging/${_repo}/${pkgfile}" || {
error "Can't put ${pkgfile} on [staging]"
exit 1
} && {
msg2 "${pkg} staged on [${_repo}]"
- staged='y'
+ staged=true
}
- }
+
+ if [ ! -z "${SIGID}" ]; then
+ ln "${canonical_sig}" "${WORKDIR}/staging/${_repo}/${sigfile}" || {
+ error "Can't put ${sigfile} on [staging]"
+ exit 1
+ } && {
+ msg2 "${pkg} signature on [${_repo}]"
+ }
+ fi
+ fi
done
fi
done
done
-if [ $staged = 'n' ]; then
+if ! $staged ; then
error "No package was staged"
exit 1
fi