Idris2/INSTALL.md

205 lines
6.9 KiB
Markdown
Raw Normal View History

# Installation
2023-11-10 16:07:07 +03:00
- [Installing with a package manager](#installing-with-a-package-manager)
- [Installing from source](#installing-from-source)
- [Installing Chez Scheme on Apple Silicon](#installing-chez-scheme-on-apple-silicon)
2023-11-10 15:59:19 +03:00
## Installing with a package manager
You can install Idris 2 with any one of a number of package managers.
2023-11-10 15:59:19 +03:00
### Installing with [Pack](https://github.com/stefan-hoeck/idris2-pack)
2023-11-11 19:02:33 +03:00
Pack comes with an installation of Idris 2, so you just need to install Pack.
2023-11-11 19:11:02 +03:00
See [the installation instructions](https://github.com/stefan-hoeck/idris2-pack/blob/main/INSTALL.md)
on GitHub.
2023-11-10 15:59:19 +03:00
### Installing with [Homebrew](https://brew.sh/)
```sh
brew install idris2
```
2023-11-10 15:59:19 +03:00
### Installing with [Nix](https://nixos.org/features.html)
```sh
nix-env -i idris2
```
2023-11-10 15:59:19 +03:00
### Installing with [Nix Flakes](https://nixos.wiki/wiki/Flakes)
```sh
nix profile install github:idris-lang/Idris2
```
2020-06-17 02:36:26 +03:00
2023-11-10 15:59:19 +03:00
## Installing from source
2020-05-18 16:45:12 +03:00
The easiest way to install from source is via the existing generated Scheme
code. The requirements are:
2020-05-20 00:56:27 +03:00
2020-06-17 02:36:26 +03:00
- A Scheme compiler; either Chez Scheme (default), or Racket.
- `bash`, `GNU make`, `gcc` or `clang`, `sha256sum` and `GMP`. On Linux, you probably already
have these. On macOS and major BSD flavours, you can install them using a
2021-07-26 21:25:57 +03:00
package manager: for instance, on macOS, you can install with the
`brew install coreutils gmp` and on OpenBSD, with the `pkg_add coreutils
bash gmake gmp` command. You specifically need the dev GMP library, which
means on some systems the package you need to install will be named
2023-11-11 19:02:33 +03:00
something more like `libgmp3-dev`. macOS ships with `clang` whereas `gcc` is
more common for other \*nix distributions.
2020-05-20 00:56:27 +03:00
On Windows, it has been reported that installing via `MSYS2` works
2023-11-11 19:02:33 +03:00
[MSYS2](https://www.msys2.org/). On Windows older than Windows 8, you may need
to set an environment variable `OLD_WIN=1` or modify it in `config.mk`.
On Raspberry Pi, you can bootstrap via Racket.
2020-05-20 00:56:27 +03:00
By default, code generation is via Chez Scheme. You can use Racket instead,
by setting the environment variable `IDRIS2_CG=racket` before running `make`.
If you install Chez Scheme from source files, building it locally,
make sure you run `./configure --threads` to build multithreading support in.
2020-05-20 00:56:27 +03:00
**NOTE**: On FreeBSD, OpenBSD and NetBSD you need to use `gmake` command instead
of `make` in the following steps.
**NOTE**: If you're running macOS on Apple Silicon (arm64) you will need to
install the Racket fork of chez scheme as described below. If you install gmp
via homebrew, you will also need to `export CPATH=/opt/homebrew/include`.
### 1: Set installation target directory
2021-06-28 13:47:47 +03:00
- Change the `PREFIX` in `config.mk` to the absolute path of your chosen
installation destination. The default is to install in `$HOME/.idris2`
If you have an existing Idris 2, go to Step 3. Otherwise, read on...
Make sure that:
2020-06-17 02:36:26 +03:00
- `$PREFIX/bin` is in your `PATH`
2020-06-17 02:36:26 +03:00
### 2: Installing without an existing Idris 2
2020-08-17 10:16:22 +03:00
You can build from pre-built Chez Scheme source, as long as you have Chez Scheme
installed (or, alternatively, Racket). To do this, enter one of the following:
2020-06-17 02:36:26 +03:00
- `make bootstrap SCHEME=chez`
- `make bootstrap-racket`
2020-06-17 02:36:26 +03:00
`chez` is the executable name of the Chez Scheme compiler. You may need to
replace this with the executable for Chez Scheme on your system. This could be
2020-05-19 23:05:52 +03:00
`scheme`, `chezscheme` or `chezscheme9.5` or something else, depending on your
system and the Chez Scheme version.
This builds an Idris 2 compiler from scheme code output from a working Idris 2
compiler (which isn't necessarily up to date, but is up to date enough to
build the current repository). It then rebuilds using the result, and runs
the tests.
2020-05-19 01:31:25 +03:00
If all is well, to install, type:
2020-06-17 02:36:26 +03:00
- `make install`
If you are building with Racket, you'll need to run `IDRIS2_CG=racket make install`.
2020-08-17 10:16:22 +03:00
### 3: Installing with an existing Idris 2
If you have the latest *released* version of Idris 2
(0.6.0 at the time of writing) installed:
2020-06-17 02:36:26 +03:00
- `make all`
- `make install`
### 4: (Optional) Installing Idris 2 library documentation
After `make install`, type `make install-libdocs` to install Idris 2 library documentation. After
that, the index file can be found here: ``idris2 --libdir`/docs/index.html`.``
### 5: (Optional) Self-hosting step
As a final step, you can rebuild from the newly installed Idris 2 to verify
2020-06-17 02:36:26 +03:00
that everything has worked correctly. Assuming that `idris2` is in your
`PATH`.
2020-06-17 02:36:26 +03:00
- `make clean` -- to make sure you're building everything with the new version
2021-06-28 13:47:47 +03:00
- `make all && make install` -- OR
`make all IDRIS2_BOOT='idris2 --codegen racket' && make install`
if using Racket.
### 6: Running tests
2020-05-19 21:52:31 +03:00
After `make all`, type `make test` to check everything works. This uses the
executable in `./build/exec`.
### 7: (Optional) Enabling incremental compilation
If you are working on Idris, incremental compilation means that rebuilds are
much faster, at the cost of runtime performance being slower. To enable
incremental compilation for the Chez backend, set the environment variable
`IDRIS2_INC_CGS=chez`, or set the `--inc chez` flag in `idris2.ipkg`.
### 8: (Optional) Installing the Idris 2 API
You'll only need this if you're developing support tools, such as an external
code generator. To do so, once everything is successfully installed, type:
2020-06-17 02:36:26 +03:00
- `make install-api`
2021-10-23 05:04:07 +03:00
The API will only work if you've completed the self-hosting step (step 5), since
the intermediate code versions need to be consistent throughout. Otherwise, you
will get an `Error in TTC: TTC data is in an older format` error.
2020-06-17 02:36:26 +03:00
### 9: (Optional) Shell Auto-completion
Idris2 supports tab auto-completion for Bash-like shells.
#### For Bash Users
From within bash, run the following command:
```sh
eval "$(idris2 --bash-completion-script idris2)"
```
You can also add it to your `.bashrc` file.
#### For ZSH Users
2021-06-28 13:47:47 +03:00
From within ZSH, run the following commands:
```sh
autoload -U +X compinit && compinit
autoload -U +X bashcompinit && bashcompinit
eval "$(idris2 --bash-completion-script idris2)"
```
You can also add them to your `.zshrc` file.
### Troubleshooting
If you get the message `variable make-thread-parameter is not bound` while
bootstrapping via Chez Scheme, or while running the tests when bootstrapping via
Racket, then your copy of Chez Scheme was built without thread support. Pass
`--threads` to `./configure` while building Chez Scheme to correct the issue.
2021-03-15 17:21:50 +03:00
## Running in text editor
### Run on emacs using nix flakes
2021-06-28 13:47:47 +03:00
If you are a [nix flakes](https://nixos.wiki/wiki/Flakes) user you can run
Idris 2 in emacs by running the following command:
2021-03-15 17:21:50 +03:00
```sh
2021-06-28 13:47:47 +03:00
nix run github:idris-lang/Idris2#emacs-with-idris idrisCode.idr
```
2023-11-10 15:59:19 +03:00
## Installing Chez Scheme on Apple Silicon
The official version of chez scheme does not yet support Apple Silicon. So, on
macOS with Apple Silicon (e.g. M1 and M2 macs), you will need to build and install
the Racket fork of chez scheme.
```sh
git clone git@github.com:racket/ChezScheme.git
cd ChezScheme
git submodule init
git submodule update
arch=tarm64osx
./configure --pb
make ${arch}.bootquick
./configure --threads
make
sudo make install
```