2011-11-27 01:21:03 +08:00
<!doctype html>
< html >
2013-07-12 23:55:57 +08:00
< title > npm-developers< / title >
2011-11-27 01:21:03 +08:00
< meta http-equiv = "content-type" value = "text/html;utf-8" >
2013-07-12 23:55:57 +08:00
< link rel = "stylesheet" type = "text/css" href = "../../static/style.css" >
2014-04-16 06:31:36 +08:00
< link rel = "canonical" href = "https://www.npmjs.org/doc/misc/npm-developers.html" >
2014-03-20 00:25:40 +08:00
< script async = true src = "../../static/toc.js" > < / script >
2011-11-27 01:21:03 +08:00
< body >
< div id = "wrapper" >
2014-03-20 00:25:40 +08:00
2013-07-12 23:55:57 +08:00
< h1 > < a href = "../misc/npm-developers.html" > npm-developers< / a > < / h1 > < p > Developer Guide< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "description" > DESCRIPTION< / h2 >
2012-08-07 04:07:31 +08:00
< p > So, you' ve decided to use npm to develop (and maybe publish/deploy)
2011-11-27 01:21:03 +08:00
your project.< / p >
< p > Fantastic!< / p >
< p > There are a few things that you need to do above the simple steps
that your users will do to install your program.< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "about-these-documents" > About These Documents< / h2 >
2011-11-27 01:21:03 +08:00
< p > These are man pages. If you install npm, you should be able to
then do < code > man npm-thing< / code > to get the documentation on a particular
topic, or < code > npm help thing< / code > to see the same information.< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "what-is-a-package-" > What is a < code > package< / code > < / h2 >
2011-11-27 01:21:03 +08:00
< p > A package is:< / p >
2014-05-06 09:20:40 +08:00
< ul >
< li > a) a folder containing a program described by a package.json file< / li >
< li > b) a gzipped tarball containing (a)< / li >
< li > c) a url that resolves to (b)< / li >
< li > d) a < code > < name> @< version> < / code > that is published on the registry with (c)< / li >
< li > e) a < code > < name> @< tag> < / code > that points to (d)< / li >
< li > f) a < code > < name> < / code > that has a " latest" tag satisfying (e)< / li >
< li > g) a < code > git< / code > url that, when cloned, results in (a).< / li >
< / ul >
2011-11-27 01:21:03 +08:00
< 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).< / p >
2012-05-06 13:33:06 +08:00
< p > Git urls can be of the form:< / p >
< pre > < code > git://github.com/user/project.git#commit-ish
git+ssh://user@hostname:project.git#commit-ish
git+http://user@hostname/project/blah.git#commit-ish
2014-05-06 09:20:40 +08:00
git+https://user@hostname/project/blah.git#commit-ish
< / code > < / pre > < p > The < code > commit-ish< / code > can be any tag, sha, or branch which can be supplied as
2012-05-06 13:33:06 +08:00
an argument to < code > git checkout< / code > . The default is < code > master< / code > .< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "the-package-json-file" > The package.json File< / h2 >
2011-11-27 01:21:03 +08:00
< p > You need to have a < code > package.json< / code > file in the root of your project to do
much of anything with npm. That is basically the whole interface.< / p >
2014-11-05 07:08:12 +08:00
< p > See < code > < a href = "../files/package.json.html" > < a href = "../files/package.json.html" > package.json(5)< / a > < / a > < / code > for details about what goes in that file. At the very
2011-11-27 01:21:03 +08:00
least, you need:< / p >
2014-05-06 09:20:40 +08:00
< ul >
< li > < p > name:
2011-11-27 01:21:03 +08:00
This should be a string that identifies your project. Please do not
use the name to specify that it runs on node, or is in JavaScript.
2012-08-07 04:07:31 +08:00
You can use the " engines" field to explicitly state the versions of
node (or whatever else) that your program requires, and it' s pretty
2014-05-06 09:20:40 +08:00
well assumed that it' s javascript.< / p >
< p > It does not necessarily need to match your github repository name.< / p >
< p > So, < code > node-foo< / code > and < code > bar-js< / code > are bad names. < code > foo< / code > or < code > bar< / code > are better.< / p >
< / li >
< li > < p > version:
A semver-compatible version.< / p >
< / li >
< li > < p > engines:
2011-11-27 01:21:03 +08:00
Specify the versions of node (or whatever else) that your program
runs on. The node API changes a lot, and there may be bugs or new
2014-05-06 09:20:40 +08:00
functionality that you depend on. Be explicit.< / p >
< / li >
< li > < p > author:
Take some credit.< / p >
< / li >
< li > < p > scripts:
2011-11-27 01:21:03 +08:00
If you have a special compilation or installation script, then you
2014-11-05 07:08:12 +08:00
should put it in the < code > scripts< / code > object. You should definitely have at
2012-08-07 04:07:31 +08:00
least a basic smoke-test command as the " scripts.test" field.
2014-11-05 07:08:12 +08:00
See < a href = "../misc/npm-scripts.html" > < a href = "../misc/npm-scripts.html" > npm-scripts(7)< / a > < / a > .< / p >
2014-05-06 09:20:40 +08:00
< / li >
< li > < p > main:
2011-11-27 01:21:03 +08:00
If you have a single module that serves as the entry point to your
2012-08-07 04:07:31 +08:00
program (like what the " foo" package gives you at require(" foo" )),
2014-05-06 09:20:40 +08:00
then you need to specify that in the " main" field.< / p >
< / li >
< li > < p > directories:
2014-11-05 07:08:12 +08:00
This is an object mapping names to folders. The best ones to include are
" lib" and " doc" , but if you use " man" to specify a folder full of man pages,
2014-05-06 09:20:40 +08:00
they' ll get installed just like these ones.< / p >
< / li >
< / ul >
2011-11-27 01:21:03 +08:00
< p > You can use < code > npm init< / code > in the root of your package in order to get you
2014-11-05 07:08:12 +08:00
started with a pretty basic package.json file. See < code > < a href = "../cli/npm-init.html" > < a href = "../cli/npm-init.html" > npm-init(1)< / a > < / a > < / code > for
2011-11-27 01:21:03 +08:00
more info.< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "keeping-files-out-of-your-package" > Keeping files < em > out< / em > of your package< / h2 >
2012-08-07 04:07:31 +08:00
< p > Use a < code > .npmignore< / code > file to keep stuff out of your package. If there' s
2013-05-31 01:19:45 +08:00
no < code > .npmignore< / code > file, but there < em > is< / em > a < code > .gitignore< / code > file, then npm will
ignore the stuff matched by the < code > .gitignore< / code > file. If you < em > want< / em > to
include something that is excluded by your < code > .gitignore< / code > file, you can
create an empty < code > .npmignore< / code > file to override it.< / p >
2015-01-09 06:37:26 +08:00
< p > < code > .npmignore< / code > files follow the < a href = "http://git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository#Ignoring-Files" > same pattern rules< / a >
as < code > .gitignore< / code > files:< / p >
< ul >
< li > Blank lines or lines starting with < code > #< / code > are ignored.< / li >
< li > Standard glob patterns work.< / li >
< li > You can end patterns with a forward slash < code > /< / code > to specify a directory.< / li >
< li > You can negate a pattern by starting it with an exclamation point < code > !< / code > .< / li >
< / ul >
2013-05-31 01:19:45 +08:00
< p > By default, the following paths and files are ignored, so there' s no
need to add them to < code > .npmignore< / code > explicitly:< / p >
2014-05-06 09:20:40 +08:00
< ul >
< li > < code > .*.swp< / code > < / li >
< li > < code > ._*< / code > < / li >
< li > < code > .DS_Store< / code > < / li >
< li > < code > .git< / code > < / li >
< li > < code > .hg< / code > < / li >
< li > < code > .lock-wscript< / code > < / li >
< li > < code > .svn< / code > < / li >
< li > < code > .wafpickle-*< / code > < / li >
< li > < code > CVS< / code > < / li >
< li > < code > npm-debug.log< / code > < / li >
< / ul >
2013-05-31 01:19:45 +08:00
< p > Additionally, everything in < code > node_modules< / code > is ignored, except for
bundled dependencies. npm automatically handles this for you, so don' t
bother adding < code > node_modules< / code > to < code > .npmignore< / code > .< / p >
< p > The following paths and files are never ignored, so adding them to
< code > .npmignore< / code > is pointless:< / p >
2014-05-06 09:20:40 +08:00
< ul >
< li > < code > package.json< / code > < / li >
2014-11-05 07:08:12 +08:00
< li > < code > < a href = "../../doc/README.html" > < a href = "../../doc/README.html" > README< / a > < / a > .*< / code > < / li >
2014-05-06 09:20:40 +08:00
< / ul >
< h2 id = "link-packages" > Link Packages< / h2 >
2011-11-27 01:21:03 +08:00
< p > < code > npm link< / code > is designed to install a development package and see the
changes in real time without having to keep re-installing it. (You do
need to either re-link or < code > npm rebuild -g< / code > to update compiled packages,
of course.)< / p >
2014-11-05 07:08:12 +08:00
< p > More info at < code > < a href = "../cli/npm-link.html" > < a href = "../cli/npm-link.html" > npm-link(1)< / a > < / a > < / code > .< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "before-publishing-make-sure-your-package-installs-and-works" > Before Publishing: Make Sure Your Package Installs and Works< / h2 >
2011-11-27 01:21:03 +08:00
< p > < strong > This is important.< / strong > < / p >
2012-08-07 04:07:31 +08:00
< p > If you can not install it locally, you' ll have
problems trying to publish it. Or, worse yet, you' ll be able to
publish it, but you' ll be publishing a broken or pointless package.
So don' t do that.< / p >
2011-11-27 01:21:03 +08:00
< p > In the root of your package, do this:< / p >
2014-05-06 09:20:40 +08:00
< pre > < code > npm install . -g
< / code > < / pre > < p > That' ll show you that it' s working. If you' d rather just create a symlink
2011-11-27 01:21:03 +08:00
package that points to your working directory, then do this:< / p >
2014-05-06 09:20:40 +08:00
< pre > < code > npm link
< / code > < / pre > < p > Use < code > npm ls -g< / code > to see if it' s there.< / p >
2011-11-27 01:21:03 +08:00
< p > To test a local install, go into some other folder, and then do:< / p >
< pre > < code > cd ../some-other-folder
2014-05-06 09:20:40 +08:00
npm install ../my-package
< / code > < / pre > < p > to install it locally into the node_modules folder in that other place.< / p >
2012-08-07 04:07:31 +08:00
< p > Then go into the node-repl, and try using require(" my-thing" ) to
bring in your module' s main module.< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "create-a-user-account" > Create a User Account< / h2 >
2011-11-27 01:21:03 +08:00
< p > Create a user with the adduser command. It works like this:< / p >
2014-05-06 09:20:40 +08:00
< pre > < code > npm adduser
< / code > < / pre > < p > and then follow the prompts.< / p >
2014-11-05 07:08:12 +08:00
< p > This is documented better in < a href = "../cli/npm-adduser.html" > < a href = "../cli/npm-adduser.html" > npm-adduser(1)< / a > < / a > .< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "publish-your-package" > Publish your package< / h2 >
2012-08-07 04:07:31 +08:00
< p > This part' s easy. IN the root of your folder, do this:< / p >
2014-05-06 09:20:40 +08:00
< pre > < code > npm publish
< / code > < / pre > < p > You can give publish a url to a tarball, or a filename of a tarball,
2011-11-27 01:21:03 +08:00
or a path to a folder.< / p >
< p > Note that pretty much < strong > everything in that folder will be exposed< / strong >
2011-12-14 10:53:02 +08:00
by default. So, if you have secret stuff in there, use a
< code > .npmignore< / code > file to list out the globs to ignore, or publish
2011-11-27 01:21:03 +08:00
from a fresh checkout.< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "brag-about-it" > Brag about it< / h2 >
2011-11-27 01:21:03 +08:00
< p > Send emails, write blogs, blab in IRC.< / p >
< p > Tell the world how easy it is to install your program!< / p >
2014-05-06 09:20:40 +08:00
< h2 id = "see-also" > SEE ALSO< / h2 >
< ul >
2014-11-05 07:08:12 +08:00
< li > < a href = "../misc/npm-faq.html" > < a href = "../misc/npm-faq.html" > npm-faq(7)< / a > < / a > < / li >
< li > < a href = "../cli/npm.html" > < a href = "../cli/npm.html" > npm(1)< / a > < / a > < / li >
< li > < a href = "../cli/npm-init.html" > < a href = "../cli/npm-init.html" > npm-init(1)< / a > < / a > < / li >
< li > < a href = "../files/package.json.html" > < a href = "../files/package.json.html" > package.json(5)< / a > < / a > < / li >
< li > < a href = "../misc/npm-scripts.html" > < a href = "../misc/npm-scripts.html" > npm-scripts(7)< / a > < / a > < / li >
< li > < a href = "../cli/npm-publish.html" > < a href = "../cli/npm-publish.html" > npm-publish(1)< / a > < / a > < / li >
< li > < a href = "../cli/npm-adduser.html" > < a href = "../cli/npm-adduser.html" > npm-adduser(1)< / a > < / a > < / li >
< li > < a href = "../misc/npm-registry.html" > < a href = "../misc/npm-registry.html" > npm-registry(7)< / a > < / a > < / li >
2014-05-06 09:20:40 +08:00
< / ul >
2011-11-27 01:21:03 +08:00
< / div >
2014-03-20 00:25:40 +08:00
< table border = 0 cellspacing = 0 cellpadding = 0 id = npmlogo >
< tr > < td style = "width:180px;height:10px;background:rgb(237,127,127)" colspan = 18 > < / td > < / tr >
< tr > < td rowspan = 4 style = "width:10px;height:10px;background:rgb(237,127,127)" > < / td > < td style = "width:40px;height:10px;background:#fff" colspan = 4 > < / td > < td style = "width:10px;height:10px;background:rgb(237,127,127)" rowspan = 4 > < / td > < td style = "width:40px;height:10px;background:#fff" colspan = 4 > < / td > < td rowspan = 4 style = "width:10px;height:10px;background:rgb(237,127,127)" > < / td > < td colspan = 6 style = "width:60px;height:10px;background:#fff" > < / td > < td style = "width:10px;height:10px;background:rgb(237,127,127)" rowspan = 4 > < / td > < / tr >
< tr > < td colspan = 2 style = "width:20px;height:30px;background:#fff" rowspan = 3 > < / td > < td style = "width:10px;height:10px;background:rgb(237,127,127)" rowspan = 3 > < / td > < td style = "width:10px;height:10px;background:#fff" rowspan = 3 > < / td > < td style = "width:20px;height:10px;background:#fff" rowspan = 4 colspan = 2 > < / td > < td style = "width:10px;height:20px;background:rgb(237,127,127)" rowspan = 2 > < / td > < td style = "width:10px;height:10px;background:#fff" rowspan = 3 > < / td > < td style = "width:20px;height:10px;background:#fff" rowspan = 3 colspan = 2 > < / td > < td style = "width:10px;height:10px;background:rgb(237,127,127)" rowspan = 3 > < / td > < td style = "width:10px;height:10px;background:#fff" rowspan = 3 > < / td > < td style = "width:10px;height:10px;background:rgb(237,127,127)" rowspan = 3 > < / td > < / tr >
< tr > < td style = "width:10px;height:10px;background:#fff" rowspan = 2 > < / td > < / tr >
< tr > < td style = "width:10px;height:10px;background:#fff" > < / td > < / tr >
< tr > < td style = "width:60px;height:10px;background:rgb(237,127,127)" colspan = 6 > < / td > < td colspan = 10 style = "width:10px;height:10px;background:rgb(237,127,127)" > < / td > < / tr >
< tr > < td colspan = 5 style = "width:50px;height:10px;background:#fff" > < / td > < td style = "width:40px;height:10px;background:rgb(237,127,127)" colspan = 4 > < / td > < td style = "width:90px;height:10px;background:#fff" colspan = 9 > < / td > < / tr >
< / table >
2015-02-06 17:14:25 +08:00
< p id = "footer" > npm-developers — npm@2.5.1< / p >
2014-03-20 00:25:40 +08:00