X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=408b180519aa19a986629d7fe236eb7f82b75165;hp=8c1787ee35574380e2268499b243eb6562720a1c;hb=d2ec815a17e9327414bab7ea09ed483c4f47f460;hpb=d1065424d144b8dab949db7e57140ffdf244bd48 diff --git a/Releasing b/Releasing index 8c1787ee..408b1805 100644 --- a/Releasing +++ b/Releasing @@ -1,112 +1,161 @@ +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 + + Add the firmware to telegps/Makefile.am + + Add the firmware to telegps/telegps-windows.nsi.in + + Add the firmware to Releasing + +These are Keith's notes on how to do a release + + - update the version and date in configure.ac if Bdale hasn't already + + - update the ANDROID_VERSION in configure.ac if releasing AltosDroid + + - 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 + + - confirm doc/header.inc has correct copyright year + + These are Bdale's notes on how to do a release. - git checkout master + - make sure Debian build environment is up to date + sudo cowbuilder --update - - make sure the Google Maps API key is in the build chroot and root - mkdir -p /var/cache/pbuilder/base.cow/opt/google /opt/google - cp ~/altusmetrumllc/google-maps-api-key \ - /var/cache/pbuilder/base.cow/opt/google/maps-api-key - ln -sf /home/bdale/altusmetrumllc/google-maps-api-key \ - /opt/google/maps-api-key - - - 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) - - - get a Google Maps API key and install it in - ~/altusmetrumllc/google-maps-api-key. If you don't have a - key, the app will still work, but downloading map tiles will - be slow, and you will only be able to download a limited - number per day. - - - update the version in configure.ac - git log > ChangeLog - git commit -a + - make sure fat build environment is up to date + sudo apt update && sudo apt upgrade - - make absolutely sure checked-out tree is "clean" - - make absolutely sure the pdclib/ submodule is on the master branch, - up to date, and "clean" + - ensure i386 build support is available, and we have tools to build + installers for Windows and Mac OS X + + sudo apt update + sudo apt install genisoimage nsis \ + gcc-i686-linux-gnu gcc-aarch64-linux-gnu \ + gcc-arm-linux-gnueabi gcc-arm-linux-gnueabihf + + - make sure ~/web/altusmetrum has no pending pullable commits + + git checkout master + + - update the version in configure.ac if Keith hasn't already - 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 + - cherry-pick or merge appropriate content from master + + - make sure there is a doc/release-notes-.inc + - make sure that doc/*.txt have the right copyright year and the + new release is included + - confirm doc/header.inc has correct copyright year + - make absolutely sure checked-out tree is "clean" + - make absolutely sure any commits Keith might have pushed to branches + like debian are already pulled + + git log > ChangeLog + git commit -a + git tag -a # full x.y.z version + + - 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" - if this is a -1 release, then - git-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 - git-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 --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases + ./autogen.sh --enable-multi-arch \ + --with-fat-dir=/home/bdale/web/altusmetrum/ make && make fat - this pushes packages for each platform to web site - - # store a stable copy of ARM binaries for production use - cp src/easymini-v1.0/*.elf \ - src/telegps-v1.0/*.elf \ - src/telemega-v1.0/*.elf \ - src/telemetrum-v2.0/*.elf \ + - store a stable copy of ARM binaries for production use + + cp src/chaoskey-v1.0/{*.elf,*.ihx,*.bin,*.map} \ + src/easymega-v[1-2].0/{*.elf,*.ihx,*.map} \ + src/easymini-v[1-2].0/{*.elf,*.ihx,*.map} \ + src/easymotor-v2/{*.elf,*.ihx,*.map} \ + src/easytimer-v1/{*.elf,*.ihx,*.map} \ + src/telebt-v[3-4].0/{*.elf,*.ihx,*.map} \ + src/teledongle-v3.0/{*.elf,*.ihx,*.map} \ + src/telegps-v[1-2].0/{*.elf,*.ihx,*.map} \ + src/telemega-v[1-5].0/{*.elf,*.ihx,*.map} \ + src/telemetrum-v[2-3].0/{*.elf,*.ihx,*.map} \ + src/telemini-v3.0/{*.elf,*.ihx,*.map} \ + src/telelco-v2.0/{*.elf,*.ihx,*.map} \ + src/telefireeight-v[1-2].0/{*.elf,*.ihx,*.map} \ ~/altusmetrumllc/Binaries/ - cp src/easymini-v1.0/flash-loader/*.elf \ - src/telegps-v1.0/flash-loader/*.elf \ - src/telemega-v1.0/flash-loader/*.elf \ - src/telemetrum-v2.0/flash-loader/*.elf \ + cp src/chaoskey-v1.0/flash-loader/{*.elf,*.bin,*.map} \ + src/easymega-v[1-2].0/flash-loader/*.elf \ + src/easymini-v[1-2].0/flash-loader/*.elf \ + src/easymotor-v2/flash-loader/*.elf \ + src/easytimer-v1/flash-loader/*.elf \ + src/telebt-v[3-4].0/flash-loader/{*.elf,*.bin,*.map} \ + src/teledongle-v3.0/flash-loader/*.elf \ + src/telegps-v[1-2].0/flash-loader/{*.elf,*.bin,*.map} \ + src/telemega-v[1-5].0/flash-loader/*.elf \ + src/telemetrum-v[2-3].0/flash-loader/*.elf \ + src/telemini-v3.0/flash-loader/{*.elf,*.bin,*.map} \ + src/telelco-v2.0/flash-loader/*.elf \ + src/telefireeight-v[1-2].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) - - 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 - - - create /home/bdale/web/altusmetrum/TeleGPS/releases/, - and move the MicroPeak 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, to - include release date and explicit ref to dir contents so the - web pages shows versioned links, commit and push + - Push new release to web site + make fat-install (cd doc ; make publish) - this pushes fresh documents to the web site + (cd ~/web/altusmetrum/ && \ + git add */releases && git commit -m'Release ' && \ + git push origin master) + + - upload the Debian package + + - clean up sudo debian/rules clean git push origin master branch- debian pristine-tar git push --tags - push commits and leave the build tree in an uncluttered state - Testing before a release To verify that a build works, the following need to be checked