![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) [![brew](https://img.shields.io/homebrew/v/frum?color=blue)](https://formulae.brew.sh/formula/frum) [![aur](https://img.shields.io/aur/version/frum-bin?color=yellow)](https://aur.archlinux.org/packages/frum-bin)
![usage](./resources/frum.gif)
## Features
- Pure Rust implementation not using `ruby-build`
- Cross-platform support (macOS, Linux)
- Works with `.ruby-version` files
- Auto-Completion
## Goals
- **Blazing-Fast Ruby Installation** - built with speed in mind
- **Cross-Platform** - works on macOS, Linux and (Windows)
### Benchmark
`eval "$(frum init)"` runs about 6 times faster than `eval "$(rbenv init -)"`.
| Command | Mean [ms] | Min [ms] | Max [ms] | Relative |
|:---|---:|---:|---:|---:|
| `eval "$(rbenv init -)"` | 49.5 ± 2.1 | 46.2 | 57.2 | 6.14 ± 0.50 |
| `eval "$(frum init)"` | 8.1 ± 0.7 | 7.0 | 11.8 | 1.00 ± 0.11 |
| `eval "$(frum init)"` (pre-release) | 8.1 ± 0.6 | 7.2 | 11.7 | 1.00 |
| 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](https://github.com/TaKO8Ki/frum/pull/16).
## Installation
### Homebrew (Linux/macOS)
If you’re using Homebrew or Linuxbrew, install the [`frum`](https://formulae.brew.sh/formula/frum) formula. For more information, please see [Install Ruby with Frum](https://mac.install.guide/ruby/14.html) written by Daniel Kehoe.
```
$ brew install frum
```
### Arch Linux
If you’re using Arch Linux, install the [`frum-bin`](https://aur.archlinux.org/packages/frum-bin) or [`frum`](https://aur.archlinux.org/packages/frum) package using your favorite AUR helper.
```
$ yay -S frum-bin
```
### Cargo (Linux/macOS)
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)
- Download the [latest release binary](https://github.com/TaKO8Ki/frum/releases) for your system
- Set the `PATH` environment variable
- Configure your shell profile
## 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
- **--log-level**: The log level of frum commands [default: info] [possible values: quiet, info, error].
- **--ruby-build-mirror**: [default: https://cache.ruby-lang.org/pub/ruby].
- **--frum-dir**: The root directory of frum installations [default: $HOME/.frum]. You can set `frum-dir` as the `$FRUM_DIR` environment variable. I recommend that you use the environment variable if you want to use your customized `frum-dir` globally.
### Subcommands
- **init**: Sets environment variables for initializing frum.
- **install**: Installs the specified Ruby version.
- **-l**, **--list**: Lists the Ruby versions available to install.
- **uninstall**: Uninstall a specific Ruby version.
- **versions**: Lists installed Ruby versions.
- **global**: Sets the global Ruby version.
- **local**: Sets the current Ruby version.
### Ruby configuration options
Options to configure Ruby can be passed to the `frum install` command.
```sh
$ frum install --with-openssl-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
- [Schniz/fnm](https://github.com/Schniz/fnm)