[ANN] GHCup 0.2.2.0 release
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
.dhallextension) - consume metadata from Dhall binary format (requires
.dhallbextension) - convert an existing yaml metadata to dhall format (see
ghcup generate metadata-to-dhall) - dump the Dhall “schema” (the
GHCupInfotype) viaghcup 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 3rdpartyto get access to tools likehlint,ormolu,agdaetc. - refer to the Packaging documentation for more details
- this caused heavy changes to the internal ghcup layout and database
- run
- 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
- dump the Dhall schema via
- add
ghcup config resetsubcommand 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--verbosestill exists and is equivalent to--verbosity=1- ghcup won’t spam the installed file list on
--verbose/--verbosity=1anymore
- Store log files under
XDG_STATE_HOMEinstead ofXDG_CACHE_HOMEwhen following XDG style by Eisuke Kawashima - Make
--tooland--show-criteriaa ‘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 whereison windows by only using forward slashes in the output - lots of other things we forgot
Breaking changes
cabal install <ghc-ver>is gone, usecabal install ghc <ghc-ver>cabal install-cabal <cabal-ver>is gone, usecabal install cabal <cabal-ver>ghcup compile hls --isolate=/tmp/fooinstalls binaries into/tmp/foo/bininstead of/tmp/fooghcup listmay show-rXsuffix 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
- if you rely on version equality checks in a script and don’t want to deal with parsing those, you may consider
~/.ghcup/bin/is now all symlinks (except forghcupbinary 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