+Adding a product to the release
+
+ Make sure the firmware and loader get built by default in
+ src/Makefile
+
+ Add the firmware to altosui/Makefile.am
+
+ Add the firmware to altosui/altos-windows.nsi.in
+
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-<version>
- git tag -a <version>
+
- if this is an x.y.z release, then:
git checkout branch-<version> # the x.y parts only
- git merge master
- git tag -a <version> # full x.y.z version
+ - cherry-pick or merge appropriate content from master
+
+ - make sure there is a doc/release-notes-<version>.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"
- - edit .git/gbp.conf to use branch-<version> as upstream if needed
+ git log > ChangeLog
+ git commit -a
+ git tag -a <version> # full x.y.z version
+
+ - make sure .git/gbp.conf set to use branch-<version> as upstream
git checkout debian
git merge branch-<version>
- verify debian/changelog is "clean" ending in last release version
- craft a suitable debian/changelog entry, possibly using:
- git-dch --release --new-version=<version>-1 --multimaint-merge
+ gbp dch --release --multimaint-merge --new-version=<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_<version>.orig.tar.gz
+ - if this is a -1 release, then
+ gbp buildpackage --git-no-pristine-tar --git-submodules \
+ --git-upstream-branch=branch-<version> \ # eg 1.3
+ --git-upstream-tag=<version> # eg 1.3.1
+ pristine-tar commit \
+ ../build-area/altos_<version>.orig.tar.gz \
+ branch-<version>
+ else if this is not a -1 release
+ gbp buildpackage --git-submodules
+
git tag debian/<version>
- at this point we have packages in ~/debian/build-area/altos, now
make distclean
- ./autogen.sh --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases
- make fat
+ ./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/chaoskey-v1.0/{*.elf,*.ihx} \
+ src/easymega-v1.0/{*.elf,*.ihx} \
+ src/easymini-v1.0/{*.elf,*.ihx} \
+ src/easymini-v2.0/{*.elf,*.ihx} \
+ src/telebt-v3.0/{*.elf,*.ihx} \
+ src/teledongle-v3.0/{*.elf,*.ihx} \
+ src/telegps-v1.0/{*.elf,*.ihx} \
+ src/telemega-v1.0/{*.elf,*.ihx} \
+ src/telemega-v2.0/{*.elf,*.ihx} \
+ src/telemetrum-v2.0/{*.elf,*.ihx} \
+ src/telemini-v3.0/{*.elf,*.ihx} \
+ ~/altusmetrumllc/Binaries/
+ cp src/chaoskey-v1.0/flash-loader/{*.elf,*.bin} \
+ src/easymega-v1.0/flash-loader/*.elf \
+ src/easymini-v1.0/flash-loader/*.elf \
+ src/easymini-v2.0/flash-loader/{*.elf,*.bin} \
+ 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 \
+ src/telemini-v3.0/flash-loader/{*.elf,*.bin} \
+ ~/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/<rev>
- - go edit ~/web/altusmetrum/AltOS/releases/<rev>.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/<rev> ; rm *.tar.bz2)
+
+ - create /home/bdale/web/altusmetrum/MicroPeak/releases/<rev>,
+ and move the MicroPeak installers from AltOS/releases to there
+
+ - create /home/bdale/web/altusmetrum/TeleGPS/releases/<rev>,
+ and move the TeleGPS installers from AltOS/releases to there
+
+ - go edit ~/web/altusmetrum/AltOS/releases/<rev>.mdwn,
+ /home/bdale/web/altusmetrum/MicroPeak/releases/<rev>.mdwn, and
+ /home/bdale/web/altusmetrum/TeleGPS/releases/<rev>.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-<version> debian pristine-tar
git push --tags
push commits and leave the build tree in an uncluttered state