Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
opticaldiscs
Format-agnostic optical disc image reading and filesystem browsing for Rust.
Provides a unified SectorReader abstraction that handles the cooked/raw sector
translation across three container formats — ISO, BIN/CUE, and CHD — with
filesystem browsers for ISO 9660, HFS, HFS+, and SGI EFS on top.
Status: Published on crates.io. Disc reading, detection, and filesystem browsing are complete and in production use; physical-disc ripping is the next milestone. See PLAN.md for the roadmap.
CHD support
opticaldiscs-rs reads CHD optical images via libchdman-rs,
which wraps MAME's official chd_file core. This provides byte-for-byte
parity with the chdman tool — including subcode handling, audio
byte-swapping, and per-track frame semantics — at the cost of needing
to link MAME's C++ code.
By default, opticaldiscs-rs enables libchdman-rs's prebuilt feature,
which downloads a pre-built static archive matching the build target
from libchdman-rs's GitHub Releases instead of compiling MAME from
source. This keeps CI build times in seconds, not minutes.
When you might need to override prebuilt behavior
| Situation | Set env var |
|---|---|
| Target triple isn't covered by libchdman-rs's prebuilt matrix | LIBCHDMAN_PREBUILT_FALLBACK=1 |
| Local development without network access | LIBCHDMAN_FORCE_SOURCE=1 |
| Linux: pick a specific glibc floor for the prebuilt archive | LIBCHDMAN_GLIBC=2.31 (or 2.35, 2.39) |
See libchdman-rs's README for the full list of supported targets, glibc floors, and escape hatches.
Features
| Capability | Status |
|---|---|
| ISO sector reader | ✓ |
| BIN/CUE sector reader (raw 2352-byte) | ✓ |
| CHD sector reader (via libchdman-rs) | ✓ |
| Disc format + filesystem auto-detection | ✓ |
| ISO 9660 filesystem browser | ✓ |
| ISO 9660 PVD date/time metadata (creation/modification/expiration/effective) | ✓ (since 0.4.4) |
| Joliet (Unicode long names) | ✓ (since 0.6.0) |
| Rock Ridge / SUSP (POSIX metadata, long names, symlinks, timestamps) | ✓ (since 0.6.0) |
Per-file timestamps + POSIX ownership on FileEntry (all filesystems) |
✓ (since 0.6.0) |
| HFS / HFS+ filesystem browser | ✓ |
| SGI Volume Header + EFS filesystem browser (IRIX CDs) | ✓ (since 0.3.0) |
| TOC + MusicBrainz/FreeDB DiscID | ✓ (toc feature) |
| Physical optical drive enumeration | ✓ (drives feature) |
Quick Example
use DiscImageInfo;
use browse;
let info = open?;
println!;
println!;
let mut fs = open_disc_filesystem?;
let root = fs.root?;
for entry in fs.list_directory?
Cargo.toml
= "0.4"
# with optional features
= { = "0.4", = ["toc", "drives"] }
To track unreleased changes, depend on the git repository instead:
= { = "https://github.com/danifunker/opticaldiscs-rs" }
Feature Flags
| Flag | Enables | Extra deps |
|---|---|---|
toc |
DiscTOC, MusicBrainz DiscID, FreeDB ID |
sha1, base64 |
drives |
list_drives() — enumerate physical optical drives |
— |
Used By
- rusty-backup — vintage disc backup/restore tool
- ODE-artwork-downloader — USBODE cover art downloader
License
GPL-3.0 — see LICENSE.