One-time interactive setup to configure a project for autonomous development.
Purpose
Create CLAUDE.md and all project configuration files in .claude/ through an interactive process with auto-detection.
Execution Steps
Step 1: Check for Existing Configuration
First, check if configuration already exists:
ls CLAUDE.md .claude/testing.md .claude/code-standards.md .claude/architecture.md .claude/pipeline.md 2>/dev/null
If CLAUDE.md and all 4 config files exist, inform the user:
Project already configured. CLAUDE.md and config files exist in
.claude/. To reconfigure, delete CLAUDE.md and.claude/then run/project-setupagain.
Otherwise, continue with setup.
Step 2: Auto-Detect Project Type
Scan the project root for configuration files to detect the tech stack:
Check for these files (in parallel):
composer.json→ PHP/Laravel/Symfonypackage.json→ Node.js/React/Vue/Next.jsCargo.toml→ Rustgo.mod→ Gopyproject.tomlorrequirements.txt→ PythonGemfile→ Ruby/Railspom.xmlorbuild.gradle→ Java*.csprojor*.sln→ .NET
For each detected file, extract:
- Framework and version
- Testing framework (from devDependencies or test config)
- Linting/formatting tools
Example auto-detection output:
Detected project configuration:
- Framework: Laravel 11 (from composer.json)
- PHP Version: 8.3
- Testing: Pest PHP (from composer.json require-dev)
- Linting: Laravel Pint (from composer.json require-dev)
Step 3: Confirm Detection
Ask user to confirm detected configuration:
I detected the following. Is this correct? (y/n) [Show detected config]
If incorrect, ask clarifying questions about each incorrect item.
Step 4: Gather Additional Information
Ask these questions (skip if already detected):
Q1: Test Command
What command runs your tests? Detected:
./vendor/bin/pest[Enter to confirm or type custom]
Q1b: Parallel Test Command
Does your test runner support parallel execution? If so, what's the command? (e.g.,
./vendor/bin/pest --parallel,npm test -- --parallel,pytest -n auto,go test ./... -parallel 4) [Enter detected parallel command, type custom, or 'none' if not supported]
Auto-detect hints:
composer.jsonhasbrianium/paratestorpestphp/pest→ suggest{test command} --parallelpackage.jsonhasjest→ suggest{test command} --runInBandis serial, default is already parallelpackage.jsonhasvitest→ already parallel by defaultpytestwithpytest-xdist→ suggestpytest -n autogo test→ suggestgo test ./... -parallel {num}cargo test→ already parallel by default
Q2: Lint Command
What command runs your linter? Detected:
./vendor/bin/pint[Enter to confirm or type custom]
Q3: Architectural Patterns
Which patterns does this project use? (select all that apply)
- Repository pattern
- Service classes
- Form requests / DTOs
- Event sourcing
- CQRS
- Other (specify)
Q4: Code Standards
Any specific coding standards or style guides? Detected: PSR-12 [Enter to confirm or specify]
Q5: Coverage Requirements
Minimum test coverage percentage? (e.g., 80) Default: 80
Step 5: Open-Ended Project Dump
Offer the user a chance to provide additional context:
Tell me anything else about your project I should know.
You can paste:
- README content
- Architecture decisions
- Naming conventions
- Special requirements
- Team preferences
(Paste below, then type 'done' on a new line when finished, or 'skip' to skip)
Parse the dump for:
- Directory structure descriptions
- Naming conventions
- Special patterns or rules
- Integration details
Step 6: Create Configuration Files
Create the .claude/ directory and all config files:
mkdir -p .claude
Add .claude/ralph-loop.local.md to .gitignore:
Check if .gitignore exists and whether it already contains the entry. If not, append it:
# Ensure ralph-wiggum local state is gitignored
grep -qxF '.claude/ralph-loop.local.md' .gitignore 2>/dev/null || echo '.claude/ralph-loop.local.md' >> .gitignore
Note: The templates below show the minimum required sections. Expand each file with additional relevant details based on project complexity. For example, a framework project might include extensive architecture docs, while a simple app might stick closer to the minimum.
Create .claude/testing.md:
# Testing Configuration
## Test Framework
{detected framework}
## TDD Methodology
Each task follows strict Red → Green → Refactor:
1. Write failing test for one requirement
2. Write minimum code to pass
3. Refactor while tests stay green
4. Repeat for next requirement
5. Commit when task complete
## Commands
\`\`\`bash
# Run all tests (parallel)
{parallel test command, or test command if parallelism not supported}
# Run all tests (sequential, for debugging failures)
{test command}
# Run specific test file
{test command} {path placeholder}
# Run with coverage
{test command with coverage flag}
\`\`\`
## Parallel Execution
- **Default**: Always run tests in parallel unless debugging a specific failure
- Parallel command: `{parallel test command}`
- Sequential fallback: `{test command}` (use only when parallel causes flaky failures)
## Test File Locations
- Unit tests: `{detected or standard path}`
- Feature/Integration tests: `{detected or standard path}`
## Coverage Requirements
- Minimum: {specified}%
- New code must have tests
## Test Naming Convention
- Test files: `{Convention}Test.php` or `{convention}.test.ts`
- Test methods: `it {does something}` or `test {something}`
Optional expansions: Testing principles, framework-specific features, common test patterns, mocking strategies, CI configuration.
Create .claude/code-standards.md:
# Code Standards
## Style Guide
{detected or specified - e.g., PSR-12, Airbnb, StandardJS}
## Linting
\`\`\`bash
# Check for issues
{lint check command}
# Auto-fix issues
{lint fix command}
\`\`\`
## Formatting
\`\`\`bash
{format command if different from lint}
\`\`\`
## Pre-commit Checks
- Run linter before commits
- All tests must pass
- {any additional checks}
## Naming Conventions
- Classes: {PascalCase}
- Methods: {camelCase}
- Variables: {camelCase}
- Constants: {SCREAMING_SNAKE_CASE}
- Files: {convention}
Optional expansions: Code structure rules, attribute/decorator standards, documentation standards, pre-commit hooks, code review checklist.
Create .claude/architecture.md:
# Architecture
## Directory Structure
{Map out the key directories and their purposes}
Example:
- `app/Models/` - Eloquent models
- `app/Services/` - Business logic services
- `app/Http/Controllers/` - HTTP request handlers
- `app/Http/Requests/` - Form request validation
- `tests/Unit/` - Unit tests (mirror app/ structure)
- `tests/Feature/` - Integration/feature tests
## Patterns Used
{List from user selection}
- Repository pattern: {yes/no + brief description}
- Service classes: {yes/no + brief description}
- etc.
## Conventions
{From user dump or defaults}
- One class per file
- Tests mirror source structure
- {any other conventions}
## Key Integrations
{If mentioned in dump}
Optional expansions: DI/IoC details, plugin/extension system, event system, routing, configuration, bootstrap process, error handling, versioning strategy.
Create .claude/pipeline.md:
Copy the default pipeline.md from the HCF plugin into the project's .claude/ directory. This defines which agents run at each phase of the workflow.
# Pipeline
Configure which agents run at each phase of the development workflow. Each entry is an agent name resolved from the project's `.claude/agents/` directory (local override) or the plugin's `agents/` directory (default).
## post-plan
- devils-advocate
## post-implementation