Stop AI hallucination. Ship working code.
48% of AI-generated code contains hallucinations - false claims, non-existent functions, or broken implementations. Developers waste countless hours debugging phantom code, losing context between sessions, and watching projects drift into chaos.
RFD enforces reality at every step. No more "I implemented that feature" when nothing works. No more mock data pretending to be production code. No more losing track of what you were building.
RFD (Reality-First Development) is a development protocol that makes AI hallucination physically impossible through continuous reality validation. Not just managing the LLM but also the human to help prevent squirrel brain and SDLC drift by enforcing concrete reality checkpoints. Instead of trusting AI claims about what was implemented, RFD validates the actual code runs, tests pass, and features work. It's not just another tool - it's a fundamental shift in how we build software with AI.
✅ Zero Hallucination - Every claim is validated against running code
✅ Persistent Context - Never lose your place, even across restarts
✅ Enforced Focus - Can't drift from specified features
✅ Real Code Only - No mocks, stubs, or placeholder implementations
✅ Universal Compatibility - Works with any language, any framework
- RFD Walkthrough - Complete step-by-step guide (NEW!)
- Getting Started Guide - 5-minute tutorial
- CLI Reference - All commands documented
- Claude Code Guide - AI integration guide
- Configuration Schema - Complete .rfd/config.yaml reference
- Installation Guide - Detailed setup instructions
# Install RFD
pip install rfd-protocol
# Initialize your project
cd your-project
rfd init --wizard
# Start building with database-first workflow
rfd feature add user_auth -d "User authentication"
rfd session start user_auth
rfd build
rfd validate
rfd checkpoint "Feature complete"That's it. RFD now guards your development.
# .rfd/config.yaml defines project configuration
project:
name: "My Project"
description: "Project managed by RFD"
stack:
language: python
framework: fastapi
database: postgresql
# Features stored in database (.rfd/memory.db)
$ rfd feature list
- user_auth: "Users can register and login" (pending)# AI claims: "I implemented user authentication"
$ rfd validate
❌ Reality Check Failed:
- No /register endpoint found
- No /login endpoint found
- 0 of 5 tests passing
- Database table 'users' does not exist$ rfd status
📊 Project Status
━━━━━━━━━━━━━━━━━━━━
Features: 1 pending, 0 complete
Current: user_auth (0% complete)
Next: Create user registration endpoint
Last Valid Checkpoint: 2 hours ago
"Database schema created"rfd init # Basic project setup
rfd init --wizard # Interactive setup (recommended)
rfd init --from-prd doc.md # Initialize from requirements doc
rfd init --mode brownfield # For existing projectsrfd audit # Database-first compliance check
rfd feature add <id> -d "desc" # Add feature to database
rfd feature list # List all features
rfd feature start <id> # Start working on feature
rfd session status # Show current session details
rfd session current # Alias for status
rfd gaps # Show gap analysis from database
rfd gaps --status missing # Show missing functionality
rfd gaps --priority critical # Show critical gapsrfd session start <feature> # Begin feature work
rfd build # Run build process
rfd validate # Validate implementation
rfd checkpoint "message" # Save progress
rfd session end # Complete featurerfd check # Quick status check
rfd status # Detailed project status
rfd audit # Database-first compliance check (NEW v5.0!)
rfd gaps # Gap analysis report (NEW v5.0!)
rfd analyze # Cross-artifact consistency check
rfd dashboard # Visual progress dashboard
rfd spec review # Review current specificationrfd revert # Revert to last checkpoint
rfd memory show # Display context memory
rfd memory reset # Clear context (careful!)- All features stored in SQLite database
- Immutable config in .rfd/config.yaml
- No more PROJECT.md/PROGRESS.md conflicts
- Protected context files with DO NOT EDIT warnings
- Write-Ahead Logging for better concurrency
- Persistent memory across all sessions
- Automatic crash recovery
- Zero configuration required
$ rfd analyze
CROSS-ARTIFACT ANALYSIS REPORT
════════════════════════════════
📋 SPEC ALIGNMENT
✅ All features aligned with specification
📝 TASK CONSISTENCY
✅ All tasks consistent with feature status
🔌 API IMPLEMENTATION
Coverage: 100.0%
✅ All endpoints implemented
🧪 TEST COVERAGE
Coverage: 87.5%
✅ All acceptance criteria coveredRFD automatically configures Claude Code to prevent hallucination:
# Tell Claude to continue your project
"Continue the RFD session"
# Claude automatically:
$ rfd check
> Current feature: user_auth
> Last checkpoint: "Created User model"
> Next task: Implement registration endpoint
# Claude reads (but never edits) context files:
$ cat .rfd/context/current.md # AUTO-GENERATED - DO NOT EDIT
# Claude cannot fake progress:
$ rfd checkpoint "Added authentication"
❌ Cannot checkpoint - validation failingFor other AI tools, enforce this workflow:
- Read
.rfd/config.yamlfor project configuration - Check
.rfd/context/current.mdfor current task (READ-ONLY) - Use
rfd feature listto see features from database - Run
rfd validateafter every change - Only checkpoint when validation passes
RFD uses a flexible, extensible configuration:
# Required Fields
project:
name: "Your Project"
description: "What it does"
version: "1.0.0"
# Technology Stack (extensible)
stack:
language: python
framework: fastapi
database: postgresql
# Add any custom fields:
runtime: python-3.11
deployment: kubernetes
monitoring: prometheus
# Validation Rules
rules:
max_files: 50
max_loc_per_file: 500
must_pass_tests: true
no_mocks_in_prod: true
min_test_coverage: 80
# Features are stored in database, not config file
# Use these commands to manage features:
# rfd feature add core_api -d "RESTful API" -a "All endpoints return correct data"
# rfd feature list
# rfd feature start core_api
# Constraints
constraints:
- "Response time < 200ms"
- "Support 10k concurrent users"
---Our repository follows modern Python packaging standards:
rfd-protocol/
├── src/rfd/ # 🎯 MAIN PACKAGE
│ ├── __init__.py
│ ├── cli.py # Command-line interface
│ ├── rfd.py # Core orchestration
│ ├── validation.py # Hallucination detection
│ ├── session.py # Session management
│ ├── build.py # Build automation
│ ├── spec.py # Specification management
│ ├── analyze.py # Cross-artifact analysis (NEW!)
│ ├── db_utils.py # WAL mode database (NEW!)
│ └── templates/ # Project templates
│
├── tests/ # 🧪 TEST SUITE
│ ├── unit/
│ ├── integration/
│ └── system/
│
├── docs/ # 📚 DOCUMENTATION
│ ├── RFD_WALKTHROUGH.md # Complete guide (NEW!)
│ └── [other docs]
│
└── .github/workflows/ # 🚀 CI/CD
├── ci.yml
└── release.yml # Auto PyPI publishing
pip install rfd-protocolcd your-project
python -m venv venv
source venv/bin/activate
pip install rfd-protocolgit clone https://github.com/kryptobaseddev/rfd-protocol.git
cd rfd-protocol
pip install -e .RFD works with any technology stack:
- Python: FastAPI, Django, Flask
- JavaScript/TypeScript: Express, Next.js, React
- Go: Gin, Echo, Fiber
- Rust: Actix, Rocket, Axum
- Java/Kotlin: Spring Boot
- C/C++: Any build system
- Ruby: Rails, Sinatra
- PHP: Laravel, Symfony
- And 20+ more...
- 48% hallucination rate
- Lost context after restarts
- Endless debugging of AI mistakes
- Projects that never ship
- 0% hallucination rate
- Perfect context persistence
- Only real, working code
- Consistent project delivery
# All tests
pytest
# By category
pytest -m unit # Fast unit tests
pytest -m integration # Integration tests
pytest -m system # End-to-end tests
# With coverage
pytest --cov=src/rfd --cov-report=html# Linting
ruff check src tests
# Formatting
ruff format src tests
# Type checking
mypy src --ignore-missing-importsYou tried to work on an undefined feature. Edit PROJECT.md first.
rfd validate --verbose # See detailed errors
rfd build # Fix build issues firstrfd check # Current status
cat .rfd/context/current.md # Session detailsexport RFD_DEBUG=1
rfd validate # Verbose outputWe welcome contributions! RFD uses itself for development:
- Fork the repository
- Run
rfd initin your fork - Create feature in PROJECT.md
- Use RFD workflow to implement
- Submit PR when
rfd validatepasses
git clone https://github.com/kryptobaseddev/rfd-protocol.git
cd rfd-protocol
pip install -e ".[dev]"
pytest # Run tests- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Documentation: Full docs
- Email: keatonhoskins@icloud.com
- v5.0.0: Complete database-first migration, protected context files, audit command, deprecated PROJECT.md
- v4.x: Transition to database-first architecture, config.yaml introduction
- v3.0.0: SQLite WAL mode, cross-artifact analysis, spec-kit feature parity
- v2.3.0: Mock detection, critical fixes, session persistence improvements
- v2.0.0: Spec generation, gated workflow, AI validation
- v1.0.0: Production release with modern Python packaging and full documentation
MIT License - see LICENSE
Built with RFD - This project dogfoods its own reality-first methodology.