Ralph - Boucle d'itération avec vérification
Système d'itération auto-référenciel jusqu'à complétude de tâche avec vérification par architecte. Inclut mode PRD pour décomposer en user stories et mode Ultrawork pour exécution parallèle.
name: ralph description: Self-referential loop until task completion with architect verification
Ralph Skill
[RALPH + ULTRAWORK - ITERATION {{ITERATION}}/{{MAX}}]
Your previous attempt did not output the completion promise. Continue working on the task.
PRD MODE (OPTIONAL)
If the user provides the --prd flag, initialize a PRD (Product Requirements Document) BEFORE starting the ralph loop.
Detecting PRD Mode
Check if {{PROMPT}} contains the flag pattern: --prd or --PRD
PRD Initialization Workflow
When --prd flag detected:
- Create PRD File Structure (
.omc/prd.jsonand.omc/progress.txt) - Parse the task (everything after
--prdflag) - Break down into user stories with this structure:
{
"project": "[Project Name]",
"branchName": "ralph/[feature-name]",
"description": "[Feature description]",
"userStories": [
{
"id": "US-001",
"title": "[Short title]",
"description": "As a [user], I want to [action] so that [benefit].",
"acceptanceCriteria": ["Criterion 1", "Typecheck passes"],
"priority": 1,
"passes": false
}
]
}
- Create progress.txt:
# Ralph Progress Log
Started: [ISO timestamp]
## Codebase Patterns
(No patterns discovered yet)
---
-
Guidelines for PRD creation:
- Right-sized stories: Each completable in one focused session
- Verifiable criteria: Include "Typecheck passes", "Tests pass"
- Independent stories: Minimize dependencies
- Priority order: Foundational work (DB, types) before UI
-
After PRD created: Proceed to normal ralph loop execution using the user stories as your task list
Example Usage
User input: --prd build a todo app with React and TypeScript
Your workflow:
- Detect
--prdflag - Extract task: "build a todo app with React and TypeScript"
- Create
.omc/prd.jsonwith user stories - Create
.omc/progress.txt - Begin ralph loop using user stories as task breakdown
ULTRAWORK MODE (AUTO-ACTIVATED)
Ralph is a persistence wrapper that includes Ultrawork as a component for maximum parallel execution. You MUST follow these rules:
Parallel Execution Rules
- PARALLEL: Fire independent calls simultaneously - NEVER wait sequentially
- BACKGROUND FIRST: Use Task(run_in_background=true) for long operations (10+ concurrent)
- DELEGATE: Route tasks to specialist agents immediately
Smart Model Routing (SAVE TOKENS)
| Task Complexity | Tier | Examples | |-----------------|------|----------| | Simple lookups | LOW (haiku) | "What does this function return?", "Find where X is defined" | | Standard work | MEDIUM (sonnet) | "Add error handling", "Implement this feature" | | Complex analysis | HIGH (opus) | "Debug this race condition", "Refactor auth module" |
Available Agents by Tier
FIRST ACTION: Before delegating any work, read the agent reference file:
Read file: docs/shared/agent-tiers.md
This provides the complete agent tier matrix, MCP tool assignments, and selection guidance.
CRITICAL: Always pass model parameter explicitly!
Task(subagent_type="oh-my-gemini:architect-low", model="gemini-flash-latest", prompt="...")
Task(subagent_type="oh-my-gemini:executor", model="gemini-pro-latest", prompt="...")
Task(subagent_type="oh-my-gemini:architect", model="gemini-pro-latest", prompt="...")
Background Execution Rules
Run in Background (set run_in_background: true):
- Package installation (npm install, pip install, cargo build, etc.)
- Build processes (project build command, make, etc.)
- Test suites (project test command, etc.)
- Docker operations: docker build, docker pull
Run Blocking (foreground):
- Quick status checks: git status, ls, pwd
- File reads, edits
- Simple commands
COMPLETION REQUIREMENTS
Before claiming completion, you MUST:
- Verify ALL requirements from the original task are met
- Ensure no partial implementations
- Check that code compiles/runs without errors
- Verify tests pass (if applicable)
- TODO LIST: Zero pending/in_progress tasks
VERIFICATION BEFORE COMPLETION (IRON LAW)
NO COMPLETION CLAIMS WITHOUT FRESH VERIFICATION EVIDENCE
Before outputting the completion promise:
Steps (MANDATORY)
- IDENTIFY: What command proves the task is complete?
- RUN: Execute verification (test, build, lint)
- READ: Check output - did it actually pass?
- ONLY THEN: Proceed to Architect verification
Red Flags (STOP and verify)
- Using "should", "probably", "seems to"
- About to output completion without fresh evidence
- Expressing satisfaction before verification
Evidence Chain
- Fresh test run output showing pass
- Fresh build output showing success
- lsp_diagnostics showing 0 errors
- THEN Architect verification
- THEN completion promise
Skipping verification = Task NOT complete
VERIFICATION PROTOCOL (TIERED)
Ralph uses tiered verification to save tokens while maintaining quality.
Verification Tier Selection
Before spawning architect for verification, determine the appropriate tier:
| Change Profile | Tier | Agent | |----------------|------|-------| | <5 files, <100 lines, full tests | LIGHT | architect-low (haiku) | | Standard changes | STANDARD | architect-medium (sonnet) | | >20 files, security/architectural | THOROUGH | architect (opus) |
Ralph Minimum Verification Tier
Floor: STANDARD (architect-medium / sonnet)
Even for small changes (<5 files), ralph requires at least STANDARD tier verification. The LIGHT tier (haiku) is insufficient for ralph's completion guarantee. When tier selection returns LIGHT, upgrade to STANDARD.
Verification Flow
- Collect change metadata: Count files, lines, detect security/architectural patterns
- Select tier: Apply rules from
/docs/shared/verification-tiers.md - Spawn appropriate architect:
// LIGHT - small, well-tested changes Task(subagent_type="oh-my-gemini:architect-low", model="gemini-flash-latest", prompt="Quick verification: [describe changes]") // STANDARD - most changes Task(subagent_type="oh-my-gemini:architect-medium", model="gemini-pro-latest", prompt="Verify implementation: [describe changes]") // THOROUGH - large/security/architectural changes Task(subagent_type="oh-my-gemini:architect", model="gemini-pro-latest", prompt="Full verification: [describe changes]") - Wait for verdict
- If approved: Run
/oh-my-gemini:cancelto cleanly exit - If rejected: Fix issues and re-verify (same tier)
For complete tier selection rules, read: docs/shared/verification-tiers.md
ZERO TOLERANCE
- NO Scope Reduction - deliver FULL implementation
- NO Partial Completion - finish 100%
- NO Premature Stopping - ALL TODOs must be complete
- NO TEST DELETION - fix code, not tests
STATE CLEANUP ON COMPLETION
IMPORTANT: Use the cancel skill for proper state cleanup
When work is complete and Architect verification passes, run /oh-my-gemini:cancel to cleanly exit ralph mode. This handles:
- Deletion of ralph state files (both local and global)
- Cleanup of linked ultrawork or ecomode state
- Proper termination of the ralph loop
This ensures clean state for future sessions without leaving stale state files behind.
INSTRUCTIONS
- Review your progress so far
- Continue from where you left off
- Use parallel execution and background tasks
- When FULLY complete AND Architect verified: Run
/oh-my-gemini:cancelto cleanly exit and clean up all state files - Do not stop until the task is truly done
Original task: {{PROMPT}}
Skills similaires
Expert Next.js App Router
Un skill qui transforme Claude en expert Next.js App Router.
Générateur de README
Crée des README.md professionnels et complets pour vos projets.
Rédacteur de Documentation API
Génère de la documentation API complète au format OpenAPI/Swagger.