mirror of
https://github.com/flatcar/scripts.git
synced 2025-09-03 12:51:11 +02:00
eclass/rust-toolchain: Sync with gentoo
It's from gentoo commit 6daac4235622b88a878fa86e7217491e9172279d.
This commit is contained in:
parent
ef98d2e473
commit
d10f19aa2a
@ -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}"
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user