This is a starting point for Rust solutions to the "Build Your Own Shell" Challenge.
In this challenge, you'll build your own POSIX compliant shell that's capable of interpreting shell commands, running external programs and builtin commands like cd, pwd, echo and more. Along the way, you'll learn about shell command parsing, REPLs, builtin commands, and more.
Note: If you're viewing this repo on GitHub, head over to codecrafters.io to try the challenge.
The entry point for your shell implementation is in src/main.rs. Study and
uncomment the relevant code, and push your changes to pass the first stage:
git commit -am "pass 1st stage" # any msg
git push origin masterTime to move on to the next stage!
Note: This section is for stages 2 and beyond.
- Ensure you have
cargo (1.87)installed locally - Run
./your_program.shto run your program, which is implemented insrc/main.rs. This command compiles your Rust project, so it might be slow the first time you run it. Subsequent runs will be fast. - Commit your changes and run
git push origin masterto submit your solution to CodeCrafters. Test output will be streamed to your terminal.
This is a collection of TODOs of possible improvements/refactors that I feel would make this project more elegant / reusable / etc, but do not have the time for right now:
- Re-add "cargo" lints and fix all concerns
- CI pipeline on GitHub Actions
- Track exit status (
$?) for last executed command - 'Really good' error messages, like the Rust compiler (I think
the crate is called
eyre)- NOTE: This may not be possible / easy because CodeCrafters expects output in a certain way
- No attempt has been made to make this shell work on anything other than Linux
- See quispejo's solution for example of finding an executable on Windows
- Investigate optimisation of zero-copy command parsing with lifetimes