- Discord: https://discord.gg/adqBRq7Ece
- Rik Arends: https://twitter.com/rikarends
- Eddy Bruel: -
- Sebastian Michailidis: https://bsky.app/profile/okpokpokp.bsky.social
Makepad is an AI-accelerated application development environment for Rust. It combines a high-performance UI runtime, a live-editable design language, and a fast iteration loop so you can build native and web apps with a tight feedback cycle.
This repository contains the core engine, widgets, tools, and examples.
- A cross-platform UI runtime for native and web targets.
- A Rust-first framework with a scriptable UI DSL.
- A studio app for running, inspecting, and iterating on examples and projects.
- An AI-accelerated workflow: structure and tooling aimed at making code generation, refactoring, and iteration faster and safer.
- Streaming Splash: fast, animated, streaming UI example.
- Script Engine: live-editable UI DSL and runtime script integration.
- 3D Rendering: glTF example with GPU rendering.
- Maps: built-in map rendering with downloadable tiles.
- Voice Analysis: built-in voice support with Whisper model downloads.
- GPU-accelerated 2D and 3D rendering.
- AI automation inside Studio to control and inspect UI.
- Rust toolchain (stable works for native).
- For non-standard targets (iOS, tvOS, Android, wasm), install the Makepad build tool:
cargo install --path=./tools/cargo_makepadThen install target toolchains as needed:
cargo makepad wasm install-toolchain
cargo makepad apple ios install-toolchain
cargo makepad apple tvos install-toolchain
cargo makepad android --abi=all install-toolchainLinux build/runtime dependencies are listed in ./tools/linux_deps.sh:
Use the apt-get command below, or run the script on Ubuntu/WSL2:
sudo apt-get update && sudo apt-get install -y --no-install-recommends build-essential pkg-config clang ca-certificates libssl-dev libx11-dev libxcursor-dev libxkbcommon-dev libxrandr-dev libxi-dev libxinerama-dev libasound2-dev libpulse-dev libwayland-dev wayland-protocols libegl1-mesa-dev libgl1-mesa-dev libgles2-mesa-dev libglx-dev libdrm-dev libgbm-dev libgl1-mesa-dri mesa-vulkan-drivers mesa-utils mesa-utils-extra x11-appsMakepad Studio is the main entry point for exploring examples and iterating on UI.
cargo run -p makepad-studio --releaseIf you want a local install (note: may lag the repo):
cargo install makepad-studioRun a few representative apps directly from the repo:
# Splash (simple animated demo)
cargo run -p makepad-example-splash --release
# 3D rendering (glTF)
cargo run -p makepad-example-gltf --release
# Maps
cargo run -p makepad-example-map --releaseFor built-in maps and voice support, download the assets first:
./download_map.sh
./download_voice.sh- Install toolchain:
cargo makepad wasm install-toolchain- Run an example:
cargo makepad wasm run -p makepad-example-splash --releaseFor smaller shipped wasm output, use the shipping-size optimization pass. It keeps the post-link size reduction behavior and pairs well with the existing small profile:
cargo makepad wasm build -p makepad-example-splash --profile=small --stripTo split the wasm payloads, add --split. Bare --split uses an automatic cold-first policy: it first moves defer-safe cold functions into a secondary wasm so startup can begin on the primary first, and if there are no useful cold candidates it falls back to the normal function split. To override the function-splitting threshold directly:
cargo makepad wasm build -p makepad-example-splash --release --strip --split=200For maximum size reduction, combine --wasm-opt (Binaryen IR optimization) and --brotli (compression). Install Binaryen for --wasm-opt (e.g. brew install binaryen or apt install binaryen):
cargo makepad wasm build -p makepad-example-splash --release --wasm-opt --strip --split --brotliNotes:
--stripstrips custom sections (names, producers, etc.) for smaller binaries.--strip-custom-sectionspreserves the old behavior when you only want to remove custom sections.--wasm-optruns Binaryenwasm-opt -Osfor IR-level optimization (optional; requires Binaryen).--brotlicompresses.wasmand assets with Brotli for delivery.--profile=smalluses smaller fonts and pairs well with--strip.--no-threadstrims the web thread bridge and thread exports when threading is disabled.- The wasm linker packs relocations before the post-link size and split passes.
--splitemits a primary wasm plus secondary payloads (.secondary.wasm,.data.bin) and implies function splitting.- Bare
--splituses an automatic cold-first split policy. - Auto mode defers the secondary when it finds defer-safe cold functions, otherwise falls back to the normal startup-path split.
--split=200switches to an explicit function-body threshold (bytes).
- Open:
http://127.0.0.1:8010
Plug in a device with developer mode enabled, then:
- Install toolchain:
cargo run -p cargo-makepad --release -- android --target=all toolchain-install- Run an example:
cargo run -p cargo-makepad --release -- android run -p makepad-example-ironfish- Studio uses
cargo-makepadinternally for non-standard targets.