114 stable releases
1.221.2 | Dec 2, 2024 |
---|---|
1.221.0 | Nov 27, 2024 |
1.219.1 | Oct 10, 2024 |
1.215.0 | Jul 31, 2024 |
0.1.0 |
|
#31 in WebAssembly
522,984 downloads per month
Used in 490 crates
(132 directly)
725KB
16K
SLoC
Usage
Add wat
to your Cargo.toml
$ cargo add wat
And then you can parse WAT to binary WebAssembly via:
// Parse from a file ...
let binary = wat::parse_file("./foo.wat")?;
// ... or a string
let wat = r#"
(module
(func $foo)
(func (export "bar")
call $foo
)
)
"#;
let binary = wat::parse_str(wat)?;
AST Representation
The wat
crate does not expose an AST as its goal is to provide a
forever-stable interface against the wast
crate. Using wat
is suitable when
all you want to do is translate from text-to-binary, for example parsing the
input of a CLI program into the WebAssembly binary format.
If instead you're interested in working with the AST of a text file or otherwise
adding your own parsing to the text format you'll want to take a look at the
wast
crate.
Stability and WebAssembly Features
Consult the crate documentation for more information, but the general idea is this crate will not issue a semver-breaking change for breaking changes in the WAT format, either for MVP features or post-MVP features. No opt-in is required to use WebAssembly features, so using them may break if the upstream spec changes.
License
This project is licensed under the Apache 2.0 license with the LLVM exception. See LICENSE for more details.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be licensed as above, without any additional terms or conditions.
Dependencies
~2.3–3MB
~52K SLoC