13 unstable releases (5 breaking)

0.6.3 Feb 7, 2024
0.6.1 Nov 30, 2023
0.5.1 Nov 21, 2023
0.4.0 Oct 27, 2022
0.1.0 Dec 10, 2021

#416 in WebAssembly

Download history 43/week @ 2024-09-02 37/week @ 2024-09-09 61/week @ 2024-09-16 94/week @ 2024-09-23 68/week @ 2024-09-30 70/week @ 2024-10-07 43/week @ 2024-10-14 60/week @ 2024-10-21 51/week @ 2024-10-28 35/week @ 2024-11-04 46/week @ 2024-11-11 47/week @ 2024-11-18 46/week @ 2024-11-25 81/week @ 2024-12-02 68/week @ 2024-12-09 62/week @ 2024-12-16

272 downloads per month
Used in bevy_spatial

MIT license

24KB
370 lines

wasm-server-runner

Allows you to run programs in the browser using web assembly using a simple cargo run.

Usage

Step 1.

rustup target add wasm32-unknown-unknown
cargo install wasm-server-runner

Step 2.

Add this to your ~/.cargo/config.toml (not the Cargo.toml of your project!):

[target.wasm32-unknown-unknown]
runner = "wasm-server-runner"

Step 3.

Run programs in the browser using

cargo run --target wasm32-unknown-unknown
cargo run --target wasm32-unknown-unknown --example example

wasm-server-runner path/to/file.wasm

Example output:

INFO wasm_server_runner: wasm output is 49.79kb large
INFO wasm_server_runner: starting webserver at http://127.0.0.1:1334

The website will reload when the server is restarted and serve files relative to the current directory.

Configuration options

All configuration options can be specified via environment variables.

WASM_SERVER_RUNNER_ADDRESS

Default: 127.0.0.1 Control the address that the server listens on. Set to 0.0.0.0 to allow access from anywhere.

WASM_SERVER_RUNNER_DIRECTORY

Default: .

Can be used to specify where relative path requests are loaded from.

WASM_SERVER_RUNNER_CUSTOM_INDEX_HTML

Default: none

When set, will try to load the custom index.html from that path instead of the default. Can be relative to the directory.

Note: To support both module and non-module style the index.html needs to have specific string that will be replaced at runtime. The body should contain something like

{{ NO_MODULE }}
<script type="module">
    // {{ MODULE }}
</script>
WASM_SERVER_RUNNER_HTTPS

Default: false

Controls whether https is used.

WASM_SERVER_RUNNER_NO_MODULE

Default: false

Controls whether the wasm-bindgen output uses modules or not.

Dependencies

~31–44MB
~838K SLoC