Tvix Evaluator ============== This project implements an interpreter for the Nix programming language. The interpreter aims to be compatible with `nixpkgs`, on the foundation of Nix 2.3. Work on this project is *extremely in-progress*, and the state of the project in the public repository may not necessarily reflect the state of the private codebase, as we are slowly working on publishing it. We expect this to have caught up in a handful of weeks (as of 2022-08-12). Please contact [TVL](https://tvl.fyi) with any questions you might have. ## 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 ``` ## 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 Cargo: cargo test --features nix_tests ## 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/