| Crates.io | steel-interpreter |
| lib.rs | steel-interpreter |
| version | 0.7.0 |
| created_at | 2023-07-03 19:40:57.637407+00 |
| updated_at | 2025-06-21 15:11:40.574798+00 |
| description | Steel repl and command line interface |
| homepage | |
| repository | https://github.com/mattwparas/steel |
| max_upload_size | |
| id | 907403 |
| size | 98,377 |
An embeddable and extensible scheme dialect built in Rust.
Try it on the Playground ยท Read the Steel book (WIP)Steel is an embeddable scheme interpreter, with a standalone interpreter/repl included as well. The language is implemented as a bytecode virtual machine. At the moment, it is mostly compliant with R5RS, only missing let-syntax support. Support for R7Rs is underway.
Warning The API is relatively stable, however it may change at any time while pre 1.0. Care will be taken to keep things backwards compatible where possible.
require and provide much like Racket.syntax-rules and syntax-case macros.For more details, see the book
This github repository contains a cli interpreter. To try it out on the online playground, go to the Steel playground. To get started using a repl with the crates, make sure you first have rust installed.
Then, clone the repo and run the following command:
cargo run
This will launch a REPL instance that looks something like this:
If you'd like to install everything, just run the following command:
cargo xtask install
This will install:
steelforgecargo-steel-lib (also available via the interpreter)cogs directoryIf you would like to customize the location of installed packages, please set the STEEL_HOME environment variable. Steel currently follows XDG if present, and otherwise assumes the default of $HOME/.steel if the STEEL_HOME environment variable is not already set.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
See CONTRIBUTING.md.