Git Product home page Git Product logo

frum's Introduction

frum

A little bit fast and modern Ruby version manager written in Rust

github workflow status crates brew aur

usage

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.

Installation

Homebrew (Linux/macOS)

If you’re using Homebrew or Linuxbrew, 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 or 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 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:

eval "$(frum init)"

Zsh

add the following to your .zshrc:

eval "$(frum init)"

Fish shell

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

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.

$ 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

frum's People

Contributors

br1ght0ne avatar citizen428 avatar danielkehoe avatar jonian avatar kenoss avatar tako8ki avatar vladimyr avatar wezm 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.