rust-webpack-template
rust-webpack-template copied to clipboard
webpack fails to parse WASM file generated by Rust 1.82+
Describe the Bug
webpack v4 used in this template fails to parse WASM file generated by Rust 1.82+.
Steps to Reproduce
rustup default 1.82.0npm run start- See error:
ERROR in ./pkg/index_bg.wasm
Module parse failed: Internal failure: parseVec could not cast the value
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
Expected Behavior
Template should work without errors with latest Rust compiler.
Actual Behavior
Template doesn't work with Rust 1.82+compiler.
Additional Context
Starting from Rust 1.82.0 (released 2024-10-17) Reference types are enabled for WebAssembly target by default, see rust-lang/rust#128475. Reason for this change was just upgrade to LLVM 19, see WebAssembly/tool-conventions#233.
This broke webpack, because it uses webassemblyjs to parse WASM files and the latter didn't have Reference types support, see webpack/webpack#15566 (opened 2022-03-20, long before Rust 1.82.0 release).
webassemblyjs v1.14.1 (released 2024-11-06, 3 weeks after Rust 1.82.0 release) added working support for Reference types.
webpack v5.97.0 (released 2024-12-03, 1.5 months after Rust 1.82.0 release) finally added support for WebAssembly Reference types.
Also see related wasm-bindgen issue rustwasm/wasm-bindgen#4211 (opened 2024-10-18).
Workaround
To workaround this issue (e.g. in case one has to use webpack v4) one has to change target to initial release of WebAssembly (as this version doesn't have Reference types) and force cargo to recompile Rust Standard Library.
Use these steps to do this:
- Get nightly rust to be able to recompile Rust Standard Library:
rustup default nightly
- Create this
.cargo/config.tomlconfig:
[target.wasm32-unknown-unknown]
rustflags = ["-Ctarget-cpu=mvp"]
[unstable]
build-std = ["std", "panic_abort"]
- Add
rust-srccomponent for your architecture:
rustup component add rust-src --toolchain nightly-<your-architecture>
To get exact name of the component one can just run wasm-pack build and see it in error message:
$ wasm-pack build
...
error: ".../Cargo.lock" does not exist, unable to build with the standard library, try:
rustup component add rust-src --toolchain nightly-<your-architecture-is-here>
Error: Compiling your crate to WebAssembly failed
- Done.
npm run startshould work now.
Pull request #192 fixes this issue once merged.