2011-01-05 16:01:29 +01:00
|
|
|
|
# n
|
|
|
|
|
|
2013-01-18 16:44:01 +01:00
|
|
|
|
Simple flavour of node binary management, no subshells, no profile setup, no convoluted api, just _simple_.
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2013-08-28 05:08:43 +02:00
|
|
|
|
![](https://dsz91cxz97a03.cloudfront.net/4umODgexJb.gif)
|
|
|
|
|
|
2011-01-05 16:01:29 +01:00
|
|
|
|
## Installation
|
|
|
|
|
|
2011-07-08 00:27:38 +02:00
|
|
|
|
$ npm install -g n
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
|
|
|
|
or
|
|
|
|
|
|
|
|
|
|
$ make install
|
|
|
|
|
|
2011-01-21 04:35:00 +01:00
|
|
|
|
### Installing Binaries
|
2011-01-05 16:48:51 +01:00
|
|
|
|
|
2013-01-18 16:44:01 +01:00
|
|
|
|
Install a few nodes:
|
2011-01-05 16:48:51 +01:00
|
|
|
|
|
2013-01-18 16:44:01 +01:00
|
|
|
|
$ n 0.8.14
|
|
|
|
|
$ n 0.8.17
|
|
|
|
|
$ n 0.9.6
|
2011-01-05 16:48:51 +01:00
|
|
|
|
|
2013-01-19 22:25:00 +01:00
|
|
|
|
Type `n` to prompt selection of an installed node. Use the up /
|
|
|
|
|
down arrow to navigate, and press enter or the right arrow to
|
|
|
|
|
select, or ^C to cancel:
|
2011-01-05 16:48:51 +01:00
|
|
|
|
|
|
|
|
|
$ n
|
2011-10-26 22:59:40 +02:00
|
|
|
|
|
2013-01-18 16:44:01 +01:00
|
|
|
|
0.8.14
|
|
|
|
|
ο 0.8.17
|
|
|
|
|
0.9.6
|
2011-01-05 16:48:51 +01:00
|
|
|
|
|
2011-01-22 00:25:07 +01:00
|
|
|
|
Use or install the latest official release:
|
|
|
|
|
|
2012-01-25 12:42:27 +01:00
|
|
|
|
$ n latest
|
|
|
|
|
|
2012-01-28 16:34:26 +01:00
|
|
|
|
Use or install the stable official release:
|
|
|
|
|
|
|
|
|
|
$ n stable
|
|
|
|
|
|
2013-01-18 19:43:44 +01:00
|
|
|
|
Switch to the previous version you were using:
|
|
|
|
|
|
|
|
|
|
$ n prev
|
|
|
|
|
|
2011-01-21 04:35:00 +01:00
|
|
|
|
### Removing Binaries
|
2011-01-05 16:55:56 +01:00
|
|
|
|
|
2011-01-05 17:17:16 +01:00
|
|
|
|
Remove some versions:
|
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
$ n rm 0.9.4 v0.10.0
|
2011-01-05 17:17:16 +01:00
|
|
|
|
|
2011-01-05 17:23:02 +01:00
|
|
|
|
Instead of using `rm` we can simply use `-`:
|
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
$ n - 0.9.4
|
2011-01-05 17:23:02 +01:00
|
|
|
|
|
2011-01-21 04:35:00 +01:00
|
|
|
|
### Binary Usage
|
|
|
|
|
|
2011-01-05 17:43:16 +01:00
|
|
|
|
When running multiple versions of node, we can target
|
|
|
|
|
them directly by asking `n` for the binary path:
|
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
$ n bin 0.9.4
|
|
|
|
|
/usr/local/n/versions/0.9.4/bin/node
|
2011-01-05 17:43:16 +01:00
|
|
|
|
|
2013-01-18 20:19:01 +01:00
|
|
|
|
Or by using a specific version through `n`'s `use` sub-command:
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
$ n use 0.9.4 some.js
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2011-01-05 22:33:28 +01:00
|
|
|
|
with flags:
|
2011-01-05 17:17:16 +01:00
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
$ n as 0.9.4 --debug some.js
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2011-01-05 22:33:28 +01:00
|
|
|
|
## Usage
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2011-01-05 22:33:28 +01:00
|
|
|
|
Output from `n --help`:
|
2011-01-05 16:01:29 +01:00
|
|
|
|
|
2013-07-12 12:25:31 +02:00
|
|
|
|
Usage: n [options] [COMMAND] [args]
|
2013-01-18 16:41:51 +01:00
|
|
|
|
|
|
|
|
|
Commands:
|
|
|
|
|
|
|
|
|
|
n Output versions installed
|
2013-07-12 12:25:31 +02:00
|
|
|
|
n latest Install or activate the latest node release
|
|
|
|
|
n stable Install or activate the latest stable node release
|
|
|
|
|
n <version> Install node <version>
|
2013-01-18 16:41:51 +01:00
|
|
|
|
n use <version> [args ...] Execute node <version> with [args ...]
|
|
|
|
|
n bin <version> Output bin path for <version>
|
|
|
|
|
n rm <version ...> Remove the given version(s)
|
|
|
|
|
n --latest Output the latest node version available
|
|
|
|
|
n --stable Output the latest stable node version available
|
|
|
|
|
n ls Output the versions of node available
|
|
|
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
|
|
-V, --version Output current version of n
|
|
|
|
|
-h, --help Display help information
|
|
|
|
|
|
|
|
|
|
Aliases:
|
|
|
|
|
|
|
|
|
|
which bin
|
|
|
|
|
use as
|
|
|
|
|
list ls
|
|
|
|
|
- rm
|
2011-01-22 00:25:07 +01:00
|
|
|
|
|
2011-01-05 16:08:46 +01:00
|
|
|
|
## Details
|
|
|
|
|
|
|
|
|
|
`n` by default installs node to _/usr/local/n/versions_, from
|
|
|
|
|
which it can see what you have currently installed, and activate previously installed versions of node when `n <version>` is invoked again.
|
|
|
|
|
|
2011-10-26 22:59:40 +02:00
|
|
|
|
Activated nodes are then installed to the prefix _/usr/local_, which of course may be altered via the __N_PREFIX__ environment variable.
|
2011-01-05 16:40:17 +01:00
|
|
|
|
|
2011-01-05 16:08:46 +01:00
|
|
|
|
To alter where `n` operates simply export __N_PREFIX__ to whatever you prefer.
|
|
|
|
|
|
2011-10-26 22:59:40 +02:00
|
|
|
|
## License
|
2011-01-05 14:50:12 +01:00
|
|
|
|
|
|
|
|
|
(The MIT License)
|
|
|
|
|
|
|
|
|
|
Copyright (c) 2010 TJ Holowaychuk <tj@vision-media.ca>
|
|
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
|
a copy of this software and associated documentation files (the
|
|
|
|
|
'Software'), to deal in the Software without restriction, including
|
|
|
|
|
without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
|
distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
|
permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
|
the following conditions:
|
|
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be
|
|
|
|
|
included in all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
2011-10-26 22:59:40 +02:00
|
|
|
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|