Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jam1garner/binrw
A Rust crate for helping parse and rebuild binary data using ✨macro magic✨.
https://github.com/jam1garner/binrw
Last synced: about 1 hour ago
JSON representation
A Rust crate for helping parse and rebuild binary data using ✨macro magic✨.
- Host: GitHub
- URL: https://github.com/jam1garner/binrw
- Owner: jam1garner
- License: mit
- Created: 2020-10-31T19:19:07.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-12-01T07:41:19.000Z (3 months ago)
- Last Synced: 2025-02-14T13:02:15.302Z (7 days ago)
- Language: Rust
- Homepage: https://binrw.rs
- Size: 1.47 MB
- Stars: 671
- Watchers: 9
- Forks: 40
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# binrw
[data:image/s3,"s3://crabby-images/fb559/fb559386c63624ad08b8e421d9ea77ae8c9a739a" alt="crates"](https://crates.io/crates/binrw)
[data:image/s3,"s3://crabby-images/e2c0d/e2c0d4e0678082ad2dcd4cbd70ac1e87f8ad7565" alt="tests"](https://github.com/jam1garner/binrw/actions/workflows/main.yml)
[data:image/s3,"s3://crabby-images/154f0/154f0b1775649923f3467703dea4341d79152670" alt="docs.rs"](https://docs.rs/binrw)
[data:image/s3,"s3://crabby-images/d2983/d29835c2424ac2431bb72c2edc5fde349bba368a" alt="codecov"](https://codecov.io/gh/jam1garner/binrw)
[data:image/s3,"s3://crabby-images/66025/660250c4ef4bd6406f8d7cf344e13cb99212d898" alt="discord"](https://discord.gg/ABy4Qh549j)
[data:image/s3,"s3://crabby-images/4d508/4d50836cde4cbb9bf17431b29e09fa8f00cbde38" alt="matrix: #binrw:matrix.org"](https://matrix.to/#/#binrw:matrix.org)binrw helps you write maintainable & easy-to-read declarative binary data
readers and writers using ✨macro magic✨.## Features
* Generates efficient data parsers and serialisers for structs and enums using
`#[derive]`
* Reads and writes data from any source using standard `io::Read` and
`io::Write` streams
* [Directives in attributes](https://docs.rs/binrw/latest/binrw/docs/attribute)
handle common binary parsing tasks like matching magic numbers, byte ordering,
padding & alignment, data validation, and more
* Includes reusable types for common data structures like
[null-terminated strings](https://docs.rs/binrw/latest/binrw/struct.NullString.html) and
[data indirection using offsets](https://docs.rs/binrw/latest/binrw/struct.FilePtr.html)
* Parses types from third-party crates using
[free functions](https://docs.rs/binrw/latest/binrw/docs/attribute#custom-parsers)
or [value maps](https://docs.rs/binrw/latest/binrw/docs/attribute#map)
* Uses efficient in-memory representations (does not require `#[repr(C)]` or
`#[repr(packed)]`)
* Code in attributes is written as code, not as strings, for improved ergonomics
and first-class IDE support
* Supports no_std## Usage
```rust
#[derive(BinRead)]
#[br(magic = b"DOG", assert(name.len() != 0))]
struct Dog {
bone_pile_count: u8,#[br(big, count = bone_pile_count)]
bone_piles: Vec,#[br(align_before = 0xA)]
name: NullString
}let mut reader = Cursor::new(b"DOG\x02\x00\x01\x00\x12\0\0Rudy\0");
let dog: Dog = reader.read_ne().unwrap();
assert_eq!(dog.bone_piles, &[0x1, 0x12]);
assert_eq!(dog.name.into_string(), "Rudy")
```For more information, including a more detailed overview of binrw,
[visit the documentation](https://docs.rs/binrw).