On Fri, 2022-12-16 at 18:21 -0700, Alejandro Hernandez Samaniego wrote:
> From: Alejandro Hernandez Samaniego <[email protected]>
> 
> Rust follows the train release model via the stable, beta and nightly 
> channels,
> by default we build rust from the stable channel, however there are certain
> features which are only available in the beta or nightly channels.
> 
> Make these channels available by setting a RUST_CHANNEL variable which 
> defaults
> to stable making this change transparent to the user.
> 
> The snapshot version used by rust during its compilation wont necessarily 
> match
> the version being built, specially if were building from an unstable channel,
> to avoid confusion rename this to SNAPSHOT_VERSION and use RUST_VERSION for 
> the
> version to be built, which is automatically defined to PV.
> 
> Append -beta or -nightly to rusts PV for signature awareness.
> 
> It is important to note that this does not build rust from the beta/nightly
> published tarball (which today build rust v1.67.0 and v1.68.0 respectively),
> instead this builds rust from the current selected version (1.66.0) and 
> enables
> the beta/nightly features for that version.
> 
> Setting the variable RUST_CHANNEL=nightly results in the following:
> 
> $ rustc -Vv
> rustc 1.66.0-nightly
> 
> Signed-off-by: Alejandro Hernandez Samaniego <[email protected]>
> ---
>  meta/recipes-devtools/rust/rust-snapshot.inc | 7 ++++---
>  meta/recipes-devtools/rust/rust-source.inc   | 5 +++--
>  meta/recipes-devtools/rust/rust.inc          | 6 +++++-
>  3 files changed, 12 insertions(+), 6 deletions(-)
> 
> diff --git a/meta/recipes-devtools/rust/rust-snapshot.inc 
> b/meta/recipes-devtools/rust/rust-snapshot.inc
> index 222f34f9a8..6420bcff55 100644
> --- a/meta/recipes-devtools/rust/rust-snapshot.inc
> +++ b/meta/recipes-devtools/rust/rust-snapshot.inc
> @@ -5,7 +5,8 @@
>  ## The version is replicated here.
>  ## TODO: find a way to add additional SRC_URIs based on the contents of an
>  ##       earlier SRC_URI.
> -RS_VERSION = "1.65.0"
> +
> +SNAPSHOT_VERSION = "1.65.0"
>  CARGO_VERSION = "1.65.0"
>  
>  # TODO: Add hashes for other architecture toolchains as well. Make a script?
> @@ -27,6 +28,6 @@ SRC_URI += " \
>      
> https://static.rust-lang.org/dist/${CARGO_SNAPSHOT}.tar.xz;name=cargo-snapshot-${RUST_BUILD_ARCH};subdir=rust-snapshot-components
>  \
>  "
>  
> -RUST_STD_SNAPSHOT = 
> "rust-std-${RS_VERSION}-${RUST_BUILD_ARCH}-unknown-linux-gnu"
> -RUSTC_SNAPSHOT = "rustc-${RS_VERSION}-${RUST_BUILD_ARCH}-unknown-linux-gnu"
> +RUST_STD_SNAPSHOT = 
> "rust-std-${SNAPSHOT_VERSION}-${RUST_BUILD_ARCH}-unknown-linux-gnu"
> +RUSTC_SNAPSHOT = 
> "rustc-${SNAPSHOT_VERSION}-${RUST_BUILD_ARCH}-unknown-linux-gnu"
>  CARGO_SNAPSHOT = 
> "cargo-${CARGO_VERSION}-${RUST_BUILD_ARCH}-unknown-linux-gnu"
> diff --git a/meta/recipes-devtools/rust/rust-source.inc 
> b/meta/recipes-devtools/rust/rust-source.inc
> index 1c511917e2..91a6c5a942 100644
> --- a/meta/recipes-devtools/rust/rust-source.inc
> +++ b/meta/recipes-devtools/rust/rust-source.inc
> @@ -1,4 +1,5 @@
> -SRC_URI += 
> "https://static.rust-lang.org/dist/rustc-${PV}-src.tar.xz;name=rust";
> +RUST_VERSION ?= "${@d.getVar('PV').split('-')[0]}"
> +SRC_URI += 
> "https://static.rust-lang.org/dist/rustc-${RUST_VERSION}-src.tar.xz;name=rust";
>  SRC_URI[rust.sha256sum] = 
> "0dc176e34fae9871f855a6ba4cb30fa19d69c5b4428d29281a07419c4950715c"
>  
>  SRC_URI:append:class-target:pn-rust = " \
> @@ -6,7 +7,7 @@ SRC_URI:append:class-target:pn-rust = " \
>      file://crossbeam_atomic.patch"
>  SRC_URI:append:class-nativesdk:pn-nativesdk-rust = " 
> file://hardcodepaths.patch"
>  
> -RUSTSRC = "${WORKDIR}/rustc-${PV}-src"
> +RUSTSRC = "${WORKDIR}/rustc-${RUST_VERSION}-src"
>  
>  UPSTREAM_CHECK_URI = 
> "https://forge.rust-lang.org/infra/other-installation-methods.html";
>  UPSTREAM_CHECK_REGEX = "rustc-(?P<pver>\d+(\.\d+)+)-src"
> diff --git a/meta/recipes-devtools/rust/rust.inc 
> b/meta/recipes-devtools/rust/rust.inc
> index 8d25e7993a..37a04e1204 100644
> --- a/meta/recipes-devtools/rust/rust.inc
> +++ b/meta/recipes-devtools/rust/rust.inc
> @@ -13,6 +13,10 @@ DEPENDS:append:class-nativesdk = " nativesdk-rust-llvm"
>  
>  S = "${RUSTSRC}"
>  
> +# Use at your own risk, accepted values are stable, beta and nightly
> +RUST_CHANNEL ?= "stable"
> +PV:append = "${@bb.utils.contains('RUST_CHANNEL', 'stable', '', 
> '-${RUST_CHANNEL}', d)}"
> +
>  export FORCE_CRATE_HASH="${BB_TASKHASH}"

Did you try it with .= instead of append? I'd really prefer not to use
append unless we have to, mainly so we lead by example...

Cheers,

Richard


-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#174769): 
https://lists.openembedded.org/g/openembedded-core/message/174769
Mute This Topic: https://lists.openembedded.org/mt/95722979/21656
Group Owner: [email protected]
Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub 
[[email protected]]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to