#rendering-engine #terminal #web-gpu #multi-platform #rio #cross-platform

sugarloaf

Sugarloaf is Rio rendering engine, designed to be multiplatform. It is based on WebGPU, Rust library for Desktops and WebAssembly for Web (JavaScript). This project is created and maintained for Rio terminal purposes but feel free to use it.

49 releases

new 0.2.4 Jan 17, 2025
0.2.2 Nov 23, 2024
0.1.3 Jul 27, 2024
0.0.36 Mar 14, 2024
0.0.12 Jul 21, 2023

#9 in Rendering engine

Download history 188/week @ 2024-09-27 211/week @ 2024-10-04 34/week @ 2024-10-11 19/week @ 2024-10-18 10/week @ 2024-10-25 18/week @ 2024-11-01 135/week @ 2024-11-08 211/week @ 2024-11-15 408/week @ 2024-11-22 163/week @ 2024-11-29 231/week @ 2024-12-06 115/week @ 2024-12-13 57/week @ 2024-12-20 42/week @ 2024-12-27 102/week @ 2025-01-03 223/week @ 2025-01-10

434 downloads per month
Used in 3 crates (2 directly)

MIT license

4.5MB
38K SLoC

Sugarloaf

Sugarloaf is Rio rendering engine, designed to be multiplatform. It is based on WebGPU, Rust library for Desktops and WebAssembly for Web (JavaScript). This project is created and maintained for Rio terminal purposes but feel free to use it.

cargo run --example text

WASM Tests

Setup

Install wasm-bindgen-cli globally: cargo install wasm-bindgen-cli. wasm-bindgen-cli provides a test runner harness.

Running Tests

Run (in the root sugarloaf directory):

CARGO_TARGET_WASM32_UNKNOWN_UNKNOWN_RUNNER=wasm-bindgen-test-runner cargo test --target wasm32-unknown-unknown -p sugarloaf --tests

Flag explanation:

  • CARGO_TARGET_WASM32_UNKNOWN_UNKNOWN_RUNNER=wasm-bindgen-test-runner: Tells Cargo to use the test harness provided by wasm-bindgen-cli.
  • -p sugarloaf: Only run tests in the sugarloaf directory.
  • --tests: Only run tests; do not build examples. Many (possibly all) of the examples in sugarloaf/examples currently do not compile to WASM because they use networking.

Dependencies

~43–76MB
~1.5M SLoC