Giter Site home page Giter Site logo

armaldio / fnm Goto Github PK

View Code? Open in Web Editor NEW

This project forked from schniz/fnm

0.0 1.0 0.0 2.72 MB

๐Ÿš€ Fast and simple Node.js version manager, built in Rust

Home Page: https://fnm.vercel.app

License: GNU General Public License v3.0

Shell 16.10% Rust 75.45% Batchfile 1.61% PowerShell 5.50% JavaScript 1.34%

fnm's Introduction

Fast Node Manager (fnm) Amount of downloads GitHub Actions workflow status

๐Ÿš€ Fast and simple Node.js version manager, built in Rust

Blazing fast!

Features

๐ŸŒŽ Cross-platform support (Mac, Windows, Linux)

โœจ Single file, easy installation, instant startup

๐Ÿš€ Built with speed in mind

๐Ÿค” Works with .node-version and .nvmrc files

Installation

Using a script (MacOS/Linux)

๐Ÿ‘‹ Hey, I'm sorry that the automated way does not support Windows yet. Feel free to contribute it! Maybe Chocolatey or Scoop?

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

curl -fsSL https://fnm.vercel.app/install | bash

Upgrade

On OSX, it is a 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.

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

curl -fsSL https://fnm.vercel.app/install | bash -s -- --install-dir "./.fnm" --skip-shell

Manually (OSX/Linux/Windows)

Using Homebrew (OSX)

brew install fnm

Then apply the changes the installer prints, to set up your shell profile.

Using a release binary (Linux/Mac/Windows)

  • Download the latest release binary for your system

  • Make it available globally on PATH environment variable

  • Configure your shell profile:

    • For Bash or Zsh users, add the following to your .bashrc/.zshrc respectively:

      eval "$(fnm env)"
    • For Fish Shell users, create ~/.config/fish/conf.d/fnm.fish add this line to it:

      fnm env | source
    • For PowerShell users, add the following to the end of your profile file::

      fnm env --use-on-cd | Out-String | Invoke-Expression
      • On Windows, the profile is located at ~\Documents\PowerShell\Microsoft.PowerShell_profile.ps1
      • For Mac/Linux, the profile is located at ~/.config/powershell/Microsoft.PowerShell_profile.ps1
    • For WinCMD, aka good old Windows Command Prompt or Batch, fnm is also supported but is not entirely covered. You can set up a startup script and append the following line:

      FOR /f "tokens=*" %i IN ('fnm env --use-on-cd') DO CALL %i
      

Completions

fnm ships its completions with the binary:

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.

Usage

Global Options

fnm [--shell=fish|bash|zsh] [--node-dist-mirror=URI] [--fnm-dir=DIR] [--log-level=quiet|error|info] <command>
  • 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 --fnm-dir="/tmp/fnm" will install and use versions in /tmp/fnm directory

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 .node-version or .nvmrc files located in the current working directory.

fnm install --lts

Installs the latest LTS version of Node

fnm use [VERSION]

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

Flags

  • --install-if-missing โ€” installs the version if it isn't installed yet

fnm current

Display currently activated Node version.

fnm list

Lists the installed Node versions.

fnm list-remote

Lists the Node versions available to download remotely.

fnm uninstall [VERSION]

Uninstalls the node version specified in [VERSION].

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

Prints the required shell commands in order to configure your shell, Bash compliant if can't infer the shell. This command is highly influenced by the global options

Options:

  • --use-on-cd will also output a script that will automatically change the node version if a .node-version/.nvmrc file is found

Contributing

PRs welcome ๐ŸŽ‰

Developing:

# Install Rust
git clone https://github.com/Schniz/fnm.git
cd fnm/
cargo build

Running Binary:

cargo run -- --help # Will behave like `fnm --help`

Running Tests:

cargo test

fnm's People

Contributors

0xflotus avatar adamgs avatar amitdahan avatar bjornua avatar chrisdaley avatar dangdennis avatar dean177 avatar elliottsj avatar folke avatar from-nibly avatar hwartig avatar idkjs avatar jameschensmith avatar jaythomas avatar jletey avatar joliss avatar kazushisan avatar loliee avatar maxjacobson avatar maxknee avatar pavelloz avatar probablykasper avatar ranyitz avatar renovate[bot] avatar schniz avatar tatchi avatar thomsj avatar ulrikstrid avatar vladimyr avatar waldyrious avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.