X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=8627d864da6e107e0f8a8a68a8fff99385182491;hp=edfb5eb470f69c11f66fcb93a523ea383206a586;hb=ac12e77e3dffc9e9ddb1578a38b32783ad64e940;hpb=3cea033ec928c21b9f7b810898ed3c3cc536d2ce diff --git a/Releasing b/Releasing index edfb5eb4..8627d864 100644 --- a/Releasing +++ b/Releasing @@ -1,34 +1,80 @@ These are Bdale's notes on how to do a release. - update the version in configure.ac and commit + git checkout master - git tag -a + - make sure there is a doc/release-notes-.xsl + - make sure that doc/altusmetrum.xsl has the right copyright year, + and add release to the revision history at the front (release notes + will be pulled in automatically) - git-buildpackage --git-ignore-new + - update the version in configure.ac + git log > ChangeLog + git commit -a - use --git-ignore-new so trash in checked-out tree doesn't - cause the build to fail! + - make absolutely sure checked-out tree is "clean" + - make absolutely sure the pdclib/ submodule is on the master branch, + up to date, and "clean" - at this point, we have Debian packages + - if this is an x.y release, then: + git checkout -b branch- + git tag -a + - edit .git/gbp.conf to use branch- as upstream + + - if this is an x.y.z release, then: + git checkout branch- # the x.y parts only + git merge master + git tag -a # full x.y.z version + + git checkout debian + git merge branch- + + - verify debian/changelog is "clean" ending in last release version + - craft a suitable debian/changelog entry, possibly using: + git-dch --release --new-version=-1 --multimaint-merge + + git commit -n debian/changelog -m "update changelog for Debian build" + + - if this is a -1 release, then + git-buildpackage --git-no-pristine-tar --git-submodules \ + --git-upstream-branch=branch- + pristine-tar commit \ + ../build-area/altos_.orig.tar.gz \ + branch- + else if this is not a -1 release + git-buildpackage --git-submodules + + git tag debian/ + + - at this point we have packages in ~/debian/build-area/altos, now + we move on to the non-Debian part of the release process make distclean ./autogen.sh --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases - make fat + make && make fat this pushes packages for each platform to web site - - go edit ~/web/altusmetrum/AltOS/releases/.mdwn to include - release date and explicit ref to dir contents so the AltOS page - shows versioned links, commit and push + - copy the relevant release notes file from doc/ to + /home/bdale/web/altusmetrum/AltOS/releases/ + + - create /home/bdale/web/altusmetrum/MicroPeak/releases/, + and move the MicroPeak installers from AltOS/releases to there + + - go edit ~/web/altusmetrum/AltOS/releases/.mdwn and + /home/bdale/web/altusmetrum/MicroPeak/releases/.mdwn, to + include release date and explicit ref to dir contents so the + web pages shows versioned links, commit and push (cd doc ; make publish) this pushes fresh documents to the web site sudo debian/rules clean + git push origin master branch- debian + git push --tags - leave the build tree in an unclutterd state + push commits and leave the build tree in an uncluttered state Testing before a release