wasm-bindgen/examples/import_js
Alex Crichton a2aa28e4d3 Add a #[wasm_bindgen(start)] attribute
This commit adds a new attribute to `#[wasm_bindgen]`: `start`. The
`start` attribute can be used to indicate that a function should be
executed when the module is loaded, configuring the `start` function of
the wasm executable. While this doesn't necessarily literally configure
the `start` section, it does its best!

Only one crate in a crate graph may indicate `#[wasm_bindgen(start)]`,
so it's not recommended to be used in libraries but only end-user
applications. Currently this still must be used with the `crate-type =
["cdylib"]` annotation in `Cargo.toml`.

The implementation here is somewhat tricky because of the circular
dependency between our generated JS and the wasm file that we emit. This
circular dependency makes running initialization routines (like the
`start` shim) particularly fraught with complications because one may
need to run before the other but bundlers may not necessarily respect
it. Workarounds have been implemented for various emission strategies,
for example calling the start function directly after exports are wired
up with `--no-modules` and otherwise working around what appears to be
a Webpack bug with initializers running in a different order than we'd
like. In any case, this in theory doesn't show up to the end user!

Closes #74
2018-11-28 22:11:15 -08:00
..
src Add a #[wasm_bindgen(start)] attribute 2018-11-28 22:11:15 -08:00
.gitignore Add an example of importing non-browser functions 2018-05-23 12:14:12 -07:00
build.sh Promote CI jobs to using stable Rust 2018-10-28 13:28:02 -07:00
Cargo.toml Bump to 0.2.28 2018-11-12 09:28:01 -08:00
defined-in-js.js Applied eslint from main .eslintrc to examples (#418) 2018-07-08 01:02:10 -05:00
index.html Reorganize and rewrite examples 2018-09-20 16:45:30 -07:00
index.js Add a #[wasm_bindgen(start)] attribute 2018-11-28 22:11:15 -08:00
package.json Fix polyfill of TextEncoder and TextDecoder 2018-09-30 10:16:20 -07:00
README.md Build examples and deploy to gh-pages 2018-09-20 20:55:02 -07:00
webpack.config.js Fix polyfill of TextEncoder and TextDecoder 2018-09-30 10:16:20 -07:00

Importing non-browser JS

View documentation for this example online or View compiled example online

You can build the example locally with:

$ ./build.sh

(or running the commands on Windows manually)

and then visiting http://localhost:8080 in a browser should run the example!