Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samuela/rustybox
A free-range, non-GMO fork of busybox in 100% Rust 🦀
https://github.com/samuela/rustybox
busybox linux rust rust-lang
Last synced: 1 day ago
JSON representation
A free-range, non-GMO fork of busybox in 100% Rust 🦀
- Host: GitHub
- URL: https://github.com/samuela/rustybox
- Owner: samuela
- Created: 2019-11-02T01:35:39.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-04-09T04:14:27.000Z (over 1 year ago)
- Last Synced: 2024-12-06T09:12:21.642Z (6 days ago)
- Topics: busybox, linux, rust, rust-lang
- Language: Rust
- Homepage:
- Size: 8.05 MB
- Stars: 815
- Watchers: 14
- Forks: 33
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
- awesome-starred - samuela/rustybox - A free-range, non-GMO fork of busybox in 100% Rust 🦀 (rust)
README
# rustybox
[![](https://github.com/samuela/rustybox/workflows/Rust/badge.svg)](https://github.com/samuela/rustybox/actions)RustyBox is a free-range, non-GMO fork of [BusyBox](https://busybox.net/) written entirely in [Rust](https://www.rust-lang.org/). It includes all your favorite commands like `ls`, `mount`, and `top`, but without a single line of C code! Like BusyBox, rustybox weighs in at just under 1 megabyte and includes all the basic utilities you need to set up a small Linux OS.
![screenshot](https://i.ibb.co/fnJG4K3/carbon-1.png)
## Status
rustybox is a work-in-progress! It started out life as a direct [c2rust](https://github.com/immunant/c2rust) transpile of the busybox project, and has been steadily improving since then. This has the benefit of ensuring that rustybox is "bug-for-bug" compatible with busybox, but it does mean that we have inherited the raw pointers and `unsafe`s that come from C land. If making essential software memory-safe is your cup of tea then join the party with a PR!
## Contributing to rustybox
Contributing to rustybox is a great way to get started with rust, dig into the bowels of linux, or to help to free the world from the diabolical tyranny of C.
There's lots to be done, so we're happy to have you! Here are just a few ideas:
- Replace some `extern "C"` includes with more idiomatic `use`s. Pretty straightforward find/replace-all usually does the trick.
- Pick a utility, like `cat` or `touch`, and work on translating it into safer, more idiomatic rust. There are plenty of `unsafe`s lying around that you can tackle!
- Try building Alpine linux with rustybox in place of busybox. This could be an awesome drop-in replacement for the popular [`alpine` Docker image](https://hub.docker.com/_/alpine).Check out [the contributing doc](CONTRIBUTING.md) for more info!
And of course please test out rustybox and report [any and all](https://pointersgonewild.com/2019/11/02/they-might-never-tell-you-its-broken/) issues, concerns, and comments!
## Building rustybox
Rustybox requires a Linux system to build. Developing in Docker works just as well on macOS and Windows. You'll need GCC and its development headers (esp. `quadmath.h`) in order to build the f128 dependency. Running `sudo apt install build-essential` should do the trick on Ubuntu/Debian.
Please open an issue if you have trouble building!
### Customizing your rustybox distribution
By default, rustybox does not include any utility. You can include all of them:
```
cargo build --all-features
```Chances are you don't actually need or want _everything_ in rustybox, especially for a release. If you'd like to build rustybox with only a specific set of utilities:
```
cargo build --release --features "cat ls which"
```Check out the `[features]` section of `Cargo.toml` for the full list of utilities on tap.
After building, you can remove unnecessary debug sections with `strip`. This is recommended if you are particularly size-conscious.
## Acknowledgements
There's simply no way this project would be possible without the hard work from the wonderful [busybox](https://busybox.net/) and [c2rust](https://github.com/immunant/c2rust) teams. Both projects are dope, and you should check them out. Much of the code you find in this repo is transpiled from the work of the busybox [AUTHORS](https://github.com/mirror/busybox/blob/master/AUTHORS).