]> git.puffer.fish Git - matthieu/frr.git/commitdiff
Revert "debian: Update the tools/build-debian-package.sh to be example build script"
authorQuentin Young <qlyoung@nvidia.com>
Thu, 19 Nov 2020 22:12:27 +0000 (17:12 -0500)
committerQuentin Young <qlyoung@nvidia.com>
Thu, 19 Nov 2020 22:12:27 +0000 (17:12 -0500)
This reverts commit c950a7f214cd713652da1b6b78eca9278c33b448.

debian/gbp.conf
tools/build-debian-package.sh

index 23917b9b8f610cea808769f23796b9cd430d7eac..990c4d226e03628d57f887118de8a51d16e4ab1b 100644 (file)
@@ -1,4 +1,4 @@
 [DEFAULT]
 pristine-tar = False
 debian-branch = master
-upstream-tree = SLOPPY
+upstream-tree=SLOPPY
index b8ac7e1ffcf7e4381c020734b4e235f0c794ea23..6791325e75723858f87e40a0a223f7e2b746a5eb 100755 (executable)
 # This file is public domain
 set -e
 
-BASEDIR="$(realpath -e "$(dirname "$(dirname "$0")")")"
-cd "$BASEDIR"
-
-#
-# Directory where the git-buildpackage does the work
-#
-WORKDIR=$(mktemp -d /tmp/debwork-XXXXXXXX) || exit 1
-trap '( rm -rf "$WORKDIR" )' EXIT
-
-#
-# Checking requirements
-#
+cd "$(dirname "$(dirname "$0")")"
 
 if [ "$(id -u)" = 0 ]; then
        echo "Running as root - installing dependencies"
-       apt-get install fakeroot debhelper devscripts git-buildpackage lsb-release
+       apt-get install fakeroot debhelper devscripts git-buildpackage
        mk-build-deps --install debian/control
        exit 0
 fi
 
 git diff-index --quiet HEAD || { echo "ERROR: git working directory is not clean!" ; exit 1; }
 
-#
-# We switch to a separate branch to not mangle the actual branch, this is
-# not needed in the CI
-#
-
-CLONEDIR="$WORKDIR/$(basename "$BASEDIR")"
-
-echo "Creating shallow clone from $BASEDIR to $CLONEDIR..."
+HEAD_COMMIT=$(git rev-parse --short HEAD)
+HEAD_BRANCH=$(git rev-parse --abbrev-ref HEAD)
+BUILD_BRANCH="debian/$HEAD_BRANCH-$(date +%s)"
 
-git clone --depth=2 "file://$BASEDIR" "$CLONEDIR"
-cd "$CLONEDIR"
+echo "Switching to a '$BUILD_BRANCH' build branch"
 
-####################################
-# Build the Debian package sources #
-####################################
-
-#
-# Now we will construct an "upstream" version out of:
-# 1. version in AC_INIT
-# 2. the unix time from the last commit (HEAD)
-#    (alternatively %Y%m%d%H%M%S could be used here)
-# 4. Debian version (always -1)
-#
+git checkout -b "$BUILD_BRANCH" "$HEAD_BRANCH"
 
 UPSTREAM_VERSION=$(sed -ne 's/AC_INIT(\[frr\],\s\[\([^]]*\)\],.*/\1/p' configure.ac | sed -e 's/-\(\(dev\|alpha\|beta\)\d*\)/~\1/')
-LAST_TIMESTAMP=$(git log --format=format:%ad --date=format:%s -1 "HEAD")
-DEBIAN_VERSION="$UPSTREAM_VERSION-$LAST_TIMESTAMP-1"
+LAST_TIMESTAMP=$(git log --format=format:%ad --date=format:%Y%m%d -1 "$HEAD_COMMIT")
+SINCE_COMMIT=$(git log --since="00:00:00" --format=format:%H | tail -1)
+DEBIAN_VERSION="$UPSTREAM_VERSION-$LAST_TIMESTAMP-git.$HEAD_COMMIT-1"
 
-#
-# We add a Debian changelog entry, and use artifical "since commit"
-# so there's not a whole git history in the debian/changelog.
-#
-# The --snapshot option appends ~1.<shorthash> to the debian version, so for the
-# release build, this needs to be replaces with --release
-#
-
-echo "Adding new snapshot debian/changelog entry for $DEBIAN_VERSION..."
+echo "Adding new snapshot debian/changelog entry for $DEBIAN_VERSION"
 
 gbp dch \
-    --ignore-branch \
+    --debian-branch="$BUILD_BRANCH" \
     --new-version "$DEBIAN_VERSION" \
-    --dch-opt="--force-bad-version" \
-    --since="HEAD~" \
+    --since="$SINCE_COMMIT~" \
     --snapshot \
     --commit
 
-echo "Building package..."
-
-#
-# git-buildpackage will use $BUILDER command to just build new source package
-#
-
-BUILDER="dpkg-buildpackage -uc -us --build=source --no-check-builddeps --no-pre-clean -sa"
-UPSTREAM_COMPRESSION=xz
+echo "Building package"
 
 gbp buildpackage \
-    --git-export-dir="$WORKDIR" \
-    --git-builder="$BUILDER" \
-    --git-ignore-branch \
+    --git-builder=debuild \
+    --git-debian-branch="$BUILD_BRANCH" \
     --git-force-create \
-    --git-compression=$UPSTREAM_COMPRESSION \
     --git-no-pristine-tar
 
-DEB_SOURCE="$(dpkg-parsechangelog -SSource)"
-DEB_VERSION="$(dpkg-parsechangelog -SVersion)"
-DEB_VERSION_UPSTREAM_REVISION="$(echo "${DEB_VERSION}" | sed -e 's/^[0-9]*://')"
-DEB_VERSION_UPSTREAM="$(echo "${DEB_VERSION_UPSTREAM_REVISION}" | sed -e 's/-[^-]*$//')"
-
-#
-# Now the source package has been built and it is stored in following files:
-#
-
-echo "Running lintian on the source package"
-
-lintian "${WORKDIR}/${DEB_SOURCE}_${DEB_VERSION_UPSTREAM_REVISION}_source.changes"
-
-####################
-# Backporting part #
-####################
+echo "Switching back to '$HEAD_BRANCH' branch"
 
-#
-# Now we determine what should be the suffix for the system we are backporting
-# for.
-#
+git checkout "$HEAD_BRANCH"
 
-DIST=$(lsb_release --codename --short)
-PATCH=${PATCH:-1}
-
-case "$DIST" in
-    jessie)  EXTRA_VERSION="deb8u${PATCH}" ;;
-    stretch) EXTRA_VERSION="deb9u${PATCH}" ;;
-    buster)  EXTRA_VERSION="deb10u${PATCH}" ;;
-    sid)     EXTRA_VERSION="sid+${PATCH}" ;;
-    xenial)  EXTRA_VERSION="ubuntu16.04+${PATCH}" ;;
-    bionic)  EXTRA_VERSION="ubuntu16.04+${PATCH}" ;;
-    focal)   EXTRA_VERSION="ubuntu20.04+${PATCH}" ;;
-    groovy)  EXTRA_VERSION="ubuntu20.10+${PATCH}" ;;
-    *) echo "Unknown distribution '$DIST'" ; exit 1 ;;
-esac
-
-#
-# Now the actual backport, we:
-#
-# 1. Unpack the sources
-# 2. Append the EXTRA_VERSION
-# 3. Use debuild to build the package (don't sign
-#
-
-(cd "$WORKDIR" && dpkg-source -x "${DEB_SOURCE}_${DEB_VERSION_UPSTREAM_REVISION}.dsc")
-(cd "$WORKDIR/${DEB_SOURCE}-${DEB_VERSION_UPSTREAM}/" && dch -b -m -t -l "~$EXTRA_VERSION" "No change backport build for $DIST")
-(cd "$WORKDIR/${DEB_SOURCE}-${DEB_VERSION_UPSTREAM}/" && debuild -uc -us)
-
-#
-# Copy back the result
-#
+echo "Deleting the '$BUILD_BRANCH' build branch"
 
-cp -a "$WORKDIR"/*.build "$WORKDIR"/*.buildinfo "$WORKDIR"/*.changes "$WORKDIR"/*.dsc "$WORKDIR"/*.deb "$WORKDIR"/*.debian.* "$WORKDIR"/*.orig.tar.* "${BASEDIR}/"
+git branch -D "$BUILD_BRANCH"