Skip to content

c-d-cc/reap

Repository files navigation

한국어 | 日本語 | 简体中文 | Deutsch

REAP

REAP

Recursive Evolutionary Autonomous Pipeline
A self-evolving development pipeline where AI and humans co-evolve software across generations.

REAP Architecture

REAP is a generation-based development pipeline where AI and humans collaborate to build and evolve software. The human provides vision and makes key decisions. The AI learns the project's knowledge — Genome (architecture, conventions, constraints) and Environment (codebase, dependencies, domain) — then works through structured generations to implement, verify, and adapt. Each completed generation feeds lessons back into the knowledge base. Over time, both the knowledge and the source code (Civilization) self-evolve.

Table of Contents

What is REAP?

Have you ever run into these problems when developing with AI agents?

  • Context loss — The agent forgets everything when you start a new session
  • Scattered development — Code gets modified with no clear direction or goal
  • Design-code drift — Documentation diverges from actual implementation
  • Forgotten lessons — Hard-won insights never carry forward
  • Collaboration chaos — Multiple agents or developers produce conflicting changes

REAP solves these with a self-evolving generation model:

  • Each generation follows a structured lifecycle: learn the current state, plan a goal, implement, validate, and reflect
  • The AI agent automatically restores full project context at every session start
  • Prescriptive knowledge (Genome) evolves through human-approved adaptations at each generation's completion
  • The AI automatically selects goals by analyzing the gap between vision and current state
  • Clarity-driven interaction ensures the AI communicates with structure, examples, and honest opinions
  • Parallel work across branches is reconciled through a genome-first merge workflow

Installation

Global installation required.

npm install -g @c-d-cc/reap

Requirements: Node.js v18+, Claude Code CLI.

Quick Start

Open your AI agent (Claude Code) and use slash commands:

# Initialize REAP in your project (auto-detects greenfield vs existing codebase)
/reap.init

# Run a full generation
/reap.evolve

/reap.evolve drives the entire generation lifecycle — from learning through completion. The AI explores the project, plans the work, implements it, validates, and reflects. This is the primary command for day-to-day development.

Note: Users interact with REAP through /reap.* slash commands in their AI agent. The CLI is the internal engine that powers those commands.

Life Cycle

Each generation follows a five-stage lifecycle.

learning → planning → implementation ⟷ validation → completion
Stage What happens Artifact
Learning Explore the project, build context, review genome and environment 01-learning.md
Planning Define goal, decompose tasks, map dependencies 02-planning.md
Implementation Build with AI-human collaboration 03-implementation.md
Validation Run tests, verify completion criteria 04-validation.md
Completion Reflect, collect fitness feedback, adapt genome, archive 05-completion.md

Core Concepts

Genome — How to Build

The project's prescriptive knowledge. Three files, always fully loaded:

.reap/genome/
  application.md    # Project identity, architecture, conventions, constraints
  evolution.md      # AI behavior guide, evolution direction, soft lifecycle rules
  invariants.md     # Absolute constraints (human-only edits)

Environment — What Exists Now

The project's descriptive knowledge. Two-tier loading strategy:

.reap/environment/
  summary.md        # Always loaded at session start (~100 lines)
  domain/           # Domain knowledge (on-demand)
  resources/        # External reference documents — API docs, SDK specs (on-demand)
  docs/             # Project reference documents — design docs, specs (on-demand)
  source-map.md     # Current code structure + dependencies (on-demand)

Vision — Where We're Going

Long-term goals and direction. The AI references vision during the adapt phase to decide what's most valuable next.

.reap/vision/
  goals.md          # North star objectives
  docs/             # Planning documents
  memory/           # AI memory (3-tier: longterm, midterm, shortterm)

Backlog

Issues discovered during a generation are never fixed on the spot. They are logged as backlog items in .reap/life/backlog/:

  • type: genome-change — genome modifications to apply at adapt phase
  • type: environment-change — environment updates
  • type: task — work items for future generations

Backlog items carry over between generations automatically. Consumed items are archived with the generation's lineage.

Lineage — What We've Learned

Archive of completed generations with two-level automatic compression:

  • Level 1: Generation folder (5 artifacts) → single summary file
  • Level 2: 100+ Level 1 files → single epoch.md

DAG metadata is preserved for branch-aware lineage traversal.

Hooks

File-based lifecycle event hooks in .reap/hooks/:

  • .md files: AI prompts executed by the agent
  • .sh files: Shell scripts executed directly

Principles

  • Genome Immutability: The genome is never modified during a generation. Issues are logged in the backlog and applied at completion's adapt phase.
  • Environment Immutability: The environment is never modified directly during a generation. Changes are recorded in the backlog and applied at completion's reflect phase.
  • Human Judges Fitness: No quantitative metrics. The human's natural language feedback is the only fitness signal.
  • Self-fitness Prohibited: The AI never scores its own success. Only self-assessment (metacognition) is allowed.

Merge Lifecycle

When multiple developers or agents work in parallel, REAP provides a genome-first merge workflow.

detect → mate → merge → reconcile → validation → completion
Stage Purpose
Detect Identify divergence between branches
Mate Resolve genome conflicts first (human decides)
Merge Merge source code guided by finalized genome
Reconcile Verify genome-source consistency
Validation Run tests
Completion Commit merged result and archive

Self-Evolving Features

Gap-Driven Goal Selection

The AI automatically selects the next generation's goal by analyzing the gap between vision and current state. It cross-references unchecked goals in vision/goals.md with pending backlog items, prioritizes by impact, and proposes the most valuable next step. The human approves or adjusts.

Human Judges Fitness

No quantitative metrics. The human's natural language feedback during the fitness phase is the only fitness signal. The AI never scores its own success — only self-assessment (metacognition) is allowed.

Clarity-Driven Interaction

The AI adjusts its communication style based on how well-defined the current context is:

  • High clarity (clear goal, defined tasks) → Execute with minimal questions
  • Medium clarity (direction exists, details unclear) → Present 2-3 options with tradeoffs
  • Low clarity (ambiguous goal) → Active dialogue with examples to build shared understanding

Cruise Mode

Pre-approve N generations for autonomous execution:

  • The AI selects goals from vision gaps and runs the full lifecycle autonomously
  • If uncertainty or risk is detected, cruise pauses and requests human feedback
  • After all N generations complete, human reviews the batch

Slash Commands

Command Description
/reap.evolve Run an entire generation (recommended)
/reap.start Start a new generation
/reap.next Advance to the next stage
/reap.back Return to a previous stage
/reap.abort Abort current generation
/reap.knowledge Review and manage genome/environment
/reap.merge Merge lifecycle operations
/reap.pull Fetch + merge lifecycle
/reap.push Validate + push
/reap.status Check current state
/reap.help Show available commands
/reap.init Initialize REAP in a project
/reap.run Execute a lifecycle command directly
/reap.config View/edit project configuration

Agent Integration

REAP integrates with AI agents through slash commands and lifecycle hooks. Currently supported: Claude Code. The architecture uses an adapter pattern for future agent support.

How It Works

  1. CLAUDE.md instructs the AI to load genome, environment, and reap-guide at session start
  2. Slash commands call reap run <cmd>, which returns structured JSON instructions for the AI
  3. Signature-based locking (nonce chain) enforces stage ordering at the code level — no skipping, no forgery, no replay

Subagent Mode

/reap.evolve can delegate the entire generation to a subagent that runs autonomously through all stages, surfacing only when genuinely blocked.

Project Structure

my-project/
  src/                        # Your code
  .reap/
    config.yml                # Project configuration
    genome/                   # Prescriptive knowledge (3 files)
      application.md
      evolution.md
      invariants.md
    environment/              # Descriptive knowledge (2-tier)
      summary.md
      domain/
      resources/              # External reference docs (API, SDK)
      docs/                   # Project reference docs (design, specs)
      source-map.md
    vision/                   # Long-term goals
      goals.md
      docs/
      memory/                 # AI memory (longterm/midterm/shortterm)
    life/                     # Current generation
      current.yml
      backlog/
    lineage/                  # Completed generation archive
    hooks/                    # Lifecycle hooks (.md/.sh)

Configuration

Project settings in .reap/config.yml:

project: my-project # Project name
language: english # Artifact/prompt language
autoSubagent: true # Auto-delegate to subagent in evolve
strictEdit: false # Restrict code changes to REAP lifecycle
strictMerge: false # Restrict direct git pull/push/merge
agentClient: claude-code # AI agent client
# cruiseCount: 1/5             # Present = cruise mode (current/total)

Key settings:

  • cruiseCount: When present, enables cruise mode. Format current/total. Removed after cruise completes.
  • strictEdit: Restricts code changes to the implementation stage within the planned scope.
  • strictMerge: Restricts direct git pull/push/merge — use /reap.pull, /reap.push, /reap.merge instead.
  • agentClient: Determines which adapter is used for skill deployment.

Upgrading from v0.15

REAP v0.16 is a complete rewrite built on the Self-Evolving Pipeline architecture.

Migration Steps

  1. Install v0.16:

    npm install -g @c-d-cc/reap

    This automatically installs v0.16 skills to ~/.claude/commands/ and removes legacy v0.15 project-level skills.

  2. Open Claude Code in your project and run:

    /reap.update
    
  3. Follow the multi-phase migration:

    Phase What happens Your role
    Confirm Shows what will change, creates backup at .reap/v15/ Review and confirm
    Execute Restructures directories, migrates config/hooks/lineage/backlog Automatic
    Genome Convert AI reconstructs genome from v0.15 files into new 3-file structure Review AI's work
    Vision Set up vision/goals.md and memory Provide project direction
    Complete Summary of migration results Verify
  4. Verify your project works:

    /reap.status
    /reap.evolve
    

Interrupted Migration

If the migration is interrupted (API error, session disconnect, etc.), your progress is saved in .reap/migration-state.yml. Simply run /reap.update again — it will resume from where it left off, skipping already completed steps.

To start over instead, delete .reap/migration-state.yml and run /reap.update again.

Backup

All v0.15 files are preserved at .reap/v15/. After verifying the migration, you can safely delete this directory.

What Changed

Lifecycle redesigned:

  • The first stage is now learning (was objective). The AI explores the project before setting goals.
  • Completion is now 4 phases: reflectfitnessadaptcommit (was 5 phases).
  • New concepts: embryo generations, cruise mode, vision-driven planning.

Vision layer added:

  • vision/goals.md — long-term objectives, gap-driven goal selection at adapt phase
  • vision/memory/ — 3-tier memory (longterm, midterm, shortterm) for cross-generation context
  • vision/design/ — planning documents and specs

Genome restructured (3 files):

  • application.md — project identity, architecture, conventions, constraints
  • evolution.md — AI behavior guide, evolution direction, soft lifecycle rules
  • invariants.md — absolute constraints (human-only edits)

New features:

  • Clarity-driven interaction: AI adjusts communication depth based on context clarity
  • Cruise mode: pre-approve N generations, AI runs autonomously with self-assessment
  • Merge lifecycle with reconcile stage for genome-source consistency verification
  • Vision system with 3-tier memory for cross-generation context

Deprecated commands:

  • /reap.sync/reap.knowledge
  • /reap.refreshKnowledge/reap.knowledge

Author

HyeonIL Choihichoi@c-d.cc | c-d.cc | LinkedIn | GitHub

License

MIT

About

Recursive Evolutionary Autonomous Pipeline — AI and humans evolve software across generations

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors