cargo-component
0.9.0 has now been released.
Please review the release notes here as there are a number of breaking changes relating to this release.
woooohhhh!!!! :partying_face:
The binary artifacts are still being built, just FYI
When reading the changelog I see that there are some breaking changes to [package.metadata.component.bindings]
, does this also apply for std_feature
?
Because I just upgraded to 0.9, and now I get the following error:
error[E0152]: found duplicate lang item `panic_impl`
--> src/lib.rs:68:1
|
68 | / fn panic(_panic: &core::panic::PanicInfo<'_>) -> ! {
69 | | // My panic
70 | | loop {}
71 | | }
| |_^
|
= note: the lang item is first defined in crate `std` (which `wit_bindgen_rt` depends on)
= note: first definition in `std` loaded from /home/zelzahn/.rustup/toolchains/nightly-x86_64-unknown-linux-gnu/lib/rustlib/wasm32-wasi/lib/libstd-b30c25b1d25082c4.rlib
I have set std_feature
to true and set the #![no_std]
attribute in my lib.rs
.
@Friedrich Vandenberghe it shouldn't have, unless there was a regression in wit-bindgen
(double checked that the option was being passed from cargo-component
to wit-bindgen
); let me take a deeper look, although I'm about to board a plane
Oh whoops, it appears we left #![no_std]
off wit-bindgen-rt
when we refactored it out into its own crate
we should be able to fix that with a patch to wit-bindgen-rt
and cargo update
on your project will then hopefully get you working again
I'll also add a test to cargo-component
so this doesn't regress in the future
I've opened https://github.com/bytecodealliance/wit-bindgen/pull/877; once that's merged and released, I'll add that regression test to cargo-component
Thanks for the swift response! :big_smile:
When 0.21.0 of wit-bindgen-rt
is released, you should be able to cargo upgrade --incompatible
(if you're using cargo-edit
) or just manually update the dependency your project; it should not require a cargo-component
release
Last updated: Jan 24 2025 at 00:11 UTC