Tar for Node.js.



See examples/ for usage examples.

var tar = require('tar')

Returns an object with .Pack, .Extract and .Parse methods.


Returns a through stream. Use fstream to write files into the pack stream and you will receive tar archive data from the pack stream.

The optional properties object are used to set properties in the tar 'Global Extended Header'.


Returns a through stream. Write tar data to the stream and the files in the tarball will be extracted onto the filesystem.

options can be:

  path: '/path/to/extract/tar/into',
  strip: 0, // how many path segments to strip from the root when extracting

options also get passed to the fstream.Writer instance that tar uses internally.


Returns a writable stream. Write tar data to it and it will emit entry events for each entry parsed from the tarball. This is used by tar.Extract.