
Fixes #687. If "-" is passed as a filename, decompress data from stdin. Currently `--format` must be passed as well, but as a next step, we could try to infer the format from magic numbers. As stdin is not connected to the terminal, we cannot prompt for Y/N when warning about decompression in memory, for e.g. zip. Just default to No, and require passing "-y" in these cases. For zip, we have to buffer the whole stream in memory to seek into it, just as we do with a chained decoder like `.zip.bz`. The rar format requires an actual file (not an `impl Read`), so we write a temp file that it can decode. When decoding a single-file archive (e.g. file.bz), the output filename is just `-`, since we don't know the original filename. I had to add a bit of a hack to the tests to work around this. Another option would be to interpret "-d" as a destination filename in this case. When decoding a multi-file archive, I decided to unpack directly into the destination directory, as this seemed like a better experience than adding a top-level "-" folder inside the destination.
Ouch!
ouch
stands for Obvious Unified Compression Helper.
It's a CLI tool for compressing and decompressing for various formats.
Features
- Easy to use.
- Fast.
- Great error message feedback.
- No runtime dependencies required (for Linux x86_64).
- Accessibility mode (see more).
- Shell completions and man pages.
Usage
Ouch has three main subcommands:
ouch decompress
(aliasd
)ouch compress
(aliasc
)ouch list
(aliasl
orls
)
To see help
for a specific command:
ouch help <COMMAND>
ouch <COMMAND> --help # equivalent
Decompressing
Use the decompress
subcommand, ouch
will detect the extensions automatically.
ouch decompress a.zip
# Decompress multiple files
ouch decompress a.zip b.tar.gz c.tar
The -d/--dir
flag can be used to redirect decompression results to another directory.
# Decompress 'summer_vacation.zip' inside of new folder 'pictures'
ouch decompress summer_vacation.zip --dir pictures
Compressing
Pass input files to the compress
subcommand, add the output file at the end.
# Compress two files into `archive.zip`
ouch compress one.txt two.txt archive.zip
# Compress file.txt using .lz4 and .zst
ouch compress file.txt file.txt.lz4.zst
ouch
detects the extensions of the output file to decide what formats to use.
Listing
ouch list archive.zip
# Example with tree formatting
ouch list source-code.zip --tree
Output:
└── src
├── archive
│ ├── mod.rs
│ ├── tar.rs
│ └── zip.rs
├── utils
│ ├── colors.rs
│ ├── formatting.rs
│ ├── mod.rs
│ └── fs.rs
├── commands
│ ├── list.rs
│ ├── compress.rs
│ ├── decompress.rs
│ └── mod.rs
├── accessible.rs
├── error.rs
├── cli.rs
└── main.rs
Supported formats
Format | .tar |
.zip |
7z |
.gz |
.xz , .lzma |
.bz , .bz2 |
.lz4 |
.sz (Snappy) |
.zst |
.rar |
---|---|---|---|---|---|---|---|---|---|---|
Supported | ✓ | ✓¹ | ✓¹ | ✓² | ✓ | ✓ | ✓ | ✓² | ✓² | ✓³ |
✓: Supports compression and decompression.
✓¹: Due to limitations of the compression format itself, (de)compression can't be done with streaming.
✓²: Supported, and compression runs in parallel.
✓³: Due to RAR's restrictive license, only decompression and listing can be supported.
If you wish to exclude non-free code from your build, you can disable RAR support
by building without the unrar
feature.
tar
aliases are also supported: tgz
, tbz
, tbz2
, tlz4
, txz
, tlzma
, tsz
, tzst
.
Formats can be chained:
.tar.gz
.tar.gz.xz.zst.gz.lz4.sz
If the filename has no extensions, Ouch
will try to infer the format by the file signature and ask the user for confirmation.
Installation
On Arch Linux
pacman -S ouch
On Windows via Scoop
scoop install ouch
From crates.io
cargo install ouch
Download the latest release bundle
Check the releases page.
Compiling from source code
Check the wiki guide on compiling.
Runtime Dependencies
If running ouch
results in a linking error, it means you're missing a runtime dependency.
If you're downloading binaries from the releases page, try the musl
variants, those are static binaries that require no runtime dependencies.
Otherwise, you'll need these libraries installed on your system:
These should be available in your system's package manager.
Benchmarks
Benchmark results are available here. Performance of compressing and decompressing Rust source code are measured and compared with Hyperfine. The values presented are the average (wall clock) elapsed time.
Note: ouch
focuses heavily on usage ergonomics and nice error messages, but
we plan on doing some optimization in the future.
Versions used:
Contributing
ouch
is made out of voluntary work, contributors are very welcome! Contributions of all sizes are appreciated.
- Open an issue.
- Package it for your favorite distribution or package manager.
- Share it with a friend!
- Open a pull request.
If you're creating a Pull Request, check CONTRIBUTING.md.