2022-08-12 13:14:09 +02:00
|
|
|
Tvix Evaluator
|
|
|
|
==============
|
|
|
|
|
|
|
|
This project implements an interpreter for the Nix programming
|
2022-09-11 14:35:06 +02:00
|
|
|
language. You can experiment with an online version of the evaluator:
|
|
|
|
[tvixbolt][].
|
2022-08-12 13:14:09 +02:00
|
|
|
|
|
|
|
The interpreter aims to be compatible with `nixpkgs`, on the
|
|
|
|
foundation of Nix 2.3.
|
|
|
|
|
2022-09-11 14:35:06 +02:00
|
|
|
**Important note:** The evaluator is not yet feature-complete, and
|
|
|
|
while the core mechanisms (compiler, runtime, ...) have stabilised
|
|
|
|
somewhat, a lot of components are still changing rapidly.
|
2022-08-12 13:14:09 +02:00
|
|
|
|
|
|
|
Please contact [TVL](https://tvl.fyi) with any questions you might
|
|
|
|
have.
|
|
|
|
|
2022-09-11 14:33:15 +02:00
|
|
|
## Building the evaluator
|
|
|
|
|
|
|
|
If you are in a full checkout of the TVL depot, you can simply run `mg
|
|
|
|
build` in this directory (or `mg build //tvix/eval` from anywhere in
|
|
|
|
the repo).
|
|
|
|
|
|
|
|
**Important note:** We only use and test Nix builds of our software
|
|
|
|
against Nix 2.3. There are a variety of bugs and subtle problems in
|
|
|
|
newer Nix versions which we do not have the bandwidth to address,
|
|
|
|
builds in newer Nix versions may or may not work.
|
|
|
|
|
|
|
|
The evaluator can also be built with standard Rust tooling (i.e.
|
|
|
|
`cargo build`).
|
|
|
|
|
|
|
|
If you would like to clone **only** the evaluator and build it
|
|
|
|
directly with Rust tooling, you can do:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
git clone https://code.tvl.fyi/depot.git:/tvix/eval.git tvix-eval
|
|
|
|
|
|
|
|
cd tvix-eval && cargo build
|
|
|
|
```
|
|
|
|
|
2022-08-12 13:25:07 +02:00
|
|
|
## Nix test suite
|
|
|
|
|
|
|
|
C++ Nix implements a language test suite in the form of Nix source
|
|
|
|
code files, and their expected output. The coverage of this test suite
|
|
|
|
is not complete, but we intend to be compatible with it.
|
|
|
|
|
|
|
|
We have ported the test suite to Tvix, but do not run it by default as
|
|
|
|
we are not yet compatible with it.
|
|
|
|
|
|
|
|
You can run the test suite by enabling the `nix_tests` feature in
|
2022-08-26 17:29:07 +02:00
|
|
|
Cargo:
|
|
|
|
|
|
|
|
cargo test --features nix_tests
|
2022-08-12 13:25:07 +02:00
|
|
|
|
2022-08-12 13:14:09 +02:00
|
|
|
## rnix-parser
|
|
|
|
|
|
|
|
Tvix is written in memory of jD91mZM2, the author of [rnix-parser][]
|
|
|
|
who sadly [passed away][rip].
|
|
|
|
|
|
|
|
Tvix makes heavy use of rnix-parser in its bytecode compiler. The
|
|
|
|
parser is now maintained by Nix community members.
|
|
|
|
|
|
|
|
[rnix-parser]: https://github.com/nix-community/rnix-parser
|
|
|
|
[rip]: https://www.redox-os.org/news/open-source-mental-health/
|
2022-09-11 14:35:06 +02:00
|
|
|
[tvixbolt]: https://tazj.in/blobs/tvixbolt/
|