External Publication
Visit Post

[ANN] GHCup 0.2.2.0 release

Haskell Community [Unofficial] May 21, 2026
Source

I’m very pleased to announce the release of 0.2.2.0

Motivation

The work on this release was sponsored by IOG, since their need for shipping alternative compilers coincided with the Installer DSL feature request that had been lingering on the tracker for years.

What I ended up implementing is not quite a DSL, since I wanted to keep the complexity low, both in terms of implementation and in terms of “packaging effort” for end users.

This release is a major rewrite and took around 2 months. While I’ve been investing a lot of time in tests and correctness… there might be things that slipped through.

How to update

If you haven’t installed yet, follow the instructions at https://www.haskell.org/ghcup/

Otherwise simply run ghcup upgrade.

For end users

New tools

For regular end users, I think the most exciting change is the new “3rdparty” channel, which gives access to non-core tools and compilers such as Agda, ormou, hlint, etc.

After upgrading, add it via:

ghcup config add-release-channel 3rdparty

Then run ghcup tui to get an overview of available tools.

Asciinema video

New online documentation

The documentation uses a new readthedocs format (similar to stack) and is now structured much better: https://www.haskell.org/ghcup/guide/

For upstream projects/packagers

Upstream projects and end users can now in theory ship arbitrary tools through ghcup. Refer to the Adding new tools documentation.

A lot of time has also been invested in supporting Dhall metadata. GHCup can now:

  • consume metadata in the form of resolved Dhall text files (no imports, requires .dhall extension)
  • consume metadata from Dhall binary format (requires .dhallb extension)
  • convert an existing yaml metadata to dhall format (see ghcup generate metadata-to-dhall)
  • dump the Dhall “schema” (the GHCupInfo type) via ghcup generate dhall-schema

The other major feature is revisions. These would allow e.g. the HLS project to add new GHC binaries to an existing release (in case that doesn’t require source code changes) without having to release a new hackage version etc. It also allows any other non source code fixes to bindists

Refer to the Packaging Guide for more information.

Full ChangeLog

New feature

  • implement “installer DSL” (custom tool installation) wrt #141
    • run ghcup config add-release-channel 3rdparty to get access to tools like hlint, ormolu, agda etc.
    • refer to the Packaging documentation for more details
    • this caused heavy changes to the internal ghcup layout and database
  • major design change in the TUI (two-pane view)
    • use left/right arrow keys or tab to switch between the tool and version list
  • implement revisions
    • these are “distributor” updates (e.g. fixes to bindists or the metadata) without requiring a proper upstream release
    • refer to the documentation for more details
  • pave the way for OpenBSD support wrt #182
    • we still lack GHC bindists
  • add experimental support for Dhall metadata wrt #60
    • dump the Dhall schema via ghcup generate dhall-schema
  • add ghcup config reset subcommand by Vladislav Sabanov
  • add experimental healthcheck command ghcup check tool ghc <ver>
    • this may only give useful information on newly installed versions since the database needs to be populated

Improvements and bug fixes

  • Introduce --verbosity=<LEVEL> (0-2) option
    • --verbose still exists and is equivalent to --verbosity=1
    • ghcup won’t spam the installed file list on --verbose/--verbosity=1 anymore
  • Store log files under XDG_STATE_HOME instead of XDG_CACHE_HOME when following XDG style by Eisuke Kawashima
  • Make --tool and --show-criteria a ‘many’ parser, fixes #1235
  • Ignore local cache when dlUri has a file: scheme, fixes #1312
  • don’t show update warnings twice (if it’s the same old warning)
  • Fix ghcup whereis on windows by only using forward slashes in the output
  • lots of other things we forgot

Breaking changes

  • cabal install <ghc-ver> is gone, use cabal install ghc <ghc-ver>
  • cabal install-cabal <cabal-ver> is gone, use cabal install cabal <cabal-ver>
  • ghcup compile hls --isolate=/tmp/foo installs binaries into /tmp/foo/bin instead of /tmp/foo
  • ghcup list may show -rX suffix on versions when there’s a revision update
    • if you rely on version equality checks in a script and don’t want to deal with parsing those, you may consider ghcup list --show-revisions=none
  • ~/.ghcup/bin/ is now all symlinks (except for ghcup binary itself) and the link targets may have different shape

Contributors

  • with design discussions and guidance
    • The stable-haskell team at IOG
    • @angerman
  • with testing
    • @Kleidukos
    • @Bodigrim
  • with reviews
    • @Lsmor
  • with code contributions
    • Ai-Ya-Ya
    • Andreas Klebinger
    • Andreas Schacker
    • Divam
    • Eisuke Kawashima
    • Jonathan Knowles
    • Suhani370
    • Tom Ellis
    • Tom Smeding
    • Vladislav Sabanov

Discussion in the ATmosphere

Loading comments...