Motiejus Jakštys 68d0917ec3 astgen: fix build.zig corpus - call payload, condbr, for loop, ResultCtx
Major fixes to match upstream AstGen.zig:
- Call/FieldCall: flags at offset 0, scratch_extra for arg bodies,
  pop_error_return_trace from ResultCtx instead of hardcoded true
- CondBr: write {condition, then_body_len, else_body_len} then bodies
  (was interleaving lengths with bodies)
- For loop: use instructionsSliceUpto, resurrect loop_scope for
  increment/repeat after then/else unstacked
- validate_struct_init_result_ty: un_node encoding (no extra payload)
- addEnsureResult: flags always at pi+0 for all call types
- addFunc: param_insts extra refs for correct body attribution
- array_init_elem_type: addBin instead of addPlNodeBin
- Pre-register struct field names for correct string ordering
- comptime break_inline: AST_NODE_OFFSET_NONE
- varDecl: pass RI_CTX_CONST_INIT context
- Rewrite test infrastructure with field-by-field ZIR comparison

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-13 12:51:43 +00:00
2026-02-13 11:37:57 +02:00
fmt
2025-01-08 19:04:40 +01:00
2026-02-10 10:03:44 +00:00
2026-02-12 14:08:49 +02:00
2026-02-13 08:00:57 +00:00
2026-02-11 18:14:32 +00:00
2026-02-10 11:35:41 +00:00
2026-02-12 16:13:56 +02:00
2026-02-12 14:06:15 +02:00
2026-02-12 16:13:56 +02:00
2026-02-12 16:13:56 +02:00
2026-02-10 11:35:41 +00:00
2025-07-01 19:48:18 +00:00

About

zig0 aspires to be an interpreter of zig 0.15.1 written in C.

This is written with help from LLM:

  • Lexer:
    • Datastructures 100% human.
    • Helper functions 100% human.
    • Lexing functions 50/50 human/bot.
  • Parser:
    • Datastructures 100% human.
    • Helper functions 50/50.
    • Parser functions 5/95 human/bot.
  • AstGen: TBD.

Testing

Quick test:

zig build fmt test

Full test and static analysis with all supported compilers and valgrind (run before commit, takes a while):

zig build -Dvalgrind

Debugging tips

Test runs infinitely? Build the test program executable:

$ zig build test -Dno-exec

And then run it, capturing the stack trace:

gdb -batch \
    -ex "python import threading; threading.Timer(1.0, lambda: gdb.post_event(lambda: gdb.execute('interrupt'))).start()" \
    -ex run \
    -ex "bt full" \
    -ex quit \
    zig-out/bin/test

You are welcome to replace -ex "bt full" with anything other of interest.

Description
Replacing zig1.wasm with a C program (see stage0/).
Readme MIT 388 MiB
Languages
Zig 96.3%
C 2.7%
C++ 0.6%
Python 0.1%