eclass/rust-toolchain: Sync with gentoo

It's from gentoo commit 6daac4235622b88a878fa86e7217491e9172279d.
This commit is contained in:
Krzesimir Nowak 2022-03-03 16:27:39 +01:00
parent ef98d2e473
commit d10f19aa2a

View File

@ -1,10 +1,10 @@
# Copyright 1999-2019 Gentoo Authors # Copyright 1999-2022 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2 # Distributed under the terms of the GNU General Public License v2
# @ECLASS: rust-toolchain.eclass # @ECLASS: rust-toolchain.eclass
# @MAINTAINER: # @MAINTAINER:
# Rust Project <rust@gentoo.org> # Rust Project <rust@gentoo.org>
# @SUPPORTED_EAPIS: 6 7 # @SUPPORTED_EAPIS: 6 7 8
# @BLURB: helps map gentoo arches to rust ABIs # @BLURB: helps map gentoo arches to rust ABIs
# @DESCRIPTION: # @DESCRIPTION:
# This eclass contains a src_unpack default phase function, and # This eclass contains a src_unpack default phase function, and
@ -14,6 +14,7 @@
case ${EAPI} in case ${EAPI} in
6) : ;; 6) : ;;
7) : ;; 7) : ;;
8) : ;;
*) die "EAPI=${EAPI:-0} is not supported" ;; *) die "EAPI=${EAPI:-0} is not supported" ;;
esac esac
@ -33,22 +34,25 @@ inherit multilib-build
# environment if none is specified. # environment if none is specified.
rust_abi() { rust_abi() {
local CTARGET=${1:-${CHOST}} local CTARGET=${1:-${CHOST}}
case ${CTARGET%%*-} in case ${CTARGET%%*-} in
aarch64*) echo aarch64-unknown-linux-gnu;; aarch64*gnu) echo aarch64-unknown-linux-gnu;;
mips64*) echo mips64-unknown-linux-gnuabi64;; aarch64*musl) echo aarch64-unknown-linux-musl;;
powerpc64le*) echo powerpc64le-unknown-linux-gnu;; mips64*) echo mips64-unknown-linux-gnuabi64;;
powerpc64*) echo powerpc64-unknown-linux-gnu;; powerpc64le*) echo powerpc64le-unknown-linux-gnu;;
x86_64*) echo x86_64-unknown-linux-gnu;; powerpc64*) echo powerpc64-unknown-linux-gnu;;
armv6j*s*) echo arm-unknown-linux-gnueabi;; x86_64*gnu) echo x86_64-unknown-linux-gnu;;
armv6j*h*) echo arm-unknown-linux-gnueabihf;; x86_64*musl) echo x86_64-unknown-linux-musl;;
armv7a*h*) echo armv7-unknown-linux-gnueabihf;; armv6j*s*) echo arm-unknown-linux-gnueabi;;
i?86*) echo i686-unknown-linux-gnu;; armv6j*h*) echo arm-unknown-linux-gnueabihf;;
mipsel*) echo mipsel-unknown-linux-gnu;; armv7a*h*) echo armv7-unknown-linux-gnueabihf;;
mips*) echo mips-unknown-linux-gnu;; i?86*) echo i686-unknown-linux-gnu;;
powerpc*) echo powerpc-unknown-linux-gnu;; mipsel*) echo mipsel-unknown-linux-gnu;;
s390x*) echo s390x-unknown-linux-gnu;; mips*) echo mips-unknown-linux-gnu;;
*) echo ${CTARGET};; powerpc*) echo powerpc-unknown-linux-gnu;;
s390x*) echo s390x-unknown-linux-gnu;;
riscv64*) echo riscv64gc-unknown-linux-gnu;;
*) echo ${CTARGET};;
esac esac
} }
@ -56,18 +60,18 @@ rust_abi() {
# @DESCRIPTION: # @DESCRIPTION:
# Outputs a list of all the enabled Rust ABIs # Outputs a list of all the enabled Rust ABIs
rust_all_abis() { rust_all_abis() {
if use multilib; then if use multilib; then
local abi local abi
local ALL_ABIS=() local ALL_ABIS=()
for abi in $(multilib_get_enabled_abis); do for abi in $(multilib_get_enabled_abis); do
ALL_ABIS+=( $(rust_abi $(get_abi_CHOST ${abi})) ) ALL_ABIS+=( $(rust_abi $(get_abi_CHOST ${abi})) )
done done
local abi_list local abi_list
IFS=, eval 'abi_list=${ALL_ABIS[*]}' IFS=, eval 'abi_list=${ALL_ABIS[*]}'
echo ${abi_list} echo ${abi_list}
else else
rust_abi rust_abi
fi fi
} }
# @FUNCTION: rust_arch_uri # @FUNCTION: rust_arch_uri
@ -79,22 +83,23 @@ rust_all_abis() {
# #
# @EXAMPLE: # @EXAMPLE:
# SRC_URI="amd64? ( # SRC_URI="amd64? (
# $(rust_arch_uri x86_64-unknown-linux-gnu rustc-${STAGE0_VERSION}) # $(rust_arch_uri x86_64-unknown-linux-gnu rustc-${STAGE0_VERSION})
# )" # )"
# #
rust_arch_uri() { rust_arch_uri() {
if [ -n "$3" ]; then if [ -n "$3" ]; then
echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz -> ${3}-${1}.tar.xz" echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz -> ${3}-${1}.tar.xz"
else else
echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz" echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz"
fi echo "verify-sig? ( ${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz.asc )"
fi
} }
# @FUNCTION: rust_all_arch_uris # @FUNCTION: rust_all_arch_uris
# @USAGE: <base-uri> [alt-distfile-basename] # @USAGE: <base-uri> [alt-distfile-basename]
# @DESCRIPTION: # @DESCRIPTION:
# Outputs the URIs for SRC_URI to help fetch dependencies, using a base URI # Outputs the URIs for SRC_URI to help fetch dependencies, using a base URI
# provided as an argument. Optionally allows for distfile renaming via a specified # provided as an argument. Optionally allows for distfile renaming via a specified
# basename. # basename.
# #
# @EXAMPLE: # @EXAMPLE:
@ -103,18 +108,21 @@ rust_arch_uri() {
rust_all_arch_uris() rust_all_arch_uris()
{ {
local uris="" local uris=""
uris+="amd64? ( $(rust_arch_uri x86_64-unknown-linux-gnu "$@") ) " uris+="abi_x86_64? ( elibc_glibc? ( $(rust_arch_uri x86_64-unknown-linux-gnu "$@") )
uris+="arm? ( $(rust_arch_uri arm-unknown-linux-gnueabi "$@") elibc_musl? ( $(rust_arch_uri x86_64-unknown-linux-musl "$@") ) ) "
$(rust_arch_uri arm-unknown-linux-gnueabihf "$@") uris+="arm? ( $(rust_arch_uri arm-unknown-linux-gnueabi "$@")
$(rust_arch_uri armv7-unknown-linux-gnueabihf "$@") ) " $(rust_arch_uri arm-unknown-linux-gnueabihf "$@")
uris+="arm64? ( $(rust_arch_uri aarch64-unknown-linux-gnu "$@") ) " $(rust_arch_uri armv7-unknown-linux-gnueabihf "$@") ) "
uris+="mips? ( $(rust_arch_uri mips-unknown-linux-gnu "$@") uris+="arm64? ( elibc_glibc? ( $(rust_arch_uri aarch64-unknown-linux-gnu "$@") )
$(rust_arch_uri mipsel-unknown-linux-gnu "$@") elibc_musl? ( $(rust_arch_uri aarch64-unknown-linux-musl "$@") ) ) "
$(rust_arch_uri mips64-unknown-linux-gnuabi64 "$@") ) " uris+="mips? ( $(rust_arch_uri mips-unknown-linux-gnu "$@")
uris+="ppc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "$@") ) " $(rust_arch_uri mipsel-unknown-linux-gnu "$@")
uris+="ppc64? ( $(rust_arch_uri powerpc64-unknown-linux-gnu "$@") $(rust_arch_uri mips64-unknown-linux-gnuabi64 "$@") ) "
$(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") ) " uris+="ppc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "$@") ) "
uris+="s390? ( $(rust_arch_uri s390x-unknown-linux-gnu "$@") ) " uris+="ppc64? ( $(rust_arch_uri powerpc64-unknown-linux-gnu "$@")
uris+="x86? ( $(rust_arch_uri i686-unknown-linux-gnu "$@") ) " $(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") ) "
uris+="s390? ( $(rust_arch_uri s390x-unknown-linux-gnu "$@") ) "
uris+="abi_x86_32? ( $(rust_arch_uri i686-unknown-linux-gnu "$@") ) "
uris+="riscv? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") ) "
echo "${uris}" echo "${uris}"
} }