15 releases

0.5.6 Jan 10, 2023
0.5.5 Oct 12, 2022
0.5.4 Apr 27, 2022
0.5.1 Mar 29, 2022
0.4.0 Jul 28, 2021

#106 in Windows APIs

Download history 152/week @ 2024-08-31 206/week @ 2024-09-07 139/week @ 2024-09-14 213/week @ 2024-09-21 158/week @ 2024-09-28 137/week @ 2024-10-05 276/week @ 2024-10-12 201/week @ 2024-10-19 183/week @ 2024-10-26 194/week @ 2024-11-02 70/week @ 2024-11-09 110/week @ 2024-11-16 124/week @ 2024-11-23 158/week @ 2024-11-30 203/week @ 2024-12-07 148/week @ 2024-12-14

653 downloads per month
Used in 10 crates (8 directly)

GPL-3.0 license

305KB
6K SLoC

exe-rs

exe-rs is a Portable Executable (PE) parsing library tested on multiple kinds of malformed PE executables, including the Corkami corpus and various forms of malware! It's a library built with creation in mind as well as parsing, attempting to make tasks related to PE files as smooth and flawless as possible.

You can read the documentation here, and see various use examples in the test file. The changelog between various versions is available here.

Windows-specific features (such as loading a given PE file for execution) can be configured by enabling the win32 feature of the crate.


lib.rs:

exe-rs is a library for handling PE files, whether it be building them or analyzing them!

Getting started is easy:

use exe::pe::{PE, VecPE};
use exe::types::{ImportDirectory, ImportData, CCharString};

let image = VecPE::from_disk_file("test/compiled.exe").unwrap();
let import_directory = ImportDirectory::parse(&image).unwrap();

for descriptor in import_directory.descriptors {
   println!("Module: {}", descriptor.get_name(&image).unwrap().as_str().unwrap());
   println!("Imports:");

   for import in descriptor.get_imports(&image).unwrap() {
      match import {
         ImportData::Ordinal(x) => println!("   #{}", x),
         ImportData::ImportByName(s) => println!("   {}", s)
      }
   }
}

Standard PE headers and other types can be found in the headers module, while helper types can be found in the types module. Low-level functionality for handling PE data, such as collecting pointers and managing pointers as well as pulling out data, is handled by the pkbuffer module and the Buffer trait. Further usage examples can be found in the test file.

Dependencies

~4–12MB
~90K SLoC