Skip to content

9.2.2 release tracking

This is the template to be used to create release tracking tickets. Copy this into a new issue and fill in the TODOs. Those items marked with major-only can be ignored for minor releases.

This is the release checklist for the TODO milestone. See #16816 for the template that this was derived from.

Pre-fork checklist (major-only)

When forking a new release branch for a new major release series (e.g. ghc-9.0), please check the following:

  • Verify that haddock's development branch (namely the branch corresponding to GHC's previous major release, e.g. ghc-8.10) has been merged into ghc-head.
  • Remove the release notes for the previous release (e.g. docs/users_guide/8.6.*-notes.rst)
  • Create the new branch: git branch ghc-9.0
  • In the new branch bump the version number in configure.ac to, e.g., 9.0
  • In master bump the version number to that of the next development series, e.g., 9.1
  • Tag this master commit as, e.g., ghc-9.1-start
  • Push all of the above tags and branches
  • After forking remove release notes from master and start a new set of release notes for the next release

Pre-release checklist

  • Ensure that submodules are on released tags (the below is produced using this script):
    • libraries/Cabal: version 3.6.3.0
    • libraries/Win32: version 2.12.0.1
    • libraries/array: todo (on v0.5.4.0-8-g3e4334a)
    • libraries/binary: version 0.8.9.0
    • libraries/bytestring: version 0.11.1.0
    • libraries/containers: version 0.6.5.1
    • libraries/deepseq: version 1.4.6.1
    • libraries/directory: version 1.3.6.2
    • libraries/exceptions: todo (on v0.10.4-9-gebc21bd, no interesting changes from 0.10.4)
    • libraries/filepath: version 1.4.2.2
    • libraries/haskeline: version 0.8.2
    • libraries/mtl: version 2.2.2
    • libraries/parsec: version 3.1.15.0
    • libraries/pretty: version 1.1.3.6
    • libraries/process: version 1.6.13.2
    • libraries/stm: 2.5.0.2
    • libraries/terminfo: version 0.4.1.5
    • libraries/text: version 1.2.5.0 (plus a warning fix)
    • libraries/time: version 1.11.1.1
    • libraries/transformers: version 0.5.6.2
    • libraries/unix: 2.7.2.2 (plus bounds bumps)
    • libraries/xhtml: version 3000.2.2.1
    • utils/haddock: on current ghc-9.2 branch
    • utils/hsc2hs: version 0.68.8
  • Non-released submodules up-to-date:
    • nofib
    • libffi-tarballs
    • libraries/integer-gmp/gmp/gmp-tarballs
  • Release notes (docs/users_guide/x.y.z-notes.rst) written
  • Release notes linked in docs/users_guide/index.rst
  • autoconf scripts updated
  • Check that Unicode database in base (libraries/base/cbits/README.Unicode) reflects current standard release (http://www.unicode.org/versions/latest/)
  • LlvmVersion in configure.ac is targetting intended LLVM version
  • Release notes mentions LLVM version requirement
  • llvm-targets file updated
  • Changelogs updated (these can be checked using .gitlab/linters/check-changelogs.sh):
    • libraries/ghc-prim
    • libraries/ghc-bignum
    • libraries/hpc
    • libraries/base
  • Verify that the ~"backport needed" label has no more issues/merge requests needing backport
  • Verify that all CI builds are green before moving to release checklist

Release checklist

  • Ensure that the Migration page is up-to-date
  • Push a provision provisional release commit to trigger the release builds using git push -o ci.variable="RELEASE_JOB=yes"
  • Wait until builds finish; verify that they finished successfully
  • Fetch release artifacts TODO: documentation
  • Sign and push release artifacts to downloads.haskell.org [TODO: documentation]
  • Make a release tag
  • Release/revise GHC-maintained libraries on Hackage using this script:
    • libraries/base
    • libraries/ghc-prim
    • libraries/array
    • libraries/stm
    • libraries/ghc-heap
    • libraries/ghc-compact
    • libraries/ghc-boot
    • libraries/ghc-boot-th
    • libraries/hpc
    • libraries/libiserv
    • libraries/template-haskell
    • libraries/ghc-bignum
  • Update ghc/homepage>:
    • Write download page (see ghc/homepage>)
    • Check that download page has a section for each bindist in the downloads folder.
    • Add news item to index.html
    • Add link to download.shtml. Be sure to link to the Migration guide.
    • Look over changes locally
    • Add release announcement to GHC blog. Be sure to link to the Migration guide.
    • Push changes to master
  • Announce on: GHC developers <ghc-devs@haskell.org>, GHC Users <glasgow-haskell-users@haskell.org>, Haskell Cafe <haskell-cafe@haskell.org>
  • Announce on: Haskell Discourse, /r/haskell, Twitter
  • Update latest symlink on downloads.haskell.org

Post-release checklist

Edited by Ben Gamari
To upload designs, you'll need to enable LFS and have an admin enable hashed storage. More information