rullama 0.2.0

Browser-resident Gemma 4 inference: pure Rust → WebAssembly + WebGPU. Loads Ollama's on-disk GGUF blobs and runs the forward pass on the local GPU via hand-written WGSL.
Documentation
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
#
# When uploading crates to the registry Cargo will automatically
# "normalize" Cargo.toml files for maximal compatibility
# with all versions of Cargo and also rewrite `path` dependencies
# to registry (e.g., crates.io) dependencies.
#
# If you are reading this file be aware that the original Cargo.toml
# will likely look very different (and much more reasonable).
# See Cargo.toml.orig for the original contents.

[package]
edition = "2024"
rust-version = "1.91"
name = "rullama"
version = "0.2.0"
authors = ["Brainwires <brainwires.net@gmail.com>"]
build = false
publish = true
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Browser-resident Gemma 4 inference: pure Rust → WebAssembly + WebGPU. Loads Ollama's on-disk GGUF blobs and runs the forward pass on the local GPU via hand-written WGSL."
homepage = "https://github.com/Brainwires/rullama"
readme = "README.md"
keywords = [
    "gemma",
    "webgpu",
    "wasm",
    "inference",
    "llm",
]
categories = [
    "wasm",
    "graphics",
    "science",
]
license = "MIT OR Apache-2.0"
repository = "https://github.com/Brainwires/rullama"

[features]
cpu-reference = []
default = []

[lib]
name = "rullama"
crate-type = [
    "cdylib",
    "rlib",
]
path = "src/lib.rs"

[[example]]
name = "adapter_probe"
path = "examples/adapter_probe.rs"

[[example]]
name = "audio_parity"
path = "examples/audio_parity.rs"

[[example]]
name = "audio_perf"
path = "examples/audio_perf.rs"

[[example]]
name = "audio_smoke"
path = "examples/audio_smoke.rs"

[[example]]
name = "chained_smoke"
path = "examples/chained_smoke.rs"

[[example]]
name = "decode_ids"
path = "examples/decode_ids.rs"

[[example]]
name = "dequant_probe"
path = "examples/dequant_probe.rs"

[[example]]
name = "encode_check"
path = "examples/encode_check.rs"

[[example]]
name = "encode_lookup"
path = "examples/encode_lookup.rs"

[[example]]
name = "forward_parity"
path = "examples/forward_parity.rs"

[[example]]
name = "forward_smoke"
path = "examples/forward_smoke.rs"

[[example]]
name = "greedy_parity"
path = "examples/greedy_parity.rs"

[[example]]
name = "inspect"
path = "examples/inspect.rs"

[[example]]
name = "kv_dump_load_roundtrip"
path = "examples/kv_dump_load_roundtrip.rs"

[[example]]
name = "list_tensors"
path = "examples/list_tensors.rs"

[[example]]
name = "matmul_bench"
path = "examples/matmul_bench.rs"

[[example]]
name = "model_api"
path = "examples/model_api.rs"

[[example]]
name = "vision_parity"
path = "examples/vision_parity.rs"

[[example]]
name = "vision_perf"
path = "examples/vision_perf.rs"

[[example]]
name = "vision_smoke"
path = "examples/vision_smoke.rs"

[dependencies.async-trait]
version = "0.1.89"

[dependencies.bytemuck]
version = "1.25"
features = ["derive"]

[dependencies.futures-channel]
version = "0.3.32"
features = ["alloc"]
default-features = false

[dependencies.futures-util]
version = "0.3.32"
features = ["alloc"]
default-features = false

[dependencies.half]
version = "2.7"
features = ["bytemuck"]

[dependencies.log]
version = "0.4.29"

[dependencies.serde]
version = "1.0.228"
features = ["derive"]

[dependencies.serde_json]
version = "1.0.149"

[dependencies.thiserror]
version = "2.0.18"

[dependencies.wgpu]
version = "29.0.3"

[target.'cfg(not(target_arch = "wasm32"))'.dependencies.env_logger]
version = "0.11.10"

[target.'cfg(not(target_arch = "wasm32"))'.dependencies.pollster]
version = "0.4.0"

[target.'cfg(target_arch = "wasm32")'.dependencies.console_error_panic_hook]
version = "0.1.7"

[target.'cfg(target_arch = "wasm32")'.dependencies.console_log]
version = "1.0.0"

[target.'cfg(target_arch = "wasm32")'.dependencies.js-sys]
version = "0.3.98"

[target.'cfg(target_arch = "wasm32")'.dependencies.rsqlite-wasm]
version = "0.1"

[target.'cfg(target_arch = "wasm32")'.dependencies.serde-wasm-bindgen]
version = "0.6.5"

[target.'cfg(target_arch = "wasm32")'.dependencies.wasm-bindgen]
version = "0.2.121"

[target.'cfg(target_arch = "wasm32")'.dependencies.wasm-bindgen-futures]
version = "0.4.71"

[target.'cfg(target_arch = "wasm32")'.dependencies.web-sys]
version = "0.3.98"
features = [
    "Navigator",
    "Window",
    "WorkerGlobalScope",
    "WorkerNavigator",
    "Gpu",
    "GpuAdapter",
    "GpuDevice",
    "Headers",
    "Request",
    "RequestInit",
    "Response",
]