Install
openclaw skills install baml-codegenUse when generating BAML code for type-safe LLM extraction, classification, RAG, or agent workflows - creates complete .baml files with types, functions, clients, tests, and framework integrations from natural language requirements. Queries official BoundaryML repositories via MCP for real-time patterns. Supports multimodal inputs (images, audio), Python/TypeScript/Ruby/Go, 10+ frameworks, 50-70% token optimization, 95%+ compilation success.
openclaw skills install baml-codegenGenerate type-safe LLM extraction code. Use when creating structured outputs, classification, RAG, or agent workflows.
baml_client/ - 100% generated, overwritten on every baml-cli generate; check baml_src/generators.baml for output_type (python, typescript, ruby, go)baml_src/ - Source of truth for all BAML codebaml-cli generate after changes - Regenerates typed client code for target language.baml → generate native code (Python/TypeScript/Ruby/Go), no runtime dependencybaml-cli test to iterateAnalyze → Pattern Match (MCP) → Validate → Generate → Test → Deliver
↓ [IF ERRORS] Error Recovery (MCP) → Retry
| Element | Example |
|---|---|
| Class | class Invoice { total float @description("Amount") @assert(this > 0) @alias("amt") } |
| Enum | enum Category { Tech @alias("technology") @description("Tech sector"), Finance, Other } |
| Function | function Extract(text: string, img: image?) -> Invoice { client GPT5 prompt #"{{ text }} {{ img }} {{ ctx.output_format }}"# } |
| Client | client<llm> GPT5 { provider openai options { model gpt-5 } retry_policy Exponential } |
| Fallback | client<llm> Resilient { provider fallback options { strategy [FastModel, SlowModel] } } |
string, int, float, bool | Multimodal: image, audioType[] (array), Type? (optional), map<string, Type> (key-value)Type1 | Type2 (union), nested classes@description("..."), @assert(condition), @alias("json_name"), @check(name, condition)openai, anthropic, gemini, vertex, bedrock, ollama + any OpenAI-compatible via openai-generic
| Pattern | Use Case | Model | Framework Markers |
|---|---|---|---|
| Extraction | Unstructured → structured | GPT-5 | fastapi, next.js |
| Classification | Categorization | GPT-5-mini | any |
| RAG | Answers with citations | GPT-5 | langgraph |
| Agents | Multi-step reasoning | GPT-5 | langgraph |
| Vision | Image/audio data extraction | GPT-5-Vision | multimodal |
retry_policy Exp { max_retries 3 strategy { type exponential_backoff } }[FastCheap, SlowReliable] for cost/reliability tradeoff.baml files (types, functions, clients, retry_policy)