#tar-archive #tar #archive #utils #data-file

app splitar

A tool for content-aware splitting of tar files

1 unstable release

0.1.3 Mar 5, 2023
0.1.2 Jun 7, 2022
0.1.1 May 7, 2022
0.1.0 Feb 26, 2022

#37 in #tar-archive

MIT license

24KB
467 lines

Content-aware splitting of tar archives

splitar splits large tar archive, writing each volume as (almost) independent tar archive, never splitting it in the middle of a file.

splitar works in a streaming fashion, never loading into the memory more than necessary.

Features

  • Split tar files, generating valid tar files of limited data size.
  • Reading data from stdin if file is - (writing to stdout is not possible, obviously).
  • Compress filter (or any other kind) for the output.
  • Optionally recreate directory entries for each new volume.
  • Optionally fail when file too large is found.

Limitations

  • While chunks are limited by size, it is the size of contained data, not file output.
  • If the input archive contains file larger than chunk size limit, the output chunk will inevitably contains the entire file, as splitar never splits contained files. You may use option --fail-on-large-file if you want the util to fail on such a file.
  • If a volume contains a hardlink or symlink to file in some previous volume, tar will refuse creating this link if the target does not exists (e.g. it was not unpacked from one of previous volumes).

Installation

splitar is written in Rust, and having the cargo installed, you can install it with cargo install splitar command. No manual installation of any additional dependency is required.

WASM target

You can compile splitar for the wasm32-wasi target.

Links

Dependencies

~9–20MB
~277K SLoC