fnm
)
:rocket: Fast and simple Node.js version manager, built in Rust
:earth_americas: Cross-platform support (macOS, Windows, Linux)
:sparkles: Single file, easy installation, instant startup
:rocket: Built with speed in mind
:thinking: Works with .node-version
and .nvmrc
files
For bash
, zsh
and fish
shells, there's an automatic installation script:
sh
curl -fsSL https://fnm.vercel.app/install | bash
On macOS, it is as simple as brew upgrade fnm
.
On other operating systems, upgrading fnm
is almost the same as installing it. To prevent duplication in your shell config file add --skip-shell
to install command.
--install-dir
Set a custom directory for fnm to be installed. The default is $HOME/.fnm
.
--skip-shell
Skip appending shell specific loader to shell config file, based on the current user shell, defined in $SHELL
. e.g. for Bash, $HOME/.bashrc
. $HOME/.zshrc
for Zsh. For Fish - $HOME/.config/fish/conf.d/fnm.fish
--force-install
macOS installations using the installation script are deprecated in favor of the Homebrew formula, but this forces the script to install using it anyway.
Example:
sh
curl -fsSL https://fnm.vercel.app/install | bash -s -- --install-dir "./.fnm" --skip-shell
sh
brew install fnm
Then, set up your shell for fnm
sh
scoop install fnm
Then, set up your shell for fnm
sh
cargo install fnm
Then, set up your shell for fnm
PATH
environment variableTo remove fnm (😢), just delete the .fnm
folder in your home directory. You should also edit your shell configuration to remove any references to fnm (ie. read Shell Setup, and do the opposite).
fnm ships its completions with the binary:
sh
fnm completions --shell <SHELL>
Where <SHELL>
can be one of the supported shells:
bash
zsh
fish
powershell
Please follow your shell instructions to install them.
fnm needs to run some shell commands before you can start using it.
This is done by evaluating the output of fnm env
. Check out the following guides for the shell you use:
add the following to your .bashrc
profile:
bash
eval "$(fnm env)"
add the following to your .zshrc
profile:
zsh
eval "$(fnm env)"
create ~/.config/fish/conf.d/fnm.fish
add this line to it:
fish
fnm env | source
Before adding any configuration to your shell, you'd need to enable symlink support for a standard accounts (non-administrator).
You can do it by enabling Developer Mode, or updating the Local Security Policy.
Open Local Security Policy
(secpol.msc
) and go to Local Policies
-> User Rights Assignment
, select Create symbolic links
, add your user to the list and reboot.
Use
whoami
if you are not sure what's your user name.
Add the following to the end of your profile file:
powershell
fnm env --use-on-cd | Out-String | Invoke-Expression
~\Documents\PowerShell\Microsoft.PowerShell_profile.ps1
or $PROFILE
~/.config/powershell/Microsoft.PowerShell_profile.ps1
fnm is also supported but is not entirely covered. You can set up a startup script and append the following line:
batch
FOR /f "tokens=*" %i IN ('fnm env --use-on-cd') DO CALL %i
See the available commands for an extended usage documentation
PRs welcome :tada:
```sh
git clone https://github.com/Schniz/fnm.git cd fnm/ cargo build ```
sh
cargo run -- --help # Will behave like `fnm --help`
sh
cargo test