[](https://crates.io/crates/hfsplus-forensic)
[](https://docs.rs/hfsplus-forensic)
[](LICENSE)
[](https://github.com/SecurityRonin/hfsplus-forensic/actions)
[](https://github.com/sponsors/h4x0r)
**Pure-Rust forensic Apple HFS+/HFSX reader — volume-header geometry, catalog B-tree directory listing, and data-fork file extraction from a byte buffer.**
Built for parsing the HFS/HFS+ side of Apple hybrid optical discs and HFS+ volumes, with no `unsafe` and no allocations beyond the data it returns.
## Install
```toml
[dependencies]
hfsplus-forensic = "0.1"
```
## Quick start
```rust
// `volume` is the whole HFS+ volume (its header is at offset 1024).
let volume: Vec<u8> = std::fs::read("hfsplus.img")?;
if let Some(v) = hfsplus_forensic::parse(&volume) {
println!("{:?} {} blocks x {} bytes", v.kind, v.total_blocks, v.block_size);
for e in hfsplus_forensic::list_root(&volume).unwrap_or_default() {
println!(" {} {}", if e.is_dir { "dir " } else { "file" }, e.name);
if !e.is_dir {
let bytes = hfsplus_forensic::read_file(&volume, e.cnid);
println!(" {} bytes", bytes.map(|b| b.len()).unwrap_or(0));
}
}
}
```
## What it parses
| Capability | Notes |
|---|---|
| Volume header | `H+` / `HX` signature, version, allocation block size, block counts |
| Root + directory listing | catalog B-tree leaf walk; `list_dir(parent_cnid)` for any folder |
| File extraction | data-fork extents, truncated to the logical size |
Geometry and listing only; on-disk journal replay and resource-fork specifics are out of scope.
## Validation
Tests run against **real `hdiutil`-created HFS+ output** — a volume header and a populated volume (`HELLO.TXT` / `READ.ME` / `SUBDIR`) — so the parser is checked against genuine Apple structures, not hand-built fixtures.
## Related
Part of the [Security Ronin](https://github.com/SecurityRonin) forensic toolkit. Sibling filesystem readers: [`ext4fs-forensic`](https://github.com/SecurityRonin/ext4fs-forensic), [`ntfs-forensic`](https://github.com/SecurityRonin/ntfs-forensic), [`udf-forensic`](https://github.com/SecurityRonin/udf-forensic); partition maps: [`apm-forensic`](https://github.com/SecurityRonin/apm-forensic), [`gpt-forensic`](https://github.com/SecurityRonin/gpt-forensic), [`mbr-forensic`](https://github.com/SecurityRonin/mbr-forensic). Consumed by [`iso9660-forensic`](https://github.com/SecurityRonin/iso9660-forensic) for Apple hybrid discs.
---
[Privacy Policy](https://securityronin.github.io/hfsplus-forensic/privacy/) · [Terms of Service](https://securityronin.github.io/hfsplus-forensic/terms/) · © 2026 Security Ronin Ltd