Files
Claude-Code-Workflow/test-rules-cli-generation.md
catlog22 d91477ad80 feat: Implement CLAUDE.md Manager View with file tree, viewer, and metadata actions
- Added main JavaScript functionality for CLAUDE.md management including file loading, rendering, and editing capabilities.
- Created a test HTML file to validate the functionality of the CLAUDE.md manager.
- Introduced CLI generation examples and documentation for rules creation via CLI.
- Enhanced error handling and notifications for file operations.
2025-12-14 23:08:36 +08:00

139 lines
3.2 KiB
Markdown

# Test: Rules CLI Generation Feature
## Overview
This document demonstrates the CLI generation feature for Rules Manager.
## API Usage
### Endpoint
```
POST /api/rules/create
```
### Mode: CLI Generation
Set `mode: 'cli-generate'` in the request body.
## Generation Types
### 1. From Description
Generate rule from natural language description:
```json
{
"mode": "cli-generate",
"generationType": "description",
"description": "Always use TypeScript strict mode and proper type annotations",
"fileName": "typescript-strict.md",
"location": "project",
"subdirectory": "",
"projectPath": "D:/Claude_dms3"
}
```
### 2. From Template
Generate rule from template type:
```json
{
"mode": "cli-generate",
"generationType": "template",
"templateType": "error-handling",
"fileName": "error-handling-rules.md",
"location": "project",
"subdirectory": "",
"projectPath": "D:/Claude_dms3"
}
```
### 3. From Code Extraction
Extract rules from existing codebase:
```json
{
"mode": "cli-generate",
"generationType": "extract",
"extractScope": "ccw/src/**/*.ts",
"extractFocus": "error handling, async patterns, type safety",
"fileName": "extracted-patterns.md",
"location": "project",
"subdirectory": "",
"projectPath": "D:/Claude_dms3"
}
```
## Response Format
### Success Response
```json
{
"success": true,
"fileName": "typescript-strict.md",
"location": "project",
"path": "D:/Claude_dms3/.claude/rules/typescript-strict.md",
"subdirectory": null,
"generatedContent": "# TypeScript Strict Mode\n\n...",
"executionId": "1734168000000-gemini"
}
```
### Error Response
```json
{
"error": "CLI execution failed: ...",
"stderr": "..."
}
```
## Implementation Details
### Function: `generateRuleViaCLI()`
**Parameters:**
- `generationType`: 'description' | 'template' | 'extract'
- `description`: Rule description (for 'description' mode)
- `templateType`: Template type (for 'template' mode)
- `extractScope`: File pattern like 'src/**/*.ts' (for 'extract' mode)
- `extractFocus`: Focus areas like 'error handling, naming' (for 'extract' mode)
- `fileName`: Target file name (must end with .md)
- `location`: 'project' or 'user'
- `subdirectory`: Optional subdirectory within rules folder
- `projectPath`: Project root path
**Process:**
1. Build CLI prompt based on generation type
2. Execute Gemini CLI with 10-minute timeout
3. Extract generated content from stdout
4. Create rule file using `createRule()`
5. Return result with execution ID
### Prompt Templates
#### Description Mode
```
PURPOSE: Generate Claude Code memory rule from description
MODE: write
RULES: $(cat ~/.claude/workflows/cli-templates/prompts/universal/00-universal-rigorous-style.txt)
```
#### Extract Mode
```
PURPOSE: Extract coding rules from codebase
MODE: analysis
CONTEXT: @{extractScope}
RULES: $(cat ~/.claude/workflows/cli-templates/prompts/analysis/02-analyze-code-patterns.txt)
```
## Error Handling
- CLI execution timeout: 10 minutes (600000ms)
- Empty content validation
- File existence checking
- Generation type validation
## Integration
The feature integrates with:
- **cli-executor.ts**: For Gemini CLI execution
- **createRule()**: For file creation
- **Rules Manager UI**: For user interface (to be implemented)