nod-rs/README.md

135 lines
3.5 KiB
Markdown
Raw Permalink Normal View History

# nod [![Build Status]][actions] [![Latest Version]][crates.io] [![Api Rustdoc]][rustdoc] ![Rust Version]
2021-08-23 13:48:35 +00:00
2024-02-22 06:47:13 +00:00
[Build Status]: https://github.com/encounter/nod-rs/actions/workflows/build.yaml/badge.svg
2021-08-23 13:48:35 +00:00
[actions]: https://github.com/encounter/nod-rs/actions
[Latest Version]: https://img.shields.io/crates/v/nod.svg
[crates.io]: https://crates.io/crates/nod
[Api Rustdoc]: https://img.shields.io/badge/api-rustdoc-blue.svg
[rustdoc]: https://docs.rs/nod
2024-02-22 06:33:48 +00:00
[Rust Version]: https://img.shields.io/badge/rust-1.73+-blue.svg?maxAge=3600
2021-08-23 13:48:35 +00:00
Library for traversing & reading Nintendo Optical Disc (GameCube and Wii) images.
2021-08-23 13:48:35 +00:00
Originally based on the C++ library [nod](https://github.com/AxioDL/nod),
2021-08-23 13:48:35 +00:00
but does not currently support authoring.
Currently supported file formats:
2024-09-11 05:19:19 +00:00
2024-02-02 23:17:35 +00:00
- ISO (GCM)
- WIA / RVZ
- WBFS (+ NKit 2 lossless)
- CISO (+ NKit 2 lossless)
- NFS (Wii U VC)
- GCZ
2024-09-04 05:34:05 +00:00
- TGC
2021-08-23 13:48:35 +00:00
## CLI tool
2021-08-23 13:48:35 +00:00
2024-09-05 02:26:19 +00:00
This crate includes a command-line tool called `nodtool`.
Download the latest release from the [releases page](https://github.com/encounter/nod-rs/releases),
or install it using Cargo:
```shell
cargo install --locked nodtool
```
### info
Displays information about a disc image.
```shell
nodtool info /path/to/game.iso
```
### extract
Extracts the contents of a disc image to a directory.
2021-08-23 13:48:35 +00:00
```shell
nodtool extract /path/to/game.iso [outdir]
```
For Wii U VC titles, use `content/hif_000000.nfs`:
2021-08-23 13:48:35 +00:00
```shell
nodtool extract /path/to/game/content/hif_000000.nfs [outdir]
```
### convert
Converts any supported format to raw ISO.
```shell
nodtool convert /path/to/game.wia /path/to/game.iso
2024-09-11 05:19:19 +00:00
```
2024-02-22 06:47:13 +00:00
### verify
Hashes the contents of a disc image and verifies it.
```shell
nodtool verify /path/to/game.iso
```
## Library example
2021-08-23 13:48:35 +00:00
Opening a disc image and reading a file:
2024-02-02 23:17:35 +00:00
2021-08-23 13:48:35 +00:00
```rust
use std::io::Read;
// Open a disc image and the first data partition.
let disc = nod::Disc::new("path/to/file.iso")
.expect("Failed to open disc");
let mut partition = disc.open_partition_kind(nod::PartitionKind::Data)
.expect("Failed to open data partition");
// Read partition metadata and the file system table.
let meta = partition.meta()
.expect("Failed to read partition metadata");
let fst = meta.fst()
.expect("File system table is invalid");
// Find a file by path and read it into a string.
if let Some((_, node)) = fst.find("/MP3/Worlds.txt") {
let mut s = String::new();
partition
.open_file(node)
.expect("Failed to open file stream")
.read_to_string(&mut s)
.expect("Failed to read file");
println!("{}", s);
2021-08-23 13:48:35 +00:00
}
```
Converting a disc image to raw ISO:
```rust
// Enable `rebuild_encryption` to ensure the output is a valid ISO.
let options = nod::OpenOptions { rebuild_encryption: true, ..Default::default() };
let mut disc = nod::Disc::new_with_options("path/to/file.rvz", &options)
.expect("Failed to open disc");
// Read directly from the open disc and write to the output file.
let mut out = std::fs::File::create("output.iso")
.expect("Failed to create output file");
std::io::copy(&mut disc, &mut out)
.expect("Failed to write data");
```
## License
2021-08-23 13:48:35 +00:00
Licensed under either of
2024-09-11 05:19:19 +00:00
- Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or <http://www.apache.org/licenses/LICENSE-2.0>)
- MIT license ([LICENSE-MIT](LICENSE-MIT) or <http://opensource.org/licenses/MIT>)
2021-08-23 13:48:35 +00:00
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.