JSPM

  • Created
  • Published
  • Downloads 27527052
  • Score
    100M100P100Q232468F

filesystem bindings for tar-stream

Package Exports

  • tar-fs

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (tar-fs) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

tar-fs

filesystem bindings for tar-stream.

npm install tar-fs

build status

Usage

tar-fs allows you to pack directories into tarballs and extract tarballs into directories.

var tar = require('tar-fs');
var fs = require('fs');

// packing a directory
tar.pack('./my-directory').pipe(fs.createWriteStream('my-tarball.tar'));

// extracting a directory
fs.createReadStream('my-other-tarball.tar').pipe(tar.extract('./my-other-directory'));

To ignore various files when packing or extracting add a ignore function to the options

var pack = tar.pack('./my-directory', {
    ignore: function(name) {
        return path.extname(name) === '.bin'; // ignore .bin files when packing
    }
});

var extract = tar.extract('./my-other-directory', {
    ignore: function(name) {
        return path.extname(name) === '.bin'; // ignore .bin files inside the tarball when extracing
    }
});

Set options.fmode and options.dmode to ensure that files/directories extracted have the corresponding modes

var extract = tar.extract('./my-directory', {
    dmode: 0555, // all dirs and files should be readable
    fmode: 0444
});

This is useful when the tarball was created on windows (which can result in dirs not being readable)

Copy a directory

Copying a directory with permissions and mtime intact is as simple as

tar.pack('source-directory').pipe(tar.extract('dest-directory'));

Performance

Packing and extracting a 6.1 GB with 2496 directories and 2398 files yields the following results on my Macbook Air. See the benchmark here

  • tar-fs: 34.261 ms
  • node-tar: 366.123 ms (or 10x slower)

License

MIT