need to capture .bin file for telebt-v4.0 loader
[fw/altos] / Releasing
index fd5227978b4f821cc828ec64e2180a90bd1b83ef..92d0f8e443fd5f54764a0d0afef5bb6181ade60d 100644 (file)
--- a/Releasing
+++ b/Releasing
@@ -1,3 +1,32 @@
+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
+
+       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
+
+       - make sure there is a doc/release-notes-<version>.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
@@ -8,6 +37,7 @@ These are Bdale's notes on how to do a release.
        - 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
@@ -21,10 +51,10 @@ These are Bdale's notes on how to do a release.
                git checkout branch-<version>           # the x.y parts only
                - cherry-pick or merge appropriate content from master
        
-       - make sure there is a doc/release-notes-<version>.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)
+       - 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"
@@ -40,7 +70,7 @@ These are Bdale's notes on how to do a release.
 
        - verify debian/changelog is "clean" ending in last release version
        - craft a suitable debian/changelog entry, possibly using:
-       gbp 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"
 
@@ -62,60 +92,57 @@ These are Bdale's notes on how to do a release.
        make distclean
 
        ./autogen.sh --enable-multi-arch \
-               --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases
+               --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/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 \
+       - 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/telebt-v4.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/easymega-v1.0/flash-loader/*.elf \
+       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,*.bin} \
           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 file from doc/ to 
-           /home/bdale/web/altusmetrum/AltOS/releases/<rev>
+       - Push new release to web site
 
-       (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 fat-install
+       (cd doc ; make publish)
 
-               - make sure the Windows stuff is like 1-4-1, not 1.4.1!
+       (cd ~/web/altusmetrum/ && \
+               git add */releases && git commit -m'Release <rev>' && \
+               git push origin master)
 
-       (cd doc ; make publish)
+       - upload the Debian package 
 
-               this pushes fresh documents to the web site
+       - clean up
 
        sudo debian/rules clean
        git push origin master branch-<version> 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