Awesome-omni-skill codegen-sync
Verifies TypeScript codegen is in sync with Elixir protocol definitions. Use this skill after modifying Elixir structs, protocol messages, or RPC types in lib/opal/ to regenerate and verify the TypeScript client SDK types.
install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/codegen-sync" ~/.claude/skills/diegosouzapw-awesome-omni-skill-codegen-sync && rm -rf "$T"
manifest:
skills/development/codegen-sync/SKILL.mdsource content
Codegen Sync Skill
This project uses code generation to keep TypeScript SDK types in sync with Elixir protocol definitions. When Elixir types change, the TypeScript side must be regenerated.
When to act
- After modifying any Elixir structs, message types, or RPC definitions in
.lib/opal/ - After adding or changing tool schemas in
.lib/opal/tool/ - When CI fails with a codegen drift error.
- When the user asks to sync or regenerate types.
Commands
# Run codegen (Elixir -> TypeScript) mix run scripts/codegen_ts.exs # Verify codegen is up to date (what CI runs) mix run scripts/codegen_ts.exs --check
Workflow
- After modifying Elixir protocol types, run
.mix run scripts/codegen_ts.exs - Review the generated diff in
to verify correctness.cli/src/sdk/ - Include the regenerated files in the same commit as the Elixir changes.
Rules
- Never hand-edit generated files. Always regenerate from the Elixir source.
- If codegen output looks wrong, fix the Elixir definitions or the codegen script (
), not the output.scripts/codegen_ts.exs - Always commit codegen output alongside the source changes — never in a separate commit.