3 releases (breaking)
Uses new Rust 2024
| new 0.7.0-beta.1 | Mar 8, 2026 |
|---|---|
| 0.6.0-beta.1 | Mar 8, 2026 |
| 0.5.0-alpha.1 | Mar 7, 2026 |
#1306 in Programming languages
Used in intent-implement
150KB
3.5K
SLoC
intent-gen
Natural language to IntentLang spec generation via LLM (Layer 0) for IntentLang.
Part of the IntentLang toolchain — a declarative specification language for human-AI collaboration.
What it does
Translates natural language descriptions into valid .intent specification files using an OpenAI-compatible LLM API. Implements a generate-check-retry loop: the LLM output is parsed and validated, and if validation fails, errors are fed back to the LLM for correction.
- Generation — describe what you want in plain English, get a valid
.intentspec - Editing — modify existing specs with natural language instructions
- Validation loop — auto-validates output via parser/checker, retries with error feedback
- Model-agnostic — works with any OpenAI-compatible API (OpenAI, Anthropic, Ollama, vLLM)
- Confidence levels — 1 (conservative) to 5 (comprehensive) controls generation scope
Usage
use intent_gen::{LlmClient, GenerateOptions, generate};
let client = LlmClient::from_env().unwrap();
let spec = generate(&client, "a user authentication system with login and logout", &GenerateOptions::default()).unwrap();
println!("{}", spec);
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
AI_API_KEY |
Yes | — | API key for the LLM provider |
AI_API_BASE |
No | https://api.openai.com/v1 |
Base URL for the API |
AI_MODEL |
No | gpt-4o |
Model identifier |
Modules
| Module | Description |
|---|---|
client |
LLM API client (OpenAI-compatible chat completions) |
prompt |
System prompt construction with syntax reference |
validate |
Generate-check-retry loop with parser/checker feedback |
Part of IntentLang
This crate is the natural language generation layer (Layer 0). Other crates in the workspace:
- intent-parser — PEG parser and typed AST
- intent-check — Semantic analysis and type checking
- intent-render — Markdown, HTML rendering, and formatting
- intent-ir — IR lowering, verification, audit bridge
- intent-cli — CLI binary (
intent generate,intent check, etc.)
Dependencies
~13MB
~241K SLoC