X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=7a87a48bc4114d63a7774f713ad96abdaf19b158;hp=b6184dc36cb15c31e36f23f5fdc329980cfb10ef;hb=1999b2c915bd5b7df70cffa7777e411d3032d2d5;hpb=320d90c376dccfe1599505e3b485df8d46e34bb3 diff --git a/Releasing b/Releasing index b6184dc3..7a87a48b 100644 --- a/Releasing +++ b/Releasing @@ -1,31 +1,60 @@ These are Bdale's notes on how to do a release. + - make sure build environment is up to date + sudo cowbuilder --update + git checkout master - - update the version in configure.ac - git log > ChangeLog - git commit -a - - make absolutely sure checked-out tree is "clean" + + - update the version in configure.ac if Keith hasn't already + + - make sure the Google Maps API key is in the build chroot and root + (cd ~/altusmetrumllc; git pull) + sudo mkdir -p /var/cache/pbuilder/base.cow/opt/google /opt/google + sudo cp ~/altusmetrumllc/google-maps-api-key \ + /var/cache/pbuilder/base.cow/opt/google/maps-api-key + sudo ln -sf /home/bdale/altusmetrumllc/google-maps-api-key \ + /opt/google/maps-api-key + - if this is an x.y release, then: git checkout -b branch- - git tag -a + - 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 + - cherry-pick or merge appropriate content from master + + - make sure there is a doc/release-notes-.inc + - make sure that doc/altusmetrum-docinfo.xml has the right copyright + year, and add release to the revision history at the front (release + notes will be pulled in automatically) + - make absolutely sure checked-out tree is "clean" + - make absolutely sure the pdclib/ submodule is on the master branch, + up to date, and "clean" + + git log > ChangeLog + git commit -a + git tag -a # full x.y.z version - - edit .git/gbp.conf to use branch- as upstream if needed + - make sure .git/gbp.conf set to use branch- as upstream 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 + gbp dch --release --multimaint-merge --new-version=-1 git commit -n debian/changelog -m "update changelog for Debian build" - git-buildpackage --git-no-pristine-tar - pristine-tar commit ../build-area/altos/altos_.orig.tar.gz + - if this is a -1 release, then + gbp buildpackage --git-no-pristine-tar --git-submodules \ + --git-upstream-branch=branch- \ # eg 1.3 + --git-upstream-tag= # eg 1.3.1 + pristine-tar commit \ + ../build-area/altos_.orig.tar.gz \ + branch- + else if this is not a -1 release + gbp buildpackage --git-submodules + git tag debian/ - at this point we have packages in ~/debian/build-area/altos, now @@ -33,24 +62,57 @@ These are Bdale's notes on how to do a release. make distclean - ./autogen.sh --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases + ./autogen.sh --enable-multi-arch \ + --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases make && make fat this pushes packages for each platform to web site - - copy the relevant release notes file from doc/ to + # store a stable copy of ARM binaries for production use + cp src/easymega-v1.0/*.elf \ + src/easymini-v1.0/*.elf \ + src/telebt-v3.0/*.elf \ + src/teledongle-v3.0/*.elf \ + src/telegps-v1.0/*.elf \ + src/telemega-v1.0/*.elf \ + src/telemega-v2.0/*.elf \ + src/telemetrum-v2.0/*.elf \ + ~/altusmetrumllc/Binaries/ + cp src/easymega-v1.0/flash-loader/*.elf \ + src/easymini-v1.0/flash-loader/*.elf \ + src/telebt-v3.0/flash-loader/*.elf \ + src/teledongle-v3.0/flash-loader/*.elf \ + src/telegps-v1.0/flash-loader/*.elf \ + src/telemega-v1.0/flash-loader/*.elf \ + src/telemega-v2.0/flash-loader/*.elf \ + src/telemetrum-v2.0/flash-loader/*.elf \ + ~/altusmetrumllc/Binaries/loaders/ + (cd ~/altusmetrumllc ; git add Binaries ; git commit -a) + (cd ~/altusmetrumllc ; git push) + + - copy the relevant release notes .html file from doc/ to /home/bdale/web/altusmetrum/AltOS/releases/ - - 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 + (cd ~/web/altusmetrum/AltOS/releases/ ; rm *.tar.bz2) + + - create /home/bdale/web/altusmetrum/MicroPeak/releases/, + and move the MicroPeak installers from AltOS/releases to there + + - create /home/bdale/web/altusmetrum/TeleGPS/releases/, + and move the TeleGPS installers from AltOS/releases to there + + - go edit ~/web/altusmetrum/AltOS/releases/.mdwn, + /home/bdale/web/altusmetrum/MicroPeak/releases/.mdwn, and + /home/bdale/web/altusmetrum/TeleGPS/releases/.mdwn + + - make sure the Windows stuff is like 1-4-1, not 1.4.1! (cd doc ; make publish) this pushes fresh documents to the web site sudo debian/rules clean - git push + git push origin master branch- debian pristine-tar git push --tags push commits and leave the build tree in an uncluttered state