ncw 0.1.0

Native Instruments NCW audio file format support
Documentation
# Native Instruments NCW Audio File Format

<p>
<a href="https://crates.io/crates/ncw" rel="nofollow noopener noreferrer"><img src="https://img.shields.io/crates/v/ncw.svg" alt="crates.io"></a>
<a href="https://docs.rs/ncw" rel="nofollow noopener noreferrer"><img src="https://img.shields.io/docsrs/ncw" alt="docs.rs"></a>
</p>

## Description

NCW (Native Instruments Compressed Wave) is a lossless compression algorithm developed by Native Instruments which is essentially DPCM and bit truncation.

This library is a zero-dependency Rust-based library to decode NCW files. It serves as part of a wider reverse engineering effort of proprietary audio formats, and this particular library is used in [ni-file](https://github.com/monomadic/ni-file).

This repository also includes an ncw to wav conversion cli tool, `ncw-decode`.

## Requirements

- Rust 1.50 or higher

## Usage

```rust
let input = File::open(&args[1])?;
let mut output = File::create(&args[2])?;
let mut ncw = NcwReader::read(&input)?;

let spec = WavSpec {
		channels: ncw.header.channels,
		sample_rate: ncw.header.sample_rate,
		bits_per_sample: ncw.header.bits_per_sample,
		sample_format: hound::SampleFormat::Int,
};

for sample in ncw.decode_samples()? {
	// save or convert each sample into a file or stream
	dbg!(sample);
}
```

## Utility (ncw-convert)

To install the cli utility, install it from cargo:

```bash
cargo install ncw --package ncw-convert
```

### Usage

Run the program with the following command-line arguments:

```bash
ncw-decode <INPUT> <OUTPUT>
```

- `<INPUT>`: Path to the input NCW file.
- `<OUTPUT>`: Path where the output WAV file will be saved.

## Contribution

To contribute, create a pull request with your proposed changes.