kan...@gentoo.org writes:

> From: Matt Jolly <kan...@gentoo.org>
>
> These variables enable users (though most likely Gentoo developers)
> to override the selection of the Rust implementation by the eclass.
>
> This means that _only_ the specified ERUST_SLOT and/or ERUST_TYPE
> ('source' or 'binary') will be checked for, with the eclass `die`ing
> with "No Rust slot satisfying the package's dependencies..." if the
> selected impl is not available.
>
> These variables are intended to enable reproducing bugs and testing
> packages against specific dev-lang/rust{,-bin} packages; they must
> not be set in ebuilds.

On reflection, I still quite like the idea of trying the eselect'ed Rust
first but I'm (of course) open to arguments not to.

>
> Closes: https://bugs.gentoo.org/945752
> Signed-off-by: Matt Jolly <kan...@gentoo.org>
> ---
>  eclass/rust.eclass | 49 +++++++++++++++++++++++++++++++++++++++++-----
>  1 file changed, 44 insertions(+), 5 deletions(-)
>
> diff --git a/eclass/rust.eclass b/eclass/rust.eclass
> index 71cbb4b24f8c..991a9cdb7f14 100644
> --- a/eclass/rust.eclass
> +++ b/eclass/rust.eclass
> @@ -98,6 +98,26 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
>       "1.54.0"
>  )
>  
> +# == user control knobs ==
> +
> +# @ECLASS_VARIABLE: ERUST_SLOT
> +# @USER_VARIABLE
> +# @DESCRIPTION:
> +# Specify the version (slot) of Rust to be used by the package. This is
> +# useful for troubleshooting and debugging purposes; If unset, the newest
> +# acceptable Rust version will be used. May be combined with ERUST_TYPE.
> +# This variable must not be set in ebuilds.
> +
> +# @ECLASS_VARIABLE: ERUST_TYPE
> +# @USER_VARIABLE
> +# @DESCRIPTION:
> +# Specify the type of Rust to be used by the package from options:
> +# 'source' or 'binary' (-bin). This is useful for troubleshooting and
> +# debugging purposes. If unset, the standard eclass logic will be used
> +# to determine the type of Rust to use (i.e. prefer source if binary
> +# is also available). May be combined with ERUST_SLOT.
> +# This variable must not be set in ebuilds.
> +
>  # == control variables ==
>  
>  # @ECLASS_VARIABLE: RUST_MAX_VER
> @@ -332,6 +352,10 @@ _get_rust_slot() {
>                       fi
>               fi
>  
> +             if [[ -n "${ERUST_SLOT}" && "${slot}" != "${ERUST_SLOT}" ]]; 
> then
> +                     continue
> +             fi
> +
>               # If we're in LLVM mode we can skip any slots that don't match 
> the selected USE
>               if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
>                       if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
> @@ -345,12 +369,27 @@ _get_rust_slot() {
>                       rust_check_deps && return
>               else
>                       local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
> -                     # When checking for installed packages prefer the non 
> `-bin` package
> +                     # When checking for installed packages prefer the 
> source package;
>                       # if effort was put into building it we should use it.
> -                     local rust_pkgs=(
> -                             "dev-lang/rust:${slot}${usedep}"
> -                             "dev-lang/rust-bin:${slot}${usedep}"
> -                     )
> +                     local rust_pkgs
> +                     case "${ERUST_TYPE}" in
> +                             source)
> +                                     rust_pkgs=(
> +                                             "dev-lang/rust:${slot}${usedep}"
> +                                     )
> +                                     ;;
> +                             binary)
> +                                     rust_pkgs=(
> +                                             
> "dev-lang/rust-bin:${slot}${usedep}"
> +                                     )
> +                                     ;;
> +                             *)
> +                                     rust_pkgs=(
> +                                             "dev-lang/rust:${slot}${usedep}"
> +                                             
> "dev-lang/rust-bin:${slot}${usedep}"
> +                                     )
> +                                     ;;
> +                     esac
>                       local _pkg
>                       for _pkg in "${rust_pkgs[@]}"; do
>                               if has_version "${hv_switch}" "${_pkg}"; then

Reply via email to