14 releases (5 breaking)

0.6.0 Aug 22, 2024
0.5.0 Mar 14, 2024
0.4.0 Feb 27, 2024
0.3.1 Jan 5, 2024
0.1.3 Dec 10, 2022

#72 in WebAssembly

Download history 3344/week @ 2024-09-16 3810/week @ 2024-09-23 2925/week @ 2024-09-30 2522/week @ 2024-10-07 3159/week @ 2024-10-14 3807/week @ 2024-10-21 3246/week @ 2024-10-28 2632/week @ 2024-11-04 2733/week @ 2024-11-11 2938/week @ 2024-11-18 3247/week @ 2024-11-25 4363/week @ 2024-12-02 5632/week @ 2024-12-09 5111/week @ 2024-12-16 3224/week @ 2024-12-23 3425/week @ 2024-12-30

17,891 downloads per month
Used in 32 crates (2 directly)

MIT license

36KB
189 lines

sledgehammer bindgen

What is Sledgehammer Bindgen?

Sledgehammer bindgen provides faster rust batched bindings for js code.

How does this compare to wasm-bindgen:

  • wasm-bindgen is a lot more general it allows returning values and passing around a lot more different types of values. For most users wasm-bindgen is a better choice. Sledgehammer is specifically designed for web frameworks that want low-level, fast access to the dom.

  • You can use sledgehammer bindgen with wasm-bindgen. See the docs and examples for more information.

Why is it fast?

String decoding

  • Strings are expensive to decode, but the cost doesn't change much with the size of the string. Wasm-bindgen calls TextDecoder.decode for every string. Sledgehammer only calls TextEncoder.decode once per batch.

  • If the string is small, it is faster to decode the string in javascript to avoid the constant overhead of TextDecoder.decode

  • See this benchmark: https://jsbench.me/4vl97c05lb/5

String Caching

  • You can cache strings in javascript to avoid decoding the same string multiple times.
  • If the string is static sledgehammer will hash by pointer instead of by value.

Byte encoded operations

  • In sledgehammer every operation is encoded as a sequence of bytes packed into an array. Every operation takes 1 byte plus whatever data is required for it.

  • Each operation is encoded in a batch of four as a u32. Getting a number from an array buffer has a high constant cost, but getting a u32 instead of a u8 is not more expensive. Sledgehammer bindgen reads the u32 and then splits it into the 4 individual bytes. It will shuffle and pack the bytes into as few buckets as possible and try to inline reads into js.

  • See this benchmark: https://jsbench.me/csl9lfauwi/2

Dependencies

~215–770KB
~18K SLoC