summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xbin/pbuild.sh357
1 files changed, 187 insertions, 170 deletions
diff --git a/bin/pbuild.sh b/bin/pbuild.sh
index 3e0c5ab..4a3559c 100755
--- a/bin/pbuild.sh
+++ b/bin/pbuild.sh
@@ -111,7 +111,7 @@ Parameters "${@}"
if [ -z "${DISTRIBUTION}" ] || [ -z "${PACKAGE}" ]
then
- echo "Usage: ${PROGRAM} [-b|--build BUILD] -d|--distribution DISTRIBUTION -p|--package PACKAGE -t|--tag TAG" >&2
+ echo "Usage: ${PROGRAM} [-b|--build BUILD] -d|--distribution DISTRIBUTION -p|--package PACKAGE -t|--tag TAG[,TAG,...]" >&2
exit 1
fi
@@ -123,6 +123,8 @@ then
exit 1
fi
+TAGS="$(echo ${TAG} | sed -e 's|,| |g')"
+
if [ -z "${BUILD}" ]
then
case "$(dpkg --print-architecture)" in
@@ -152,205 +154,220 @@ case "${MODE}" in
;;
esac
-for BUILD in $(echo ${BUILD} | sed -e 's|,| |g')
+for TAG in ${TAGS} HEAD
do
- echo "################################################################################"
- echo "Building ${BUILD} ($(dpkg --print-architecture)) package: ${PACKAGE} ${VERSION}"
- echo "################################################################################"
+ # if no tag is specified, build head.
+ # if a tag is specified, don't (additionally) build head
+ if [ "${TAG}" = "HEAD" ]
+ then
+ if [ -z "${TAGS}" ]
+ then
+ TAG=""
+ else
+ continue
+ fi
+ fi
- case "${BUILD}" in
- source)
- if [ -n "${TAG}" ]
- then
- GIT_BRANCH="${TAG}"
- git clone --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- else
- GIT_BRANCH="${BRANCH}"
- #git clone --depth 1 --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- git clone --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- fi
+ for BUILD in $(echo ${BUILD} | sed -e 's|,| |g')
+ do
+ echo "################################################################################"
+ echo "Building ${BUILD} ($(dpkg --print-architecture)) package: ${PACKAGE} ${VERSION}"
+ echo "################################################################################"
- cd "${TARGET}"
+ case "${BUILD}" in
+ source)
+ if [ -n "${TAG}" ]
+ then
+ GIT_BRANCH="${TAG}"
+ git clone --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ else
+ GIT_BRANCH="${BRANCH}"
+ #git clone --depth 1 --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ git clone --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ fi
- VERSION="$(dpkg-parsechangelog | awk '/^Version: / { print $2 }')"
+ cd "${TARGET}"
- SOURCE_VERSION="$(echo ${VERSION} | awk -F: '{ print $2 }')"
- SOURCE_VERSION="${SOURCE_VERSION:-${VERSION}}"
+ VERSION="$(dpkg-parsechangelog | awk '/^Version: / { print $2 }')"
- UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F- '{ $NF=""; print $0 }' | sed -e 's| |-|g' -e 's|-$||')"
+ SOURCE_VERSION="$(echo ${VERSION} | awk -F: '{ print $2 }')"
+ SOURCE_VERSION="${SOURCE_VERSION:-${VERSION}}"
- if [ -z "${UPSTREAM_VERSION}" ] && echo "${SOURCE_VERSION}" | grep -qs '+progress[0-9]*'
- then
- UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F\\+progress '{ print $1 }')"
- fi
+ UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F- '{ $NF=""; print $0 }' | sed -e 's| |-|g' -e 's|-$||')"
- if [ -z "${UPSTREAM_VERSION}" ] && echo "${SOURCE_VERSION}" | grep -qs '+bfh[0-9]*'
- then
- UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F\\+bfh '{ print $1 }')"
- fi
+ if [ -z "${UPSTREAM_VERSION}" ] && echo "${SOURCE_VERSION}" | grep -qs '+progress[0-9]*'
+ then
+ UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F\\+progress '{ print $1 }')"
+ fi
- rm -rf .git
- mv debian ../
- cd "${OLDPWD}"
+ if [ -z "${UPSTREAM_VERSION}" ] && echo "${SOURCE_VERSION}" | grep -qs '+bfh[0-9]*'
+ then
+ UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F\\+bfh '{ print $1 }')"
+ fi
- mv "${TARGET}" "${TARGET}-${UPSTREAM_VERSION}"
+ rm -rf .git
+ mv debian ../
+ cd "${OLDPWD}"
- for DISTRIBUTION in engywuck fuchur
- do
- if [ ! -e "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" ]
- then
- wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
- if [ ! -e ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ]
+ mv "${TARGET}" "${TARGET}-${UPSTREAM_VERSION}"
+
+ for DISTRIBUTION in engywuck fuchur
+ do
+ if [ ! -e "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" ]
then
- wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-backports/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
+ wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
if [ ! -e ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ]
then
- wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-extras/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
+ wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-backports/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
if [ ! -e ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ]
then
- wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-backports-extras/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
+ wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-extras/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
+ if [ ! -e ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ]
+ then
+ wget ${SERVER}/archive/$(echo ${DISTRIBUTION} | cut -d- -f 1)-backports-extras/${PACKAGE}/orig/${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz || true
+ fi
fi
fi
fi
+ done
+
+ if [ ! -e "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" ]
+ then
+ echo "Creating ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ..."
+ tar cfJ "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" "${TARGET}-${UPSTREAM_VERSION}"
+ else
+ echo "Using existing ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ..."
fi
- done
-
- if [ ! -e "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" ]
- then
- echo "Creating ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ..."
- tar cfJ "${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz" "${TARGET}-${UPSTREAM_VERSION}"
- else
- echo "Using existing ${TARGET}_${UPSTREAM_VERSION}.orig.tar.xz ..."
- fi
-
- mv debian "${TARGET}-${UPSTREAM_VERSION}"
- dpkg-source -b "${TARGET}-${UPSTREAM_VERSION}"
-
- rm -rf "${TARGET}-${UPSTREAM_VERSION}"
-
- # upload
- case "${UPLOAD}" in
- true)
- FILES="$(sed -e '1,/^Files:$/ d' ${TARGET}_${SOURCE_VERSION}*.dsc | grep -v '^\ \ ' | grep '^\ ' | awk '/^ / { print $3 }')"
-
- for FILE in ${FILES}
- do
- rsync -aP "${FILE}" apt.progress-linux.org::upload
- rm -f "${FILE}"
- done
- ;;
- esac
- ;;
- binary*)
- rm -f /tmp/control
- CONTROL="${REPOSITORY}/plain/debian/control"
- wget -q ${CONTROL} -O /tmp/control
+ mv debian "${TARGET}-${UPSTREAM_VERSION}"
+ dpkg-source -b "${TARGET}-${UPSTREAM_VERSION}"
- case "${BUILD}" in
- binary-arch)
- if ! grep -qs "^Architecture:.* any" /tmp/control && \
- ! grep -qs "^Architecture:.* linux-any" /tmp/control && \
- ! grep -qs "^Architecture:.* $(dpkg --print-architecture)" /tmp/control
- then
- echo "NO BINARY_ARCH, skipping."
- continue
- fi
- ;;
+ rm -rf "${TARGET}-${UPSTREAM_VERSION}"
- binary-indep)
- if ! grep -qs '^Architecture:.*all' /tmp/control
- then
- echo "NO BINARY_INDEP, skipping."
- continue
- fi
- ;;
- esac
+ # upload
+ case "${UPLOAD}" in
+ true)
+ FILES="$(sed -e '1,/^Files:$/ d' ${TARGET}_${SOURCE_VERSION}*.dsc | grep -v '^\ \ ' | grep '^\ ' | awk '/^ / { print $3 }')"
- if [ -n "${TAG}" ]
- then
- GIT_BRANCH="${TAG}"
- git clone --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- else
- GIT_BRANCH="${BRANCH}"
- #git clone --depth 1 --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- git clone --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
- fi
+ for FILE in ${FILES}
+ do
+ rsync -aP "${FILE}" apt.progress-linux.org::upload
+ rm -f "${FILE}"
+ done
+ ;;
+ esac
+ ;;
- cd "${TARGET}"
+ binary*)
+ rm -f /tmp/control
+ CONTROL="${REPOSITORY}/plain/debian/control"
+ wget -q ${CONTROL} -O /tmp/control
- rm -rf .git
+ case "${BUILD}" in
+ binary-arch)
+ if ! grep -qs "^Architecture:.* any" /tmp/control && \
+ ! grep -qs "^Architecture:.* linux-any" /tmp/control && \
+ ! grep -qs "^Architecture:.* $(dpkg --print-architecture)" /tmp/control
+ then
+ echo "NO BINARY_ARCH, skipping."
+ continue
+ fi
+ ;;
- VERSION="$(dpkg-parsechangelog | awk '/^Version: / { print $2 }')"
+ binary-indep)
+ if ! grep -qs '^Architecture:.*all' /tmp/control
+ then
+ echo "NO BINARY_INDEP, skipping."
+ continue
+ fi
+ ;;
+ esac
- SOURCE_VERSION="$(echo ${VERSION} | awk -F: '{ print $2 }')"
- SOURCE_VERSION="${SOURCE_VERSION:-${VERSION}}"
+ if [ -n "${TAG}" ]
+ then
+ GIT_BRANCH="${TAG}"
+ git clone --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ else
+ GIT_BRANCH="${BRANCH}"
+ #git clone --depth 1 --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ git clone --no-single-branch --branch ${GIT_BRANCH} "${REPOSITORY}" "${TARGET}"
+ fi
- UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F- '{ $NF=""; print $0 }' | sed -e 's| |-|g' -e 's|-$||')"
+ cd "${TARGET}"
- SOURCE="${TARGET}-$(echo ${SOURCE_VERSION} | sed -e 's|~|_|g' -e 's|+|.|g')"
+ rm -rf .git
- cd ..
- mv "${TARGET}" "${SOURCE}"
- cd "${SOURCE}"
+ VERSION="$(dpkg-parsechangelog | awk '/^Version: / { print $2 }')"
- # disable tests
- for TARGET in dh_auto_test dh_auto_test-arch dh_auto_test-indep \
- override_dh_auto_test override_dh_auto_test-arch override_dh_auto_test-indep \
- execute_before_dh_auto_test execute_before_dh_auto_test-arch execute_before_dh_auto_test-indep \
- execute_after_dh_auto_test execute_after_dh_auto_test-arch execute_after_dh_auto_test-indep
- do
- if grep -qs "^${TARGET}:" debian/rules
- then
- sed -i -e "s|^${TARGET}:|disabled_${TARGET}:|" debian/rules
- else
- echo "${TARGET}:" >> debian/rules
- fi
- done
-
- case "${AUTO}" in
- true)
- sudo apt build-dep -y .
- ;;
- esac
-
- case "${INTERACTIVE}" in
- true)
- echo "${PROGRAM}: WAITING... "
- read waiting
- ;;
- esac
-
- case "${BUILD}" in
- binary-any)
- dpkg-buildpackage -sa -us -uc
- ;;
-
- binary-arch)
- dpkg-buildpackage -B -us -uc
- ;;
-
- binary-indep)
- dpkg-buildpackage -A -us -uc
- ;;
- esac
-
- cd "${OLDPWD}"
-
- rm -rf "${SOURCE}"
-
- # upload
- case "${UPLOAD}" in
- true)
- FILES="$(sed -e '1,/^Files:$/ d' ${TARGET}_${SOURCE_VERSION}_*.changes | grep -v '^\ \ ' | grep '^\ ' | awk '/^ / { print $5 }')"
-
- for FILE in ${FILES}
- do
- rsync -aP "${FILE}" apt.progress-linux.org::upload
- rm -f "${FILE}"
- done
- ;;
- esac
- ;;
- esac
+ SOURCE_VERSION="$(echo ${VERSION} | awk -F: '{ print $2 }')"
+ SOURCE_VERSION="${SOURCE_VERSION:-${VERSION}}"
+
+ UPSTREAM_VERSION="$(echo ${SOURCE_VERSION} | awk -F- '{ $NF=""; print $0 }' | sed -e 's| |-|g' -e 's|-$||')"
+
+ SOURCE="${TARGET}-$(echo ${SOURCE_VERSION} | sed -e 's|~|_|g' -e 's|+|.|g')"
+
+ cd ..
+ mv "${TARGET}" "${SOURCE}"
+ cd "${SOURCE}"
+
+ # disable tests
+ for TARGET in dh_auto_test dh_auto_test-arch dh_auto_test-indep \
+ override_dh_auto_test override_dh_auto_test-arch override_dh_auto_test-indep \
+ execute_before_dh_auto_test execute_before_dh_auto_test-arch execute_before_dh_auto_test-indep \
+ execute_after_dh_auto_test execute_after_dh_auto_test-arch execute_after_dh_auto_test-indep
+ do
+ if grep -qs "^${TARGET}:" debian/rules
+ then
+ sed -i -e "s|^${TARGET}:|disabled_${TARGET}:|" debian/rules
+ else
+ echo "${TARGET}:" >> debian/rules
+ fi
+ done
+
+ case "${AUTO}" in
+ true)
+ sudo apt build-dep -y .
+ ;;
+ esac
+
+ case "${INTERACTIVE}" in
+ true)
+ echo "${PROGRAM}: WAITING... "
+ read waiting
+ ;;
+ esac
+
+ case "${BUILD}" in
+ binary-any)
+ dpkg-buildpackage -sa -us -uc
+ ;;
+
+ binary-arch)
+ dpkg-buildpackage -B -us -uc
+ ;;
+
+ binary-indep)
+ dpkg-buildpackage -A -us -uc
+ ;;
+ esac
+
+ cd "${OLDPWD}"
+
+ rm -rf "${SOURCE}"
+
+ # upload
+ case "${UPLOAD}" in
+ true)
+ FILES="$(sed -e '1,/^Files:$/ d' ${TARGET}_${SOURCE_VERSION}_*.changes | grep -v '^\ \ ' | grep '^\ ' | awk '/^ / { print $5 }')"
+
+ for FILE in ${FILES}
+ do
+ rsync -aP "${FILE}" apt.progress-linux.org::upload
+ rm -f "${FILE}"
+ done
+ ;;
+ esac
+ ;;
+ esac
+ done
done