#endianness #binary-data #little-endian #file-format #big-endian #byte #binary

byteordered

Abstraction for reading and writing data with implicit byte order awareness

9 releases (5 breaking)

Uses old Rust 2015

0.6.0 Aug 3, 2021
0.5.0 Dec 2, 2019
0.4.1 Nov 26, 2019
0.4.0 Jan 15, 2019
0.1.0 Nov 22, 2018

#6 in #big-endian

Download history 41189/week @ 2024-07-28 26107/week @ 2024-08-04 49727/week @ 2024-08-11 47287/week @ 2024-08-18 20366/week @ 2024-08-25 24718/week @ 2024-09-01 26247/week @ 2024-09-08 31222/week @ 2024-09-15 29865/week @ 2024-09-22 32123/week @ 2024-09-29 32239/week @ 2024-10-06 23823/week @ 2024-10-13 31789/week @ 2024-10-20 35908/week @ 2024-10-27 40846/week @ 2024-11-03 33702/week @ 2024-11-10

144,319 downloads per month
Used in 48 crates (15 directly)

MIT/Apache

77KB
1K SLoC

byteordered

Latest Version CI Status Minimum Rust Version 1.41.1 dependency status

A library for reading and writing data in some byte order.

Why yet another data parsing crate

While byteorder is well established in the Rust ecosystem, it relies on immaterial zero-constructor types for declaring the intended byte order. As such, it lacks a construct for reading and writing data in an endianness that is not originally known at compile time. For example, there are file formats in which the encoding may be either in little endian or in big endian order.

In addition, some users feel that adding the type parameter on each read/write method call is unnecessarily verbose and ugly.

Rather than building yet another new library, this crate aims to provide an alternative public API to byteorder, so that it becomes suitable for this particular case while preserving its familiarity and core capabilities.

Using

An example follows. Please see the documentation for more information.

use byteordered::{ByteOrdered, Endianness};

let mut rd = ByteOrdered::le(get_data_source()?);
// read 1st byte
let b1 = rd.read_u8()?;
// choose to read the following data in Little Endian if it's 0,
// otherwise read in Big Endian
let endianness = Endianness::le_iff(b1 != 0);
let mut rd = rd.into_endianness(endianness);
let value: u32 = rd.read_u32()?;

License

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.

Dependencies

~115KB