X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=613635ce4f1dc76c83e5baae9eda0c19e50ac9dd;hp=8af50a1e7b385637261c86a40baf3d010284698c;hb=eaf2ee0f498b519d64e1664a2b8c66c52ac1497c;hpb=28a2db68e4806383cfaa7075d454c35cade9633a diff --git a/Releasing b/Releasing index 8af50a1e..613635ce 100644 --- a/Releasing +++ b/Releasing @@ -3,6 +3,8 @@ Adding a product to the release Make sure the firmware and loader get built by default in src/Makefile + Add firmware targets to fat_altos target in Makefile.am + Add the firmware to altosui/Makefile.am Add the firmware to altosui/altos-windows.nsi.in @@ -17,33 +19,36 @@ These are Keith's notes on how to do a release - update the version and date in configure.ac if Bdale hasn't already + - follow instructions in doc/RELNOTES + - make sure there is a doc/release-notes-.inc - make sure doc/release-notes.inc points at that - make sure doc/Makefile points at that too - - 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 by release-notes.inc) - These are Bdale's notes on how to do a release. - - make sure build environment is up to date + - make sure Debian build environment is up to date sudo cowbuilder --update + - make sure fat build environment is up to date + sudo apt update && sudo apt upgrade + + - ensure i386 build support is available, and we have tools to build + installers for Windows and Mac OS X + + sudo dpkg --add-architecture i386 + sudo apt update + sudo apt install gcc-multilib genisoimage nsis + (need some mingw packages too, but not sure which offhand) + + - make sure ~/web/altusmetrum has no pending pullable commits + git checkout master - 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- @@ -52,12 +57,9 @@ These are Bdale's notes on how to do a release. - 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 sure that doc/*.txt have the right copyright year and the + new release is included - 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 @@ -75,21 +77,21 @@ These are Bdale's notes on how to do a release. git commit -n debian/changelog -m "update changelog for Debian build" - if this is a -1 release, then - gbp buildpackage --git-no-pristine-tar --git-submodules \ + gbp buildpackage --git-no-pristine-tar \ --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 + gbp buildpackage 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 + make distclean (just to be sure, this should do nothing) ./autogen.sh --enable-multi-arch \ --with-fat-dir=/home/bdale/web/altusmetrum/ @@ -97,8 +99,9 @@ These are Bdale's notes on how to do a release. - store a stable copy of ARM binaries for production use - cp src/chaoskey-v1.0/{*.elf,*.ihx} \ + cp src/chaoskey-v1.0/{*.elf,*.ihx,*.bin} \ src/easymega-v1.0/{*.elf,*.ihx} \ + src/easymega-v2.0/{*.elf,*.ihx} \ src/easymini-v1.0/{*.elf,*.ihx} \ src/easymini-v2.0/{*.elf,*.ihx} \ src/telebt-v3.0/{*.elf,*.ihx} \ @@ -108,24 +111,34 @@ These are Bdale's notes on how to do a release. src/telegps-v2.0/{*.elf,*.ihx} \ src/telemega-v1.0/{*.elf,*.ihx} \ src/telemega-v2.0/{*.elf,*.ihx} \ + src/telemega-v3.0/{*.elf,*.ihx} \ src/telemetrum-v2.0/{*.elf,*.ihx} \ src/telemini-v3.0/{*.elf,*.ihx} \ + src/telelco-v2.0/{*.elf,*.ihx} \ + src/telefireeight-v1.0/{*.elf,*.ihx} \ + src/telefireeight-v2.0/{*.elf,*.ihx} \ ~/altusmetrumllc/Binaries/ cp src/chaoskey-v1.0/flash-loader/{*.elf,*.bin} \ src/easymega-v1.0/flash-loader/*.elf \ + src/easymega-v2.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/telebt-v4.0/flash-loader/{*.elf,*.bin} \ src/teledongle-v3.0/flash-loader/*.elf \ src/telegps-v1.0/flash-loader/*.elf \ - src/telegps-v2.0/flash-loader/*.elf \ + src/telegps-v2.0/flash-loader/{*.elf,*.bin} \ src/telemega-v1.0/flash-loader/*.elf \ src/telemega-v2.0/flash-loader/*.elf \ + src/telemega-v3.0/flash-loader/*.elf \ src/telemetrum-v2.0/flash-loader/*.elf \ src/telemini-v3.0/flash-loader/{*.elf,*.bin} \ + src/telelco-v2.0/flash-loader/*.elf \ + src/telefireeight-v1.0/flash-loader/*.elf \ + src/telefireeight-v2.0/flash-loader/*.elf \ ~/altusmetrumllc/Binaries/loaders/ (cd ~/altusmetrumllc ; git add Binaries ; git commit -a) + - remove previous versions (only keep latest release) (cd ~/altusmetrumllc ; git push) - Push new release to web site