#pe #dll #file-format #exe #bin #load-file #mui

no-std bin+lib pelite

Lightweight, memory-safe, zero-allocation library for reading and navigating PE binaries

15 releases (9 breaking)

0.10.0 Nov 4, 2022
0.9.1 Jun 18, 2022
0.9.0 Sep 5, 2020
0.8.1 Apr 15, 2020
0.1.0 Feb 23, 2016

#394 in Parser implementations

Download history 2702/week @ 2024-06-17 2498/week @ 2024-06-24 2226/week @ 2024-07-01 2330/week @ 2024-07-08 3076/week @ 2024-07-15 2740/week @ 2024-07-22 2211/week @ 2024-07-29 2037/week @ 2024-08-05 2349/week @ 2024-08-12 2145/week @ 2024-08-19 2024/week @ 2024-08-26 2072/week @ 2024-09-02 2013/week @ 2024-09-09 1875/week @ 2024-09-16 2532/week @ 2024-09-23 2114/week @ 2024-09-30

8,636 downloads per month
Used in 26 crates (18 directly)

MIT license

485KB
9K SLoC

Contains (Windows DLL, 30KB) demo/Demo64.dll, (Windows DLL, 28KB) demo/Demo.dll, (Windows exe, 1KB) tests/tiny/tiny.128, (Windows exe, 1KB) tests/tiny/tiny.168, (Windows exe, 1KB) tests/tiny/tiny.296, (Windows exe, 1KB) tests/tiny/tiny.356 and 7 more.

PeLite

MIT License crates.io docs.rs Changelog Build status Build Status

Lightweight, memory-safe, zero-allocation library for reading and navigating PE binaries.

Design

The purpose of this library is inspecting PE binaries (whether on disk or already loaded in memory).

A trade-off was made to not unify the 32-bit (PE32) and 64-bit (PE32+) formats for two reasons:

  • There are small but incompatible differences, which would add overhead by requiring constant matching even if at source code level the match arms look identical.

  • Most of the time you know (at build time) what format you're working with anyway.

This makes it rather awkward to work with both formats together transparently.

Note that while the correct name is PE32+, the name PE64 is used as it is a valid identifier; they are otherwise synonymous.

Tools

Included are bins showing some uses for the library, try them out on the demos!

Library

This library is available on crates.io.

Documentation can be found on docs.rs.

In your Cargo.toml, put

[dependencies]
pelite = "0.8"

Examples

Try this example: cargo run --example readme.

use pelite::FileMap;
use pelite::pe64::{Pe, PeFile};

fn main() {
	// Load the desired file into memory
	let file_map = FileMap::open("demo/Demo64.dll").unwrap();
	// Process the image file
	dll_deps(file_map.as_ref()).unwrap();
}

fn dll_deps(image: &[u8]) -> pelite::Result<()> {
	// Interpret the bytes as a PE32+ executable
	let file = PeFile::from_bytes(image)?;

	// Let's read the DLL dependencies
	let imports = file.imports()?;
	for desc in imports {
		// Get the DLL name being imported from
		let dll_name = desc.dll_name()?;
		// Get the number of imports for this dll
		let iat = desc.iat()?;
		println!("imported {} functions from {}", iat.len(), dll_name);
	}

	Ok(())
}

License

Licensed under MIT License, see license.txt.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, shall be licensed as above, without any additional terms or conditions.

Dependencies