Object file parsing library for Rust
Find a file
Repository files (latest commit first)
Filename Latest commit message Latest commit date
Philip Craig eed21f6f88
Some checks failed
Rust / build (macOS-latest, stable) (push) Has been cancelled
Rust / build (ubuntu-latest, beta) (push) Has been cancelled
Rust / build (ubuntu-latest, nightly) (push) Has been cancelled
Rust / build (ubuntu-latest, stable) (push) Has been cancelled
Rust / features (push) Has been cancelled
Rust / cross (push) Has been cancelled
Rust / msrv (push) Has been cancelled
Rust / rustfmt (push) Has been cancelled
Rust / doc (push) Has been cancelled
Rust / coverage (push) Has been cancelled
Change edition to 2024 (#893)
2026-05-08 18:03:48 +10:00
.cargo Release 0.33.0 (#640) 2024-03-05 12:52:01 +10:00
.github/workflows Change MSRV to 1.85.0 (#892) 2026-05-08 17:45:11 +10:00
crates Change edition to 2024 (#893) 2026-05-08 18:03:48 +10:00
src Change edition to 2024 (#893) 2026-05-08 18:03:48 +10:00
testfiles@5b9ce64e40 rewrite: fix handling of SHT_NOBITS sections (#843) 2026-01-15 21:55:30 +10:00
tests Change edition to 2024 (#893) 2026-05-08 18:03:48 +10:00
xtask Change MSRV to 1.85.0 (#892) 2026-05-08 17:45:11 +10:00
.gitignore Ignore xtask Cargo.lock 2024-03-05 14:31:44 +10:00
.gitmodules Add initial ELF/PE/Wasm file tests 2021-08-26 12:24:52 +10:00
Cargo.lock Release 0.39.1 (#888) 2026-04-21 18:40:29 +10:00
Cargo.toml Change edition to 2024 (#893) 2026-05-08 18:03:48 +10:00
CHANGELOG.md Release 0.39.1 (#888) 2026-04-21 18:40:29 +10:00
LICENSE-APACHE Add license 2016-08-19 13:44:41 -07:00
LICENSE-MIT Add license 2016-08-19 13:44:41 -07:00
README.md Change MSRV to 1.85.0 (#892) 2026-05-08 17:45:11 +10:00

object

The object crate provides a unified interface to working with object files across platforms. It supports reading relocatable object files and executable files, and writing COFF/ELF/Mach-O/XCOFF relocatable object files and ELF/PE executable files.

For reading files, it provides multiple levels of support:

  • raw struct definitions suitable for zero copy access
  • low level APIs for accessing the raw structs (example)
  • a higher level unified API for accessing common features of object files, such as sections and symbols (example)

Supported file formats for reading: ELF, Mach-O, Windows PE/COFF, Wasm, XCOFF, and Unix archive.

For writing files, it provides:

  • low level writers for ELF, PE, and COFF
  • higher level builder for ELF (example)
  • a unified API for writing relocatable object files (ELF, Mach-O, COFF, XCOFF) (example)

Example for unified read API

use object::{Object, ObjectSection};
use std::error::Error;
use std::fs;

/// Reads a file and displays the name of each section.
fn main() -> Result<(), Box<dyn Error>> {
    let binary_data = fs::read("path/to/binary")?;
    let file = object::File::parse(&*binary_data)?;
    for section in file.sections() {
        println!("{}", section.name()?);
    }
    Ok(())
}

See crates/examples for more examples.

Security

This crate is intended to be used with trusted inputs. For example, it is suitable for use as part of a compiler toolchain, but not for malware analysis or a service exposed to arbitrary inputs.

The crate aims to be reliable: it provides memory safety (with some use of unsafe for performance), and malformed input is expected to result in an error rather than a panic or incorrect parsing.

However, there are significant limitations:

  • There is little effort to mitigate denial of service attacks (such as algorithmic complexity attacks due to overlapping structures).

  • The crate does not aim to replicate the behaviour of platform loaders such as the Windows loader or dynamic linkers. Data returned by the parser may not match the data used by a loader.

Non-intrusive fixes (low complexity or overhead) for these are welcome, but it is not a focus of development.

Minimum supported Rust version (MSRV)

Changes to MSRV are not considered breaking changes. We are conservative about changing the MSRV, but sometimes are required to due to dependencies. The MSRV with all features enabled is 1.87.0. The MSRV with some features disabled is 1.85.0.

License

Licensed under either of

at your option.

Contribution

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.