wasmer/README.md

81 lines
2.3 KiB
Markdown
Raw Normal View History

<p align="center"><a href="https://wasmer.io" target="_blank" rel="noopener noreferrer"><img width="400" src="https://raw.githubusercontent.com/wasmerio/wasmer/master/logo.png" alt="Wasmer logo"></a></p>
2018-11-05 13:52:53 +00:00
<p align="center">
<a href="https://circleci.com/gh/wasmerio/wasmer/"><img src="https://img.shields.io/circleci/project/github/wasmerio/wasmer/master.svg" alt="Build Status"></a>
<a href="https://github.com/wasmerio/wasmer/blob/master/LICENSE"><img src="https://img.shields.io/github/license/wasmerio/wasmer.svg" alt="License"></a>
2018-11-05 13:52:53 +00:00
</p>
2018-11-05 13:52:53 +00:00
## Introduction
[Wasmer](https://wasmer.io/) is a Standalone JIT WebAssembly runtime, aiming to be fully compatible with Emscripten, Rust and Go.
Install Wasmer with:
```sh
curl https://get.wasmer.io -sSfL | sh
```
2018-12-07 19:25:31 +00:00
### Usage
2018-11-05 13:52:53 +00:00
`wasmer` can execute both the standard binary format (`.wasm`) and the text
format defined by the WebAssembly reference interpreter (`.wat`).
Once installed, you will be able to run any wasm module (_including Nginx!_):
2018-10-14 21:49:10 +00:00
```sh
2018-12-07 04:25:14 +00:00
wasmer run examples/nginx/nginx.wasm -- -p examples/nginx -c nginx.conf
2018-10-14 21:49:10 +00:00
```
## Building & Running
To build this project you will need Rust and Cargo.
```sh
# checkout code
git clone https://github.com/wasmerio/wasmer.git
cd wasmer
# install tools
# make sure that `python` is accessible.
cargo install
```
2018-10-14 21:49:10 +00:00
## Testing
Thanks to [spectests](https://github.com/wasmerio/wasmer/tree/master/spectests) we can assure 100% compatibility with the WebAssembly spec test suite.
2018-10-24 10:07:52 +00:00
2018-10-14 21:49:10 +00:00
Tests can be run with:
```sh
2018-11-15 21:30:00 +00:00
make test
2018-10-14 21:49:10 +00:00
```
2018-10-24 10:07:52 +00:00
If you need to re-generate the Rust tests from the spectests
you can run:
```sh
make spectests
```
## Roadmap
2018-10-14 21:54:28 +00:00
Wasmer is an open project guided by strong principles, aiming to be modular, flexible and fast. It is open to the community to help set its direction.
2018-10-24 10:07:52 +00:00
Below are some of the goals (written with order) of this project:
- [x] It should be 100% compatible with the [WebAssembly Spectest](https://github.com/wasmerio/wasmer/tree/master/spectests)
- [x] It should be fast _(partially achieved)_
2018-11-22 06:12:34 +00:00
- [ ] Support Emscripten calls _(on the works)_
2018-10-24 10:07:52 +00:00
- [ ] Support Rust ABI calls
2018-10-14 21:54:28 +00:00
2018-12-07 19:25:31 +00:00
## Architecture
If you would like to know how Wasmer works under the hood, please visit our [ARCHITECTURE](https://github.com/wasmerio/wasmer/blob/master/ARCHITECTURE.md) document.
## License
MIT/Apache-2.0
2018-12-19 21:00:07 +00:00
<small>[Attributions](./ATTRIBUTIONS.md)</small>.