2023-11-07 18:13:12 +01:00
|
|
|
= ruby-build(1)
|
|
|
|
Mislav Marohnić
|
|
|
|
:doctype: manpage
|
|
|
|
:man manual: ruby-build Manual
|
|
|
|
:man source: ruby-build {version}
|
|
|
|
:man-linkstyle: pass:[blue R < >]
|
|
|
|
|
|
|
|
== Name
|
|
|
|
|
2023-11-08 23:48:51 +01:00
|
|
|
ruby-build - Download, compile, and install a version of Ruby
|
2023-11-07 18:13:12 +01:00
|
|
|
|
|
|
|
== Synopsis
|
|
|
|
|
2024-09-23 18:00:15 +02:00
|
|
|
ruby-build [-dvpk] _<definition>_ _<prefix>_ [-- _<configure-args>_...] +
|
2023-11-07 18:13:12 +01:00
|
|
|
ruby-build {--list|--definitions} +
|
|
|
|
ruby-build --version
|
|
|
|
|
|
|
|
== Description
|
|
|
|
|
|
|
|
ruby-build downloads, compiles, and installs a Ruby version named by the
|
2023-11-08 23:48:51 +01:00
|
|
|
_definition_ argument into the location specified by _prefix_.
|
2023-11-07 18:13:12 +01:00
|
|
|
|
2024-09-23 19:15:29 +02:00
|
|
|
The _definition_ argument can optionally start with "ruby-", in which case
|
|
|
|
it resolves to a CRuby that matches the version number that follows.
|
|
|
|
|
2023-11-07 18:13:12 +01:00
|
|
|
The _definition_ argument can be a path to a file on disk, in which case
|
|
|
|
it is sourced into ruby-build as a bash script.
|
|
|
|
|
2023-11-08 23:48:51 +01:00
|
|
|
Optionally, extra Ruby _configure-args_ may be listed after "--" and
|
|
|
|
will get forwarded to the `./configure` invocation.
|
|
|
|
|
|
|
|
By default, all compile output is redirected to a log file at
|
|
|
|
`$TMPDIR/ruby-build.*.log`. Activate the verbose mode to skip the log file
|
2023-11-07 18:13:12 +01:00
|
|
|
and print everything to standard streams.
|
|
|
|
|
2023-11-08 23:48:51 +01:00
|
|
|
== Options
|
|
|
|
|
|
|
|
*-l, --list*::
|
|
|
|
List latest stable releases for each Ruby
|
|
|
|
|
|
|
|
*--definitions*::
|
|
|
|
List all local definitions, including outdated ones
|
|
|
|
|
|
|
|
*--version*::
|
|
|
|
Show version of ruby-build
|
|
|
|
|
2024-09-23 18:00:15 +02:00
|
|
|
*-d, --dir*::
|
|
|
|
Install the Ruby in the _prefix/definition_ destination instead of directly in _prefix_
|
|
|
|
|
2023-11-08 23:48:51 +01:00
|
|
|
*-v, --verbose*::
|
|
|
|
Verbose mode: forward all build output to stdout/stderr
|
|
|
|
|
|
|
|
*-p, --patch*::
|
|
|
|
Apply a patch from stdin before building
|
|
|
|
|
|
|
|
*-k, --keep*::
|
|
|
|
Do not remove source tree after installation
|
|
|
|
|
|
|
|
*-4, --ipv4*::
|
|
|
|
Resolve names to IPv4 addresses only
|
|
|
|
|
|
|
|
*-6, --ipv6*::
|
|
|
|
Resolve names to IPv6 addresses only
|
|
|
|
|
|
|
|
== Examples
|
|
|
|
|
2024-09-23 19:15:29 +02:00
|
|
|
Install a Ruby version while tweaking some configuration options:
|
|
|
|
----
|
|
|
|
$ ruby-build 3.2.2 /path/to/destination -- --disable-install-doc --with-openssl-dir=/opt/openssl
|
|
|
|
----
|
|
|
|
|
|
|
|
Install a Ruby version to `~/.rubies/ruby-3.2.2`:
|
2023-11-08 23:48:51 +01:00
|
|
|
----
|
2024-09-23 19:15:29 +02:00
|
|
|
$ ruby-build --dir ruby-3.2.2 ~/.rubies
|
2023-11-08 23:48:51 +01:00
|
|
|
----
|
|
|
|
|
2024-09-23 19:15:29 +02:00
|
|
|
Install a Ruby version to `~/.rbenv/versions/3.3.5`:
|
2024-09-23 18:00:15 +02:00
|
|
|
----
|
|
|
|
$ ruby-build --dir 3.3.5 ~/.rbenv/versions
|
|
|
|
----
|
|
|
|
|
2024-09-23 19:15:29 +02:00
|
|
|
Usage as rbenv plugin, accomplishes the same as the previous example:
|
2023-11-08 23:48:51 +01:00
|
|
|
----
|
2024-09-23 19:15:29 +02:00
|
|
|
$ rbenv install 3.3.5
|
2023-11-08 23:48:51 +01:00
|
|
|
----
|
|
|
|
|
2023-11-07 18:13:12 +01:00
|
|
|
== Environment Variables
|
|
|
|
|
|
|
|
*TMPDIR*::
|
|
|
|
The location to write temporary files on disk
|
|
|
|
|
|
|
|
*RUBY_BUILD_BUILD_PATH* (default: a timestamped subdirectory of _TMPDIR_)::
|
|
|
|
The build location for downloading source files to and compiling
|
|
|
|
|
|
|
|
*RUBY_BUILD_CACHE_PATH* (default: "~/.rbenv/cache" if invoked as rbenv plugin)::
|
|
|
|
Where to cache downloaded package files
|
|
|
|
|
|
|
|
*RUBY_BUILD_HTTP_CLIENT* (default: first tool found in PATH)::
|
|
|
|
One of "aria2c", "curl", or "wget" to use for downloading
|
|
|
|
|
|
|
|
*RUBY_BUILD_ARIA2_OPTS*::
|
|
|
|
Additional options to pass to aria2c for downloading
|
|
|
|
|
|
|
|
*RUBY_BUILD_CURL_OPTS*::
|
|
|
|
Additional options to pass to curl for downloading
|
|
|
|
|
|
|
|
*RUBY_BUILD_WGET_OPTS*::
|
|
|
|
Additional options to pass to wget for downloading
|
|
|
|
|
|
|
|
*RUBY_BUILD_MIRROR_URL* (default: a sponsored Amazon CloudFront mirror)::
|
|
|
|
Custom mirror URL root to download packages from
|
|
|
|
|
|
|
|
*RUBY_BUILD_MIRROR_PACKAGE_URL*::
|
|
|
|
Custom complete mirror URL
|
|
|
|
|
|
|
|
*RUBY_BUILD_SKIP_MIRROR*::
|
|
|
|
Bypass the download mirror and fetch all package files from their original URLs
|
|
|
|
|
|
|
|
*RUBY_BUILD_ROOT* (default: "share/ruby-build" within ruby-build install location)::
|
|
|
|
Custom build definition directory
|
|
|
|
|
|
|
|
*RUBY_BUILD_TARBALL_OVERRIDE*::
|
|
|
|
Override the URL to fetch the ruby tarball from, optionally followed by "#<checksum>"
|
|
|
|
|
|
|
|
*RUBY_BUILD_DEFINITIONS*::
|
|
|
|
Paths to search for build definitions in addition to _RUBY_BUILD_ROOT_
|
|
|
|
|
|
|
|
*CC*::
|
|
|
|
Path to the C compiler
|
|
|
|
|
|
|
|
*RUBY_CFLAGS*::
|
|
|
|
Additional `CFLAGS` options to use for Ruby compilation
|
|
|
|
|
|
|
|
*CONFIGURE_OPTS*::
|
|
|
|
Additional "./configure" arguments
|
|
|
|
|
|
|
|
*MAKE* (default: "make")::
|
|
|
|
Custom make command (e.g., "gmake")
|
|
|
|
|
|
|
|
*MAKE_OPTS*, *MAKEOPTS*::
|
|
|
|
Additional arguments for "make"
|
|
|
|
|
|
|
|
*MAKE_INSTALL_OPTS*::
|
|
|
|
Additional arguments for "make install"
|
|
|
|
|
|
|
|
*RUBY_CONFIGURE_OPTS*::
|
|
|
|
Additional "./configure" arguments that apply only to Ruby source
|
|
|
|
|
|
|
|
*RUBY_MAKE_OPTS*::
|
|
|
|
Additional make arguments that apply only to Ruby source
|
|
|
|
|
|
|
|
*RUBY_MAKE_INSTALL_OPTS*::
|
|
|
|
Additional "make install" arguments that apply only to Ruby source
|
|
|
|
|
|
|
|
*NO_COLOR* (default: allow colors when connected to terminal)::
|
|
|
|
Disable ANSI colors in output
|
|
|
|
|
|
|
|
*CLICOLOR_FORCE*::
|
|
|
|
Use ANSI colors in output even when not connected to a terminal
|
|
|
|
|
|
|
|
== Notes
|
|
|
|
|
|
|
|
* https://github.com/rbenv/ruby-build#readme
|
|
|
|
|
|
|
|
* https://github.com/rbenv/ruby-build/wiki
|
|
|
|
|
|
|
|
* https://github.com/rbenv/ruby-build/discussions
|