Supported GHC Versions

The following GHC versions are defined in haskell.nix (there is a derivation for each, though not all are cached or tested by CI):

  • 8.4.4
  • 8.6.{1,2,3,4,5}
  • 8.8.{1,2,3,4}
  • 8.10.{1,2,3,4,5}
  • 9.0.1
  • 9.2.1
  • 9.2.2

The following table shows the Nixpkgs/GHC versions which are built/cached, and which of those are further tested. If you use a combination of Nixpkgs version and GHC version which is in this table, you should hit our cache, saving considering time by not building GHC and a few additional tools.

Note that if you try to use haskell.nix as an overlay over Nixpkgs from a standard Nixpkgs channel you will likely get a cache miss. To hit our cache you really should use an instance of Nixpkgs provided by haskell.nix itself.

Nixpkgs versionNixpkgs pinningGHC versioncompiler-nix-nameTested in CI?
22.05nixpkgs-22058.6.5ghc865No
22.05nixpkgs-22058.10.7ghc8107No
unstablenixpkgs-unstable8.6.5ghc865No
unstablenixpkgs-unstable8.8.4ghc884No
unstablenixpkgs-unstable8.10.7ghc8107Yes
unstablenixpkgs-unstable9.0.2ghc902No
unstablenixpkgs-unstable9.2.4ghc924Yes

See ci.nix for the source of truth about what is built and tested (in the off chance this document is out-of-sync with your checkout).

See the getting started guide for instructions on how to set up Nix to take advantage of our cache when building. This guide also covers where to use the Nixpkgs pinning and compiler-nix-name settings from the table above. For further information, see the instructions for how to pin Nixpkgs.

See overlays/bootstrap.nix for a full list of all the valid compiler-nix-names beyond what's cached/tested in CI. You're free to use these, but be ready for longer build times.

Lastly, see instructions on adding new GHC versions in the event that what's in haskell.nix doesn't suit your needs.