X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=6540383bca80b32ed26582c37bd5129bf7a0a679;hp=5780f3ce2778ce4e9318d58259cf083df3b548d8;hb=0b5ac831d2e63a091833c702b07b0331fba32e72;hpb=43e2275250d9c91560a770942f3c06a8f74ed501 diff --git a/Releasing b/Releasing index 5780f3ce..6540383b 100644 --- a/Releasing +++ b/Releasing @@ -17,6 +17,8 @@ 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 @@ -32,18 +34,20 @@ These are Bdale's notes on how to do a release. - make sure build environment is up to date sudo cowbuilder --update + - 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- @@ -89,18 +93,15 @@ These are Bdale's notes on how to do a release. - 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/ make && make fat - this pushes packages for each platform and application - to web site, including auto-generated mdwn files and - release notes in html format. + - store a stable copy of ARM binaries for production use - # 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/easymini-v1.0/{*.elf,*.ihx} \ src/easymini-v2.0/{*.elf,*.ihx} \ @@ -108,47 +109,53 @@ These are Bdale's notes on how to do a release. src/telebt-v4.0/{*.elf,*.ihx} \ src/teledongle-v3.0/{*.elf,*.ihx} \ src/telegps-v1.0/{*.elf,*.ihx} \ + 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} \ ~/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/telebt-v4.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,*.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 \ ~/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 .html file from doc/ to - /home/bdale/web/altusmetrum/AltOS/releases/ - - Push new release to web site make fat-install (cd doc ; make publish) - (cd ~/web/altusmetrum/ && git add AltOS/releases - TeleGPS/releases MicroPeak/releases && git commit -m'Release - ' && git push origin master) + (cd ~/web/altusmetrum/ && \ + git add */releases && git commit -m'Release ' && \ + git push origin master) - this pushes fresh documents to the web site + - 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