0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/deps/npm/node_modules/tar
2013-03-28 11:35:12 -07:00
..
examples npm: Upgrade to v1.1.69 2012-12-12 14:41:28 -08:00
lib npm: Upgrade to v1.1.69 2012-12-12 14:41:28 -08:00
test npm: Upgrade to v1.2.15 2013-03-28 11:35:12 -07:00
.npmignore npm: Upgrade to v1.2.10 2013-02-06 08:39:31 -08:00
.travis.yml npm 1.1.0-beta-2 2011-12-14 14:17:16 -08:00
LICENCE npm: Upgrade to v1.1.69 2012-12-12 14:41:28 -08:00
package.json npm: Upgrade to v1.2.15 2013-03-28 11:35:12 -07:00
README.md
tar.js npm: Upgrade to v1.2.10 2013-02-06 08:39:31 -08:00

node-tar

Tar for Node.js.

Goals of this project

  1. Be able to parse and reasonably extract the contents of any tar file created by any program that creates tar files, period.

    At least, this includes every version of:

    • bsdtar
    • gnutar
    • solaris posix tar
    • Joerg Schilling's star ("Schilly tar")
  2. Create tar files that can be extracted by any of the following tar programs:

    • bsdtar/libarchive version 2.6.2
    • gnutar 1.15 and above
    • SunOS Posix tar
    • Joerg Schilling's star ("Schilly tar")
  3. 100% test coverage. Speed is important. Correctness is slightly more important.

  4. Create the kind of tar interface that Node users would want to use.

  5. Satisfy npm's needs for a portable tar implementation with a JavaScript interface.

  6. No excuses. No complaining. No tolerance for failure.

But isn't there already a tar.js?

Yes, there are a few. This one is going to be better, and it will be fanatically maintained, because npm will depend on it.

That's why I need to write it from scratch. Creating and extracting tarballs is such a large part of what npm does, I simply can't have it be a black box any longer.

Didn't you have something already? Where'd it go?

It's in the "old" folder. It's not functional. Don't use it.

It was a useful exploration to learn the issues involved, but like most software of any reasonable complexity, node-tar won't be useful until it's been written at least 3 times.