Files
typst/vendor/wasmparser-nostd
Sergey Konev a8d83b9bab
Some checks failed
Continuous integration / Tests (push) Blocked by required conditions
Continuous integration / Tests (windows-latest) (push) Waiting to run
Continuous integration / Check clippy, formatting, and documentation (push) Failing after 20s
Continuous integration / Tests (ubuntu-latest) (push) Failing after 22s
Continuous integration / Check fuzzers (push) Failing after 18s
Continuous integration / Check mininum Rust version (push) Failing after 20s
Fixed vendoring
2024-10-16 15:22:14 +03:00
..
2024-10-16 14:18:46 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00
2024-10-16 15:22:14 +03:00

This is a fork of the wasmparser crate by the Bytecode Alliance with the sole purpose to add no_std support with a focus on embedded environments.

This crate will be deprecated as soon as the original wasmparser crate itself supports no_std.

Note: As of version 0.99.0 and above the Url type from the url crate was replaced with a simple String in order to port the entire crate to no_std. This is because the complex url crate itself does not support no_std compilation.

The WebAssembly binary file decoder in Rust

A Bytecode Alliance project

crates.io link docs.rs docs

The decoder library provides lightweight and fast decoding/parsing of WebAssembly binary files.

The other goal is minimal memory footprint. For this reason, there is no AST or IR of WebAssembly data.

See also its sibling at https://github.com/wasdk/wasmparser

Documentation

The documentation and examples can be found at the https://docs.rs/wasmparser/

Fuzzing

To fuzz test wasmparser.rs, switch to a nightly Rust compiler and install cargo-fuzz:

cargo install cargo-fuzz

Then, from the root of the repository, run:

cargo fuzz run parse

If you want to use files as seeds for the fuzzer, add them to fuzz/corpus/parse/ and restart cargo-fuzz.