zig-compiler
SKILL.md
Zig Compiler
Purpose
Guide agents through Zig compiler invocation: optimization modes, output types, zig cc as a C compiler drop-in, error message interpretation, and the Zig compilation pipeline.
Triggers
- "How do I compile a Zig program?"
- "What are Zig's optimization modes and when do I use each?"
- "How do I use zig cc to compile C code?"
- "How do I read Zig error messages?"
- "How do I compile a Zig library?"
- "What is zig ast-check?"
Workflow
1. Basic compilation
# Compile and run a single file
zig run src/main.zig
# Compile to executable
zig build-exe src/main.zig
# Compile to static library
zig build-lib src/mylib.zig
# Compile to shared library
zig build-lib src/mylib.zig -dynamic
# Compile to object file
zig build-obj src/main.zig
# Output name
zig build-exe src/main.zig -femit-bin=myapp
2. Optimization modes
| Mode | Flag | -O equiv |
Purpose |
|---|---|---|---|
Debug (default) |
-O Debug |
-O0 -g |
Fast compile, all safety checks, debug info |
ReleaseSafe |
-O ReleaseSafe |
-O2 + checks |
Optimized with safety checks retained |
ReleaseFast |
-O ReleaseFast |
-O3 |
Maximum speed, safety checks removed |
ReleaseSmall |
-O ReleaseSmall |
-Os |
Minimize binary size |
zig build-exe src/main.zig -O Debug # dev builds
zig build-exe src/main.zig -O ReleaseSafe # production with safety
zig build-exe src/main.zig -O ReleaseFast # max performance
zig build-exe src/main.zig -O ReleaseSmall # embedded/WASM
Safety checks in Debug and ReleaseSafe:
- Integer overflow → detected and panics with source location
- Array bounds checking → panics on OOB
- Null pointer dereference → panic (not crash)
unreachable→ panic- Enum tag validation → panic on bad cast
ReleaseFast: turns safety checks into undefined behaviour (same semantics as C -O3). Use only when you've validated with ReleaseSafe first.
3. Target specification
# List all supported targets
zig targets
# Cross-compile for specific target
zig build-exe src/main.zig \
-target aarch64-linux-gnu \
-O ReleaseFast
# Embedded (no OS)
zig build-exe src/main.zig \
-target thumb-freestanding-eabi \
-O ReleaseSmall
# WebAssembly
zig build-exe src/main.zig \
-target wasm32-freestanding \
-O ReleaseSmall \
--export=main
# Common target triples: cpu-os-abi
# x86_64-linux-gnu, x86_64-windows-gnu, aarch64-macos-none
# thumbv7m-freestanding-eabi, wasm32-wasi, wasm32-freestanding
4. zig cc — C compiler drop-in
Zig ships a C/C++ compiler (zig cc / zig c++) backed by Clang and musl. It is hermetic — no system libc required.
# Compile C code
zig cc -O2 -Wall main.c -o myapp
# Compile C++ code
zig c++ -std=c++17 -O2 main.cpp -o myapp
# Cross-compile C for ARM (no cross toolchain needed!)
zig cc -target aarch64-linux-gnu -O2 main.c -o myapp-arm
# Statically link with musl
zig cc -target x86_64-linux-musl main.c -o myapp-static
# Use in CMake (override compiler)
CC="zig cc" CXX="zig c++" cmake -S . -B build
cmake --build build
# Use in Makefile
CC="zig cc" make
zig cc advantages over gcc/clang:
- No system toolchain required (fully hermetic)
- Built-in cross-compilation for any supported target
- Always ships with a recent clang version
- musl libc bundled for static Linux builds
5. Emit formats
# Emit LLVM IR
zig build-exe src/main.zig --emit-llvm-ir
# Emit assembly
zig build-exe src/main.zig --emit-asm
cat main.s
# Emit binary and assembly
zig build-exe src/main.zig -femit-bin=myapp -femit-asm=myapp.s
6. AST check and syntax validation
# Check syntax without compiling
zig ast-check src/main.zig
# Format code
zig fmt src/main.zig
zig fmt src/ # format entire directory
# Check formatting without modifying
zig fmt --check src/
# Tokenize (debugging zig fmt)
zig tokenize src/main.zig
7. Reading Zig error messages
Zig error messages include:
- Source file and line
- Column indicator with arrow
- Note messages for context
src/main.zig:10:5: error: expected type 'u32', found 'i32'
x: i32 = 5,
^
src/main.zig:7:5: note: struct field 'x' declared here
x: u32,
^
Key error patterns:
| Error | Meaning |
|---|---|
error: expected type 'X', found 'Y' |
Type mismatch |
error: use of undeclared identifier 'X' |
Missing import or typo |
error: integer overflow |
Comptime overflow (caught at compile) |
error: cannot assign to constant |
Mutating a const variable |
error: unused variable 'x' |
All variables must be used |
error: unused function parameter 'x' |
Use _ = x; to suppress |
Suppress "unused" errors:
_ = unused_variable; // explicitly discard
8. Version and environment
# Check Zig version
zig version
# Show build configuration
zig env
# Show standard library location
zig env | grep lib_dir
For optimization mode details and target triple reference, see references/zig-optimize-modes.md.
Related skills
- Use
skills/zig/zig-build-systemfor multi-file projects with build.zig - Use
skills/zig/zig-cinteropfor calling C from Zig and vice versa - Use
skills/zig/zig-crossfor cross-compilation targets and sysroots - Use
skills/zig/zig-debuggingfor GDB/LLDB with Zig binaries
Weekly Installs
26
Repository
mohitmishra786/…v-skillsGitHub Stars
27
First Seen
Feb 21, 2026
Security Audits
Installed on
opencode25
gemini-cli25
github-copilot25
codex25
kimi-cli25
amp25