[![crates.io link](https://img.shields.io/crates/v/wasmi.svg)](https://crates.io/crates/wasmi) [![Build Status](https://travis-ci.org/paritytech/wasmi.svg?branch=master)](https://travis-ci.org/paritytech/wasmi) # `wasmi` WASM interpreter (previously lived in [parity-wasm](https://github.com/paritytech/parity-wasm)) Primary purpose of `wasmi` is to be used with [parity](https://github.com/paritytech/parity) (ethereum-like contracts in wasm) and with [Polkadot](https://github.com/paritytech/polkadot). However, `wasmi` is designed to be as flexible as possible and might be suited well for other purposes. At the moment, the API is rather low-level (especially, in the part related to host functions). But some high-level API is on the roadmap. # License `wasmi` is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), at your choice. See LICENSE-APACHE, and LICENSE-MIT for details. # Build & Test As `wasmi` contains a git submodule, you need to use `--recursive` for cloning or to checkout the submodule explicitly, otherwise the testing would fail. ``` git clone https://github.com/paritytech/wasmi.git --recursive cd wasmi cargo build cargo test ``` # `no_std` support This crate supports `no_std` environments. Enable the `no_std` feature and disable default features: ```toml [dependencies] parity-wasm = { version = "0.31", default-features = false, features = "no_std" } ``` `no_std` requires the `core` and `alloc` libraries and a nightly compiler. Also, code related to `std::error` is disabled. ## Contribution Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in `wasmi` by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.