You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Gal Schlezinger 0ec2da0d3d v1.15.0 6 years ago
.ci Fix spelling of availability in install.sh (#132) 6 years ago
docs v1.15.0 6 years ago
esy.lock Alias latest versions on installation (#129) 6 years ago
executable Alias -v to --version, Fixes #126 (#134) 6 years ago
feature_tests Alias latest versions on installation (#129) 6 years ago
library v1.15.0 6 years ago
test Do uninstallation in steps (#138) 6 years ago
windows.esy.lock Successfully build on Windows (#88) 7 years ago
.dockerignore Nsw 7 years ago
.gitignore Rename to fnm (#2) 7 years ago
CHANGELOG.md v1.15.0 6 years ago
Dockerfile Switch to cohttp(lwt) instead of curl (#57) 7 years ago
LICENSE Add a GPL v3 LICENSE file (#22) 7 years ago
README.md Deprecates MacOS installation using the script in favor of Homeb… (#131) 6 years ago
azure-pipelines.yml Successfully build on Windows (#88) 7 years ago
dune initial 7 years ago
dune-project Rename to fnm (#2) 7 years ago
fnm.opam Rename to fnm (#2) 7 years ago
package.json v1.15.0 6 years ago
windows.json Fix Windows build once again! (#133) 6 years ago

README.md

Fast Node Manager (fnm) Amount of downloads Build Status

🚀 Fast and simple Node.js version manager, built in native ReasonML

Blazing fast!

Features

Single file, easy installation, instant startup

🚀 Built with speed in mind

🤔 Works with .nvmrc and .node-version files

Installation

Using Homebrew (OSX)

brew install Schniz/tap/fnm

This is a custom tap I'm maintaining, and will be used until fnm will move to the official one.

Using a script

For bash, zsh and fish shells, there's an automatic installation script:

curl -fsSL https://github.com/Schniz/fnm/raw/master/.ci/install.sh | bash

Upgrade

Upgrading fnm is almost the same as installing it. To prevent duplication in your shell config file add --skip-shell to install command.

Parameters

--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/config.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:

curl -fsSL https://github.com/Schniz/fnm/raw/master/.ci/install.sh | bash -s -- --install-dir "./.fnm" --skip-shell

Manually

  • Download the latest release binary for your system

  • Make it available globally on $PATH

  • Add the following line to your .bashrc/.zshrc file:

    eval "`fnm env --multi`"
    

    If you are using fish shell, add this line to your config.fish file:

    fnm env --multi | source
    

Usage

You can always use fnm --help to read the docs:

fnm install [VERSION]

Installs [VERSION]. If no version provided, it will install the version specified in the .nvmrc file located in the current working directory.

fnm use [VERSION]

Activates [VERSION] as the current Node version. If no version provided, it will activate the version specified in the .nvmrc or .node-version file located in the current working directory.

fnm ls

Lists the installed Node versions.

fnm ls-remote

Lists the Node versions available to download remotely.

fnm alias [VERSION] [NAME]

Aliases a Node version to a given name.

fnm default [VERSION]

Aliases a Node version as default. Uses fnm alias underneath.

fnm env [--multi] [--shell=fish|bash|zsh] [--node-dist-mirror=URI] [--use-on-cd] [--base-dir=DIR] [--log-level=quiet|error|all]

Prints the required shell commands in order to configure your shell, Bash compliant by default.

  • Providing --multi will output the multishell support, allowing a different current Node version per shell
  • Providing --shell=fish will output the Fish-compliant version. Omitting it and fnm will try to infer the current shell based on the process tree
  • Providing --node-dist-mirror="https://npm.taobao.org/dist" will use the Chinese mirror of Node.js
  • Providing --use-on-cd will also output a script that will automatically change the node version if a .nvmrc/.node-version file is found
  • Providing --base-dir="/tmp/fnm" will install and use versions in /tmp/fnm directory

Future Plans

  • Feature: fnm use --install
  • Feature: fnm install lts?
  • Windows Support?
  • Linux: Replace tar with a statically linked library too (for ungzip + untar)

Contributing

PRs welcome 🎉

Developing:

npm install -g esy
git clone https://github.com/Schniz/fnm.git
cd fnm/
esy install
esy bootstrap
esy build

Running Binary:

After building the project, you can run the main binary that is produced.

esy x fnm.exe

Running Tests:

# Runs some smoke-unity test
esy test

# Runs the feature tests
feature_tests/run.sh