A rust bencode encoding/decoding implementation backed by serde.
This is one of a few bencode implementations available for rust. Though there are alternatives (see below), implementing bencode is both fun and a good learning experience. It also never hurts to have one more alternative.
There are more, but some are no longer maintained.
Add the library as a dependency to Cargo.toml
toml
[dependencies]
bende = "0.5.0"
serde = { version = "1", features = ["derive"] }
```rust use serde::{Deserialize, Serialize};
struct Person { name: String, age: u8, is_employed: bool, }
let jerry = Person { name: "Jerry Smith".tostring(), age: 50, isemployed: false, };
let bytes = bende::encode(&jerry).unwrap();
assert_eq!(bende::decode::
The types that are currently not supported are:
f32
f64
char
enum
Floats will never be supported, but char
and enum
support will probably be added in the future.
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
git checkout -b feature/AmazingFeature
)git commit -m 'Add some AmazingFeature'
)git push origin feature/AmazingFeature
)Option<_>
(Some and None) are supported by the decoder, but the encoder only supports Some
.&[u8]
or Vec<u8>
then use this crate.