Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
golem-wasm-ast
Higher level WASM library for Rust
This library defines an in-memory, mutable representation of WebAssembly modules and components. It uses
the wasmparser and wasm-encoder crates for building up and serializing this model.
Building up the full AST in memory makes it easier to perform analysis and mutation on a whole WASM component.
The analysis
module defines such higher level operations.
Usage
Add wasm-ast to your Cargo.toml
$ cargo add golem-wasm-ast
Then parse a WASM module or component from an array of bytes:
use Debug;
use DefaultAst;
use AnalysisContext;
use ;
use Component;
Use the top level Module
or Component
structs to query and manipulate parts of the model.
It is possible to use a different type than Expr
, Data
and Custom
to represent the code blocks, data and custom sections in the parsed AST to reduce the memory footprint in case the actual code is not required for the analysis. Note that if this custom representation cannot be serialized back to a stream of WASM instructions, the AST will no longer be serializable.
The following example just ignores all the code blocks, but keeps the data and custom sections:
;
It is possible to do some parse-time analysis of the code blocks in the TryFromExprSource
implementation and store the analysation result in place of the Expr
nodes.
Features
component
enables support for the WASM Component Modelparser
enables parsing of WASM modules and componentswriter
enables the serialization of WASM modules and componentsmetadata
enables the parsing of WASM metadata sections using the wasm-metadata crateanalysis
enables higher level analysis and mutation of WASM modules and components
The default
feature enables all the above.