Skip to content

rustwasm.github.io/docs/book/introduction.html

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE_APACHE
MIT
LICENSE_MIT
Notifications You must be signed in to change notification settings

luhmann/wasm-game-of-life

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Conways Game of Life with Rust and WASM

This is the implementation of this tutorial: https://rustwasm.github.io/docs/book/introduction.html

Running

Requirements are working rust-toolchain

$ cargo install (?)
$ wasm-pack build
$ cd www && npm install && npm start

Tests

wasm-pack test --chrome --headless

You can also use the following flags:

  • --firefox
  • --safari
  • --node

Notes

General

  • You define the exports of the rust modules by marking the rust language constructs with the #[wasm_bindgen]-macro
    • you need to annotate declaration and implementation for structs
    • in a struct only public members are exposed as JS exports
    • everyhing you declared as a binding in such a fashion shows up in the *_bg.js file in the generated pkg-directory and through this allows interop with wasm
  • WASMs memory is linear and can be accessed directly by importing it from the *_bg.js-file
    • you can directly access this memory by layering a UInt*Array on top of it
    • this saves the overhead of copying data to and from WASMs linear memory to the JS heap
    • this memory is not directly mutable (thank god)
  • you can pull in a local directory of files as a node-module by using this syntax in package.json: "wasm-game-of-life": "file:../pkg"
  • Webpack seems to be able to directly import wasm-files without further plugins (?)
  • You can use the js_sys-crate to access functions in the JS Standard-Library: https://rustwasm.github.io/wasm-bindgen/api/js_sys/
  • usize-Type

    Additionally, the isize and usize types depend on the kind of computer your program is running on: 64 bits if you’re on a 64-bit architecture and 32 bits if you’re on a 32-bit architecture.

  • Representing each cell with an 8bit data-type is wasteful as we only need a single bit to represent the state
  • Rust-generated WebAssembly functions cannot return borrowed references.
  • You can have multiple implementation blocks for each struct, if you have public methods in a struct-implementation, you do want to have a wasm_binding-macro on then you can create a new implementation without the macro
  • You can have config flags like this #[cfg(test)] annotating code, this means that the code is only included in the compilation when certain configuration-flags are passed
  • You can use the web-sys-crate (https://rustwasm.github.io/wasm-bindgen/web-sys/index.html) for getting bindings to the web-apis like fetch, console, etc

Testing

  • You can test your wasm-functions easily by running the module plus the js interop-code in any browser or node
  • Annotate your actual tests with the #[wasm_bindgen_test]-macro
  • Unit-Tests in Rust go into the same file as the code they test
  • There is a mature property-based-testing package for rust called quickcheck https://github.com/BurntSushi/quickcheck (sounds like its pretty much the same package-name everywhere ;=) )

Debugging

Profiling

  • You can access the tools you are used to from JS like console.time/console.timeEnd via the web-sys-crate
  • You can use Timer in utils to profile the execution time of blocks in rust code
  • There are built-in tools in rust to write benchmarks for rust code with #[bench]

Deploying

For the fastest page loads, you'll want to use the WebAssembly.instantiateStreaming (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WebAssembly/instantiateStreaming) function to pipeline wasm compilation and instantiation with network transfer (or make sure your bundler is able to use that function). However, instantiateStreaming requires that the HTTP response has the application/wasm MIME type set, or else it will throw an error.

About

rustwasm.github.io/docs/book/introduction.html

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE_APACHE
MIT
LICENSE_MIT

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published