@zkochan/pnpm
Version:
A fast implementation of npm install
95 lines (64 loc) • 2.9 kB
Markdown
# pnpm
<!-- {.massive-header.-with-tagline} -->
> Performant npm installations
pnpm is a fast implementation of `npm install`. It is loosely based off [ied].

[](https://badge.fury.io/js/pnpm)
[](https://travis-ci.org/rstacruz/pnpm "See test builds")
[](https://ci.appveyor.com/project/zkochan/pnpm/branch/master)
----
> #### :warning: Name change
> The npm package was changed from `pnpm.js` (0.15 and below) to `pnpm`. The old package will no longer be updated. For old users, uninstall the old version and install the new one:
>
> npm uninstall -g pnpm.js
> npm install -g pnpm
----
## Install
Install it via npm.
```
npm install -g pnpm
```
Use `pnpm` in place of `npm`. It overrides `pnpm i` and `pnpm install`—all other commands will passthru to `npm`.
```
pnpm install lodash
```
## Custom registries
pnpm uses whatever npm's configured to use as its registry. See: [custom registries](docs/custom-registries.md).
## Preview release
`pnpm` will stay in `<1.0.0` until it's achieved feature parity with `npm install`. See [roadmap](docs/roadmap.md) for details.
## Benchmark
```
time npm i babel-preset-es2015 browserify chalk debug minimist mkdirp
66.15 real 15.60 user 3.54 sys
```
```
time pnpm i babel-preset-es2015 browserify chalk debug minimist mkdirp
11.04 real 6.85 user 2.85 sys
```
## Design
`pnpm` maintains a flat storage of all your dependencies in `node_modules/.store`. They are then symlinked wherever they're needed.
See [store layout](docs/store-layout.md) for an explanation.
```
.
└─ node_modules/
├─ .store/
│ ├─ chalk@1.1.1/_/
│ │ └─ node_modules/
│ │ ├─ ansi-styles -> ../../../ansi-styles@2.1.0/_
│ │ └─ has-ansi -> ../../../has-ansi@2.0.0/_
│ ├─ ansi-styles@2.1.0/_/
│ └─ has-ansi@2.0.0/_/
└─ chalk -> .store/chalk@1.1.1/_
```
## Prior art
* [Compared to ied](docs/vs-ied.md)
* [Compared to npm](docs/vs-npm.md)
## Thanks
**pnpm** © 2016+, Rico Sta. Cruz. Released under the [MIT] License.<br>
Authored and maintained by Rico Sta. Cruz with help from contributors ([list][contributors]).
> [ricostacruz.com](http://ricostacruz.com) ·
> GitHub [@rstacruz](https://github.com/rstacruz) ·
> Twitter [@rstacruz](https://twitter.com/rstacruz)
[MIT]: http://mit-license.org/
[contributors]: http://github.com/rstacruz/pnpm/contributors
[ied]: https://github.com/alexanderGugel/ied