8 releases

0.3.2 Aug 23, 2023
0.3.0 Jan 6, 2020
0.2.3 Sep 5, 2019
0.2.2 Jun 1, 2019
0.1.1 May 23, 2019

#342 in Parser implementations

Download history 3113/week @ 2023-12-16 1329/week @ 2023-12-23 2119/week @ 2023-12-30 2389/week @ 2024-01-06 3247/week @ 2024-01-13 3273/week @ 2024-01-20 1953/week @ 2024-01-27 1916/week @ 2024-02-03 2730/week @ 2024-02-10 2361/week @ 2024-02-17 3321/week @ 2024-02-24 2160/week @ 2024-03-02 3296/week @ 2024-03-09 3039/week @ 2024-03-16 2557/week @ 2024-03-23 2572/week @ 2024-03-30

11,658 downloads per month
Used in 18 crates (9 directly)

MIT/Apache

37KB
866 lines

Build Status crates.io

winstructs

This crate contains definitions and some parsing logic for structures that are common across windows formats.

Consult the Documentation for supported structs and usage instructions.

Example

Here is an example for parsing a GUID.

use winstructs::guid::Guid;

fn main() {
   let raw_guid: &[u8] = &[0x25, 0x96, 0x84, 0x54, 0x78, 0x54, 0x94, 0x49,
                           0xa5, 0xba, 0x3e, 0x3b, 0x3, 0x28, 0xc3, 0xd];
                           
   let guid = Guid::from_buffer(raw_guid).unwrap();
   assert_eq!(format!("{}", guid), "54849625-5478-4994-A5BA-3E3B0328C30D");
}

lib.rs:

This crate contains definitions and some parsing logic for structures that are common across windows formats.

Documentation

API

Generally, structs in this crate will have either from_reader, if they can be read from a Read instance, or from_stream, if reading them requires Read + Seek.

from_buffer is also provided as convenience, but it generally just builds a cursor and uses either from_reader or from_stream internally.

Dependencies

~1.9–3MB
~58K SLoC