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]] -=-=-=-=-=-=-=-=-=-=-=-
