Skip to content

A Cloud Native Buildpack that provides Rustup and installs a Rust toolchain

License

Notifications You must be signed in to change notification settings

paketo-community/rustup

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gcr.io/paketo-community/rustup

The Paketo Buildpack for Rustup is a Cloud Native Buildpack that installs and executes rustup to install Rust.

Behavior

If all of these conditions are met:

  • Another buildpack requires rust
  • $BP_RUSTUP_ENABLED is true

The buildpack will do the following:

  • Contributes rustup-init to a layer marked cache with command on $PATH
  • Executes rustup-init with the output written to a layer marked build and cache with installed commands on $PATH
  • Executes rustup to install a Rust toolchain to a layer marked build and cache with installed commands on $PATH
    • If rust-toolchain or rust-toolchain.toml exists, rustup will install as configured in the file. If $BP_RUST_TOOLCHAIN / $BP_RUST_PROFILE are also set to non-default values, they will also be installed.
    • If rust-toolchain or rust-toolchain.toml do not exist, rustup will install $BP_RUST_TOOLCHAIN / $BP_RUST_PROFILE.
  • If $BP_RUST_TARGET is set, executes rustup target add to install an additional Rust target.
  • If $BP_RUST_TARGET is not set and the build is running on the Paketo Tiny or Static stacks, then the Rust Linux musl target will be automatically added.

Configuration

Environment Variable Description
$BP_RUSTUP_ENABLED Configure rustup to be enabled. This means that rustup will be used to install Rust. Default value is true. Set to false to use another Rust toolchain provider like rust-dist.
$BP_RUST_TOOLCHAIN Rust toolchain to install. Default stable. Other common values: beta, nightly or a specific versin number. Any acceptable value for a toolchain can be used here.
$BP_RUST_PROFILE Rust profile to install. Default minimum. Other acceptable values: default, complete. See Rustup docs for profile.
$BP_RUST_TARGET Additional Rust target to install. Default ``, so nothing additional is installed. If there is no user-specified target and the build is running on the Paketo Tiny or Static stack, then the Linux musl target is automatically added. Run rustup target list to see what valid targets exist.
$BP_RUSTUP_INIT_VERSION Configure the version of rustup-init to install. It can be a specific version or a wildcard like 1.*. It defaults to the latest 1.* version.
$BP_RUSTUP_INIT_LIBC Configure the libc implementation used by the installed toolchain. Available options: gnu or musl. Defaults to gnu for compatiblity. You do not need to set this option with the Paketo full/base/tiny/static stacks. It can be used for compatibility with more exotic or custom stacks.

License

This buildpack is released under version 2.0 of the Apache License.