![frum](./resources/logo.png) 🏃‍♂️ A little bit fast and modern Ruby version manager written in Rust [![github workflow status](https://img.shields.io/github/workflow/status/TaKO8Ki/frum/CI/main)](https://github.com/TaKO8Ki/frum/actions) [![crates](https://img.shields.io/crates/v/frum.svg?logo=rust)](https://crates.io/crates/frum) ![usage](./resources/frum.gif)

Features

Goals

Benchmark

| Command | Mean [ms] | Min [ms] | Max [ms] | Relative | |:---|---:|---:|---:|---:| | rbenv | 239628.1 ± 2030.2 | 237681.6 | 245162.6 | 1.04 ± 0.01 | | frum | 232944.6 ± 1224.0 | 230565.4 | 234863.5 | 1.01 ± 0.01 | | frum(pre-release) | 230366.5 ± 882.7 | 228454.2 | 232340.5 | 1.00 |

For more information, please see #16.

Installation

Homebrew

If you’re using Homebrew on macOS, install the frum formula. For more information, please see Install Ruby with Frum written by Daniel Kehoe.

$ brew install frum

Arch Linux

If you’re using Arch Linux, install the frum-bin package using your favorite AUR helper.

$ yay -S frum-bin

Cargo

If you already have a Rust environment set up, you can use the cargo install command:

$ cargo install frum

Using a release binary (Linux/macOS)

Usage

Shell Setup

You need to run some shell commands before using frum. All you have to do is evaluate the output of frum init. Check out the following guides for the shell you use:

Bash

add the following to your .bashrc:

bash eval "$(frum init)"

Zsh

add the following to your .zshrc:

zsh eval "$(frum init)"

Fish shell

create ~/.config/fish/conf.d/frum.fish add this line to it:

fish frum init | source

Options

Subcommands

Ruby configuration options

Options to configure Ruby can be passed to the frum install command.

sh $ frum install --with-openssl-dir=<ssl_dir> # Specify the OpenSSL directory $ frum install --with-jemalloc # Use jemalloc as allocator

You can also specify many other options that will be listed when running ./configure -h.

Contribution

Contributions, issues and pull requests are welcome!

Reference