2021-10-02 18:21:51 +00:00
|
|
|
# Getting started
|
|
|
|
|
|
|
|
Let's get started....
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
The following commands will download the `ghcup` binary into `~/.ghcup/bin` (or `C:\ghcup\bin` on windows) and then
|
|
|
|
run it to interactively install the [Haskell Toolchain](#supported-tools). These commands should be run as **non-root/non-admin
|
|
|
|
user**.
|
|
|
|
|
|
|
|
For Linux, macOS, FreeBSD or Windows Subsystem 2 for Linux, run this in a terminal:
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
```sh
|
|
|
|
curl --proto '=https' --tlsv1.2 -sSf https://get-ghcup.haskell.org | sh
|
|
|
|
```
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
For Windows, run this in a PowerShell session:
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
```psh
|
|
|
|
Set-ExecutionPolicy Bypass -Scope Process -Force;[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072;Invoke-Command -ScriptBlock ([ScriptBlock]::Create((Invoke-WebRequest https://www.haskell.org/ghcup/sh/bootstrap-haskell.ps1 -UseBasicParsing))) -ArgumentList $true
|
|
|
|
```
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
Advanced users may want to perform a [manual installation](#manual-install) and GPG verify the binaries.
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
## Supported tools
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
GHCup supports the following tools, which are also known as the **Haskell Toolchain**:
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
1. [GHC](https://www.haskell.org/ghc/)
|
|
|
|
2. [cabal-install](https://cabal.readthedocs.io/en/latest/)
|
|
|
|
3. [haskell-language-server](https://haskell-language-server.readthedocs.io/en/latest/)
|
|
|
|
4. [stack](https://docs.haskellstack.org/en/latest/README/)
|
|
|
|
|
|
|
|
## Supported platforms
|
|
|
|
|
|
|
|
This list may not be exhaustive and specifies support for bindists only.
|
|
|
|
|
|
|
|
| Platform | Architecture | ghcup | GHC | cabal | HLS | stack |
|
|
|
|
| ------ | ------ | ------ | ------ | ------ | ------ | ------ |
|
|
|
|
| Windows 7 | amd64 | ❔ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Windows 10 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Windows Server 2016 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Windows Server 2019 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Windows Server 2022 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Windows WSL1 | amd64 | ❌ | ❔ | ❔ | ❔ | ❔ |
|
|
|
|
| Windows WSL2 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
2021-10-06 15:27:47 +00:00
|
|
|
| MacOS >=10.13 | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| MacOS <10.13 | amd64 | ❌ | ❔ | ❔ | ❔ | ❔ |
|
2021-10-02 18:21:51 +00:00
|
|
|
| MacOS | aarch64 | ✅ | ✅ | ✅ | ⚠️ | ❌ |
|
|
|
|
| FreeBSD | amd64 | ✅ | ⚠️ | ✅ | ⚠️ | ❌ |
|
|
|
|
| Linux generic | x86 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Linux generic | amd64 | ✅ | ✅ | ✅ | ✅ | ✅ |
|
|
|
|
| Linux generic | aarch64 | ✅ | ⚠️ | ✅ | ⚠️ | ❌ |
|
|
|
|
| Linux generic | armv7 | ✅ | ⚠️ | ✅ | ⚠️ | ❌ |
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### Windows 7
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
May or may not work, several issues:
|
|
|
|
|
|
|
|
* https://gitlab.haskell.org/haskell/ghcup-hs/-/issues/140
|
|
|
|
* https://gitlab.haskell.org/haskell/ghcup-hs/-/issues/197
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### WSL1
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
Unsupported. GHC may or may not work. Upgrade to WSL2.
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### MacOS <13
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
Not supported. Would require separate binaries, since >=13 binaries are incompatible.
|
|
|
|
Please upgrade.
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### MacOS aarch64
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
HLS bindists are still experimental. Stack is theoretically supported, but has no binaries yet.
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### FreeBSD
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
Lacks some upstream bindists and may need compat libs, since most bindists are built on FreeBSD-12.
|
|
|
|
HLS bindists are experimental.
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
### Linux ARMv7/AARCH64
|
2021-10-02 18:21:51 +00:00
|
|
|
|
|
|
|
Lower availability of bindists. HLS only has experimental ones. Stack not supported currently.
|
|
|
|
|
|
|
|
## Manual install
|
|
|
|
|
|
|
|
Download the binary for your platform at [https://downloads.haskell.org/~ghcup/](https://downloads.haskell.org/~ghcup/)
|
|
|
|
and place it into your `PATH` anywhere.
|
|
|
|
|
2021-10-04 19:40:48 +00:00
|
|
|
If you want to GPG verify the binaries, import the following key first: `7784930957807690A66EBDBE3786C5262ECB4A3F`.
|
|
|
|
|
2021-10-02 18:21:51 +00:00
|
|
|
Then adjust your `PATH` in `~/.bashrc` (or similar, depending on your shell) like so:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
export PATH="$HOME/.cabal/bin:$HOME/.ghcup/bin:$PATH"
|
|
|
|
```
|
|
|
|
|
|
|
|
## Vim integration
|
|
|
|
|
|
|
|
See [ghcup.vim](https://github.com/hasufell/ghcup.vim).
|
|
|
|
|