Commit 44305a2e authored by Connor Kuehl's avatar Connor Kuehl

UBUNTU: [Packaging] update helper scripts

BugLink: http://bugs.launchpad.net/bugs/1786013Signed-off-by: default avatarConnor Kuehl <connor.kuehl@canonical.com>
parent ccb7110c
...@@ -89,12 +89,17 @@ DEBIAN= ...@@ -89,12 +89,17 @@ DEBIAN=
# shellcheck disable=SC1091 # shellcheck disable=SC1091
. debian/debian.env . debian/debian.env
# Check if the "debian.<branch>/" directory exists. # Check if the "$DEBIAN" directory exists.
if [ ! -d "$DEBIAN" ]; then if [ ! -d "$DEBIAN" ]; then
echo "You must run this script from the top directory of this repository." echo "You must run this script from the top directory of this repository."
exit 1 exit 1
fi fi
branch="${DEBIAN#*.}"
CONF="$DEBIAN/etc/update.conf"
if [ -f "$CONF" ]; then
# shellcheck disable=SC1090
. "$CONF"
fi
# Check if changelog is open # Check if changelog is open
series=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SDistribution) series=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SDistribution)
...@@ -111,45 +116,37 @@ if [ "$commit_configs" -eq 0 ] && [ -n "$changes" ]; then ...@@ -111,45 +116,37 @@ if [ "$commit_configs" -eq 0 ] && [ -n "$changes" ]; then
exit 1 exit 1
fi fi
# Derivatives have at least one base kernel. # Derivatives and backports have a master kernel directory (DEBIAN_MASTER).
if [ "$branch" != 'master' ]; then if [ "$DEBIAN" != 'debian.master' ] && [ $skip_master_entries == 0 ]; then
# For backports, insert the changes from the base derivative. if [ "$DEBIAN_MASTER" = "" ]; then
# Straight derivatives and backports such as hwe and hwe-edge, should echo "DEBIAN_MASTER should be defined either in $DEBIAN/etc/update.conf or the environment"
# skip that step and fetch the entries directly from the master kernel. exit 1
version=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SVersion) fi
if [[ $version == *~* ]]; then
if [ -z "${base_version}" ]; then if [ -z "${base_version}" ]; then
base_version=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SVersion -c1 -o1) offset=0
fi # If not provided as an option, loop through each entry of the current changelog,
base_changelog="${DEBIAN%-*}/changelog" # searching for an entry that refers to the master version used as base
if [ -f "$base_changelog" ] && [ "$DEBIAN" != "${DEBIAN%-*}" ]; then # (ie a line containing "[ Ubuntu: 4.15.0-39.42 ]"):
run ./debian/scripts/misc/insert-ubuntu-changes "$DEBIAN/changelog" "${base_version%%~*}" "${version%%~*}" "$base_changelog" while true; do
skip_master_entries=1 changes=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SChanges -c1 -o"$offset")
fi if ! [ "$changes" ]; then
echo "Failed to retrieve base master version from changelog file: $DEBIAN/changelog"
exit 1
fi
base_version=$(echo "$changes" | sed -n -r -e '/^\s.*\[ Ubuntu: ([0-9.-]*) \]$/{s//\1/p;q}')
[ "$base_version" ] && break
offset=$(( offset + 1 ))
done
fi fi
if [ "$skip_master_entries" -eq 0 ]; then master_version=$(dpkg-parsechangelog -l${DEBIAN_MASTER}/changelog -SVersion)
offset=0 if ! [ "$master_version" ]; then
# Loop through each entry of the current changelog, searching for an echo "Failed to retrieve current master version from changelog: $DEBIAN/changelog"
# entry that refers to the master version used as base (ie a line exit 1
# containing "[ Ubuntu: 4.15.0-39.42 ]"):
while true; do
changes=$(dpkg-parsechangelog -l"$DEBIAN/changelog" -SChanges -c1 -o"$offset")
if ! [ "$changes" ]; then
echo "Failed to retrieve base master version from changelog file: $DEBIAN/changelog"
exit 1
fi
base_master_version=$(echo "$changes" | sed -n -r -e '/^\s.*\[ Ubuntu: ([0-9.-]*) \]$/{s//\1/p;q}')
[ "$base_master_version" ] && break
offset=$(( offset + 1 ))
done
master_version=$(dpkg-parsechangelog -ldebian.master/changelog -SVersion)
if ! [ "$master_version" ]; then
echo "Failed to retrieve current master version from changelog: $DEBIAN/changelog"
exit 1
fi
run ./debian/scripts/misc/insert-ubuntu-changes "$DEBIAN/changelog" "$base_master_version" "$master_version"
fi fi
run ./debian/scripts/misc/insert-ubuntu-changes "$DEBIAN/changelog" "$base_version" "$master_version" \
"$DEBIAN_MASTER/changelog"
fi fi
# Insert local changes # Insert local changes
......
...@@ -210,3 +210,5 @@ fi ...@@ -210,3 +210,5 @@ fi
# Mimic maint-startnewrelease # Mimic maint-startnewrelease
[ "$dry_run" -eq 0 ] && \ [ "$dry_run" -eq 0 ] && \
hl "\n***** Now please inspect the commit before pushing *****" hl "\n***** Now please inspect the commit before pushing *****"
exit 0
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment