diff --git a/RELEASE-NOTES-next b/RELEASE-NOTES-next new file mode 100644 index 000000000..e896b54e7 --- /dev/null +++ b/RELEASE-NOTES-next @@ -0,0 +1,21 @@ + + ┌──────────────────────────────┐ + │ Release notes for i3 v4.20 │ + └──────────────────────────────┘ + +This is i3 v4.19. This version is considered stable. All users of i3 are +strongly encouraged to upgrade. + + + ┌────────────────────────────┐ + │ Changes in i3 v4.20 │ + └────────────────────────────┘ + + • placeholder + + ┌────────────────────────────┐ + │ Bugfixes │ + └────────────────────────────┘ + + • placeholder + diff --git a/release.sh b/release.sh index c6b045c0a..4477ebfe2 100755 --- a/release.sh +++ b/release.sh @@ -1,8 +1,10 @@ #!/bin/zsh # This script is used to prepare a new release of i3. +set -eu + export RELEASE_VERSION="4.19" -export PREVIOUS_VERSION="4.18" +export PREVIOUS_VERSION="4.18.3" export RELEASE_BRANCH="next" if [ ! -e "../i3.github.io" ] @@ -24,12 +26,6 @@ then exit 1 fi -if git diff-files --quiet --exit-code debian/changelog -then - echo "Expected debian/changelog to be changed (containing the changelog for ${RELEASE_VERSION})." - exit 1 -fi - eval $(gpg-agent --daemon) export GPG_AGENT_INFO @@ -52,28 +48,32 @@ if [ ! -e "${STARTDIR}/RELEASE-NOTES-${RELEASE_VERSION}" ]; then exit 1 fi git checkout -b release-${RELEASE_VERSION} +git rm RELEASE-NOTES-* cp "${STARTDIR}/RELEASE-NOTES-${RELEASE_VERSION}" "RELEASE-NOTES-${RELEASE_VERSION}" git add RELEASE-NOTES-${RELEASE_VERSION} -git rm RELEASE-NOTES-${PREVIOUS_VERSION} -sed -i "s/^\s*version: '${PREVIOUS_VERSION}'/ version: '${RELEASE_VERSION}'/" meson.build +# Update the release version: +sed -i "s/^\s*version: '4.[^']*'/ version: '${RELEASE_VERSION}'/" meson.build +cp meson.build "${TMPDIR}/meson.build" +# Inject the release date into meson.build for the dist tarball: +sed -i "s/'-non-git'/' ($(date +'%Y-%m-%d'))'/" meson.build git commit -a -m "release i3 ${RELEASE_VERSION}" git tag "${RELEASE_VERSION}" -m "release i3 ${RELEASE_VERSION}" --sign --local-user=0x4AC8EE1D mkdir build (cd build && meson .. && ninja dist) -cp build/meson-build/i3-${RELEASE_VERSION}.tar.xz . +cp build/meson-dist/i3-${RELEASE_VERSION}.tar.xz . echo "Differences in the release tarball file lists:" diff --color -u \ - <(tar tf ../i3-${PREVIOUS_VERSION}.tar.xz | sed "s,i3-${PREVIOUS_VERSION}/,,g" | sort) \ - <(tar tf i3-${RELEASE_VERSION}.tar.xz | sed "s,i3-${RELEASE_VERSION}/,,g" | sort) + <(tar tf ../i3-${PREVIOUS_VERSION}.tar.* | sed "s,i3-${PREVIOUS_VERSION}/,,g" | sort) \ + <(tar tf i3-${RELEASE_VERSION}.tar.xz | sed "s,i3-${RELEASE_VERSION}/,,g" | sort) || true gpg --armor -b i3-${RELEASE_VERSION}.tar.xz -echo "${RELEASE_VERSION}-non-git" > I3_VERSION -git add I3_VERSION -git commit -a -m "Set non-git version to ${RELEASE_VERSION}-non-git." +mv "${TMPDIR}/meson.build" . +git add meson.build +git commit -a -m "Restore non-git version suffix" if [ "${RELEASE_BRANCH}" = "stable" ]; then git checkout stable @@ -94,17 +94,12 @@ git config --add remote.origin.push "+refs/heads/next:refs/heads/next" git config --add remote.origin.push "+refs/heads/stable:refs/heads/stable" ################################################################################ -# Section 2: Debian packaging +# Section 2: Debian packaging (for QA) ################################################################################ cd "${TMPDIR}" mkdir debian -# Copy over the changelog because we expect it to be locally modified in the -# start directory. -cp "${STARTDIR}/debian/changelog" i3/debian/changelog -(cd i3 && git add debian/changelog && git commit -m 'Update debian/changelog') - cat > ${TMPDIR}/Dockerfile <