This document covers local setup, build/test commands, and release steps.
- Nix with flakes enabled
- macOS: Xcode Command Line Tools if you plan to use Homebrew dependencies
-
(Optional) Pre-fetch the ghostty dependency to speed up the first build:
just setup
just setupcaches theghosttysource tarball; the regular build will fetch it automatically if you skip this step. -
Enter the development shell:
nix develop
Or, if using direnv:
direnv allow
On macOS hosts where the active
MacOSX.sdkonly exposesarm64etargets, Zig 0.15.2 can fail during native Darwin linking with errors such asundefined symbol: __availability_version_check. The upstream tracker for this regression is https://codeberg.org/ziglang/zig/issues/31756.The dev shell works around that by exposing
MacOSX15.4.sdkthrough a fakeDEVELOPER_DIRwhoseusr/bin/xcrunis a narrow shim forxcrun --sdk macosx --show-sdk-path.build.zigalso resolves framework paths throughDEVELOPER_DIRandxcrunbefore it falls back to hardcoded SDK locations, so the workaround does not need to forceSDKROOT. Keeping the shim inside the fake developer tree means tools likegitcan still invoke/usr/bin/xcrunwithout tripping over the overriddenDEVELOPER_DIR.Remove this workaround once Architect no longer uses Zig 0.15.2, or once Zig handles the arm64e-only macOS SDK stubs correctly. If the active
MacOSX.sdk/usr/lib/libSystem.tbdadvertisesarm64-macosagain, the shell hook becomes a no-op. -
Verify the environment:
zig version # Should show 0.15.2+ (compatible with ghostty-vt) just --list # Show available commands
Build the project:
just build
# or
zig buildBuild optimized release:
zig build -Doptimize=ReleaseFastRun the application:
just run
# or
zig build run- ghostty-vt is fetched as a pinned tarball via the Zig package manager (
build.zig.zon). - SDL3 and SDL3_ttf are provided by Nix. SDL3 is pinned to 3.4.0 via
overlays/sdl3-3-4-0.nixwith binaries cached in the publicforketyforkCachix to avoid rebuilds.
Run tests:
just test
# or
zig build testCheck formatting and script linting:
just lint
# or
zig fmt --check src/
shellcheck scripts/*.sh scripts/verify-setup.sh
ruff check scripts/*.pyFormat code:
zig fmt src/macOS release binaries are automatically built for both ARM64 (Apple Silicon) and x86_64 (Intel) architectures via GitHub Actions when a version tag is pushed:
git tag v0.1.0
git push origin v0.1.0The release workflow packages ad-hoc-signed app bundles with local codesign --sign -. It does not import macOS signing certificates, does not produce Developer ID-signed artifacts, and does not notarize the app. Release downloads therefore still require clearing the quarantine attribute after extraction, as described in the README installation instructions. You can also run the Release workflow manually with workflow_dispatch to validate the packaging flow before pushing a real release tag.
Each release includes:
architect-macos-arm64.tar.gz- Apple Siliconarchitect-macos-x86_64.tar.gz- Intel