. \" Generated with Ronnjs 0.3.8
. \" http://github.com/kapouer/ronnjs/
.
.TH "NPM\-INSTALL" "1" "April 2013" "" ""
.
.SH "NAME"
\fB npm-install\fR \- \- Install a package
.
.SH "SYNOPSIS"
.
.nf
npm install (with no args in a package dir)
npm install <tarball file>
npm install <tarball url>
npm install <folder>
npm install <name> [\- \- save|\- \- save\- dev|\- \- save\- optional]
npm install <name>@<tag>
npm install <name>@<version>
npm install <name>@<version range>
npm install <name>@<version range>
.
.fi
.
.SH "DESCRIPTION"
This command installs a package, and any packages that it depends on\. If the
package has a shrinkwrap file, the installation of dependencies will be driven
by that\. See npm help shrinkwrap\.
.
.P
A \fB package\fR is:
.
.IP "\(bu" 4
a) a folder containing a program described by a package\. json file
.
.IP "\(bu" 4
b) a gzipped tarball containing (a)
.
.IP "\(bu" 4
c) a url that resolves to (b)
.
.IP "\(bu" 4
d) a \fB <name>@<version>\fR that is published on the registry with (c)
.
.IP "\(bu" 4
e) a \fB <name>@<tag>\fR that points to (d)
.
.IP "\(bu" 4
f) a \fB <name>\fR that has a "latest" tag satisfying (e)
.
.IP "\(bu" 4
g) a \fB <git remote url>\fR that resolves to (b)
.
.IP "" 0
.
.P
Even if you never publish your package, you can still get a lot of
benefits of using npm if you just want to write a node program (a), and
perhaps if you also want to be able to easily install it elsewhere
after packing it up into a tarball (b)\.
.
.IP "\(bu" 4
\fB npm install\fR (in package directory, no arguments):
.
.IP
Install the dependencies in the local node_modules folder\.
.
.IP
In global mode (ie, with \fB \- g\fR or \fB \- \- global\fR appended to the command),
it installs the current package context (ie, the current working
directory) as a global package\.
.
.IP "\(bu" 4
\fB npm install <folder>\fR :
.
.IP
Install a package that is sitting in a folder on the filesystem\.
.
.IP "\(bu" 4
\fB npm install <tarball file>\fR :
.
.IP
Install a package that is sitting on the filesystem\. Note: if you just want
to link a dev directory into your npm root, you can do this more easily by
using \fB npm link\fR \| \.
.
.IP
Example:
.
.IP "" 4
.
.nf
npm install \. /package\. tgz
.
.fi
.
.IP "" 0
.
.IP "\(bu" 4
\fB npm install <tarball url>\fR :
.
.IP
Fetch the tarball url, and then install it\. In order to distinguish between
this and other options, the argument must start with "http://" or "https://"
.
.IP
Example:
.
.IP "" 4
.
.nf
npm install https://github\. com/indexzero/forever/tarball/v0\. 5\. 6
.
.fi
.
.IP "" 0
.
.IP "\(bu" 4
\fB npm install <name> [\- \- save|\- \- save\- dev|\- \- save\- optional]\fR :
.
.IP
Do a \fB <name>@<tag>\fR install, where \fB <tag>\fR is the "tag" config\. (See \fB npm help config\fR \| \. )
.
.IP
In most cases, this will install the latest version
of the module published on npm\.
.
.IP
Example:
.
.IP
npm install sax
.
.IP
\fB npm install\fR takes 3 exclusive, optional flags which save or update
the package version in your main package\. json:
.
.IP "\(bu" 4
\fB \- \- save\fR : Package will appear in your \fB dependencies\fR \| \.
.
.IP "\(bu" 4
\fB \- \- save\- dev\fR : Package will appear in your \fB devDependencies\fR \| \.
.
.IP "\(bu" 4
\fB \- \- save\- optional\fR : Package will appear in your \fB optionalDependencies\fR \| \.
.
.IP
Examples:
.
.IP
npm install sax \- \- save
npm install node\- tap \- \- save\- dev
npm install dtrace\- provider \- \- save\- optional
.
.IP
\fB Note\fR : If there is a file or folder named \fB <name>\fR in the current
working directory, then it will try to install that, and only try to
fetch the package by name if it is not valid\.
.
.IP "" 0
.
.IP "\(bu" 4
\fB npm install <name>@<tag>\fR :
.
.IP
Install the version of the package that is referenced by the specified tag\.
If the tag does not exist in the registry data for that package, then this
will fail\.
.
.IP
Example:
.
.IP "" 4
.
.nf
npm install sax@latest
.
.fi
.
.IP "" 0
.
.IP "\(bu" 4
\fB npm install <name>@<version>\fR :
.
.IP
Install the specified version of the package\. This will fail if the version
has not been published to the registry\.
.
.IP
Example:
.
.IP "" 4
.
.nf
npm install sax@0\. 1\. 1
.
.fi
.
.IP "" 0
.
.IP "\(bu" 4
\fB npm install <name>@<version range>\fR :
.
.IP
Install a version of the package matching the specified version range\. This
will follow the same rules for resolving dependencies described in \fB npm help json\fR \| \.
.
.IP
Note that most version ranges must be put in quotes so that your shell will
treat it as a single argument\.
.
.IP
Example:
.
.IP
npm install sax@">=0\. 1\. 0 <0\. 2\. 0"
.
.IP "\(bu" 4
\fB npm install <git remote url>\fR :
.
.IP
Install a package by cloning a git remote url\. The format of the git
url is:
.
.IP
<protocol>://[<user>@]<hostname><separator><path>[#<commit\- ish>]
.
.IP
\fB <protocol>\fR is one of \fB git\fR , \fB git+ssh\fR , \fB git+http\fR , or \fB git+https\fR \| \. If no \fB <commit\- ish>\fR is specified, then \fB master\fR is
used\.
.
.IP
Examples:
.
.IP "" 4
.
.nf
git+ssh://git@github\. com:isaacs/npm\. git#v1\. 0\. 27
git+https://isaacs@github\. com/isaacs/npm\. git
git://github\. com/isaacs/npm\. git#v1\. 0\. 27
.
.fi
.
.IP "" 0
.
.IP "" 0
.
.P
You may combine multiple arguments, and even multiple types of arguments\.
For example:
.
.IP "" 4
.
.nf
npm install sax@">=0\. 1\. 0 <0\. 2\. 0" bench supervisor
.
.fi
.
.IP "" 0
.
.P
The \fB \- \- tag\fR argument will apply to all of the specified install targets\.
.
.P
The \fB \- \- force\fR argument will force npm to fetch remote resources even if a
local copy exists on disk\.
.
.IP "" 4
.
.nf
npm install sax \- \- force
.
.fi
.
.IP "" 0
.
.P
The \fB \- \- global\fR argument will cause npm to install the package globally
rather than locally\. See \fB npm help folders\fR \| \.
.
.P
The \fB \- \- link\fR argument will cause npm to link global installs into the
local space in some cases\.
.
.P
The \fB \- \- no\- bin\- links\fR argument will prevent npm from creating symlinks for
any binaries the package might contain\.
.
.P
See \fB npm help config\fR \| \. Many of the configuration params have some
effect on installation, since that\' s most of what npm does\.
.
.SH "ALGORITHM"
To install a package, npm uses the following algorithm:
.
.IP "" 4
.
.nf
install(where, what, family, ancestors)
fetch what, unpack to <where>/node_modules/<what>
for each dep in what\. dependencies
resolve dep to precise version
for each dep@version in what\. dependencies
not in <where>/node_modules/<what>/node_modules/*
and not in <family>
add precise version deps to <family>
install(<where>/node_modules/<what>, dep, family)
.
.fi
.
.IP "" 0
.
.P
For this \fB package{dep}\fR structure: \fB A{B,C}, B{C}, C{D}\fR ,
this algorithm produces:
.
.IP "" 4
.
.nf
A
+\- \- B
`\- \- C
`\- \- D
.
.fi
.
.IP "" 0
.
.P
That is, the dependency from B to C is satisfied by the fact that A
already caused C to be installed at a higher level\.
.
.P
See npm help folders for a more detailed description of the specific
folder structures that npm creates\.
.
.SS "Limitations of npm's Install Algorithm"
There are some very rare and pathological edge\- cases where a cycle can
cause npm to try to install a never\- ending tree of packages\. Here is
the simplest case:
.
.IP "" 4
.
.nf
A \- > B \- > A\' \- > B\' \- > A \- > B \- > A\' \- > B\' \- > A \- > \. \. \.
.
.fi
.
.IP "" 0
.
.P
where \fB A\fR is some version of a package, and \fB A\' \fR is a different version
of the same package\. Because \fB B\fR depends on a different version of \fB A\fR
than the one that is already in the tree, it must install a separate
copy\. The same is true of \fB A\' \fR , which must install \fB B\' \fR \| \. Because \fB B\' \fR
depends on the original version of \fB A\fR , which has been overridden, the
cycle falls into infinite regress\.
.
.P
To avoid this situation, npm flat\- out refuses to install any \fB name@version\fR that is already present anywhere in the tree of package
folder ancestors\. A more correct, but more complex, solution would be
to symlink the existing version into the new location\. If this ever
affects a real use\- case, it will be investigated\.
.
.SH "SEE ALSO"
.
.IP "\(bu" 4
npm help folders
.
.IP "\(bu" 4
npm help update
.
.IP "\(bu" 4
npm help link
.
.IP "\(bu" 4
npm help rebuild
.
.IP "\(bu" 4
npm help scripts
.
.IP "\(bu" 4
npm help build
.
.IP "\(bu" 4
npm help config
.
.IP "\(bu" 4
npm help registry
.
.IP "\(bu" 4
npm help folders
.
.IP "\(bu" 4
npm help tag
.
.IP "\(bu" 4
npm help rm
.
.IP "\(bu" 4
npm help shrinkwrap
.
.IP "" 0