A universal CLI utility to configure AI rules files for any project.
Project description
rules4
A universal CLI utility to configure AI rules files (e.g., .roo/rules, CLAUDE.md, .cursor/rules) for any project, based on the latest industry best practices via live Perplexity research.
Features
- 🔍 Automatic Project Analysis:
rules4 autointelligently detects your project's language, frameworks, and generates appropriate tags - 🎯 Smart Detection: Supports 50+ programming languages and 50+ frameworks (React, Django, FastAPI, etc.)
- ⚡ Zero Configuration: Works out-of-the-box without manual setup - just run
rules4 auto - 🛠️ Manual Control: Override auto-detection with
--langand--tagsoptions when needed - 🤖 Multi-Tool Support: Configures rules for Cursor, Roo, Claude, Copilot, and Cline
- 🔄 Flexible Model Selection: Use OpenAI or Anthropic models for both generation and review
- 🔀 Mix and Match: e.g., Claude for generation, GPT-4 for review
- 🔬 Live Research: Uses Perplexity API for up-to-date best practices
- 📋 Model Discovery: Built-in
--list-modelscommand to see all available models - 👀 Preview Mode: Dry-run mode to preview changes before writing
- ⚠️ Safe Defaults: Prompts before overwriting existing files
- 📦 Easy Install: Simple one-command install (packaged for PyPI)
- 🔮 Future Ready: Designed for MCP integration
Program Flow
The following diagram shows the core execution flow:
flowchart TD
A[CLI Command] --> B[Parse language and tags]
B --> C[Loop through each tag]
C --> D{Research enabled?}
D -->|Yes| E[Call Perplexity API]
D -->|No| F[Skip research]
E --> G[Primary model generates rules]
F --> G
G --> H{Review model specified?}
H -->|Yes| I[Review model refines rules]
H -->|No| J[Use original rules]
I --> K[Save to tool-specific folder]
J --> K
K --> L{More tags?}
L -->|Yes| C
L -->|No| M[Complete]
Installation
pip install rules4
Quick Start
🚀 The Smart Way (Recommended)
Let rules4 automatically analyze your project and generate intelligent rules:
# Automatically detect language, frameworks, and generate rules for all tools
rules4 auto
# Auto-detect with research for cutting-edge best practices
rules4 auto --research
# Auto-detect for a specific tool
rules4 auto cursor
# Auto-detect with model selection
rules4 auto --primary gpt-4-turbo --review claude-3-5-sonnet-20241022
🎯 The Manual Way
Or specify everything manually for precise control:
# For Cursor
rules4 cursor --lang python --tags "testing,security"
# For Claude with research
rules4 claude --research --lang javascript --tags "react,typescript"
# For all configured tools (requires initialization)
rules4 generate
⚙️ Configuration (Optional)
Initialize a configuration file for your project to set defaults:
rules4 init
This creates a .rules4rc file with default settings for batch operations.
API Keys and Environment Variables
rules4 interacts with various AI models and research services. To use these features, you need to set up the corresponding API keys as environment variables:
- OPENAI_API_KEY: Required for generating rules using OpenAI models (e.g.,
gpt-4-turbo,gpt-4o). - ANTHROPIC_API_KEY: Required for generating rules using Anthropic models (e.g.,
claude-3-5-sonnet-20241022,claude-3-opus-20240229). - PERPLEXITY_API_KEY: Required if you use the
--researchflag to perform research with Perplexity AI.
Example (add to your shell profile, e.g., ~/.bashrc or ~/.zshrc):
export OPENAI_API_KEY="your_openai_api_key"
export ANTHROPIC_API_KEY="your_anthropic_api_key"
export PERPLEXITY_API_KEY="your_perplexity_api_key"
Usage
Basic Rule Generation
To generate rules for a specific tool (e.g., copilot) for a given language and tags:
rules4 copilot --lang python --tags "pytest,langgraph"
This command will:
- Use
gpt-4-turboas the primary model (default). - Generate rules for Python projects, focusing on
pytestandlanggraph. - Save the rules to
.github/copilot-python-pytest,langgraph.md(or similar, depending on the tool).
Advanced Usage
You can specify a primary model, a review model, and enable research. Both --primary and --review flags support OpenAI and Anthropic models:
# Use Claude as primary, GPT-4 as reviewer
rules4 copilot --primary claude-3-5-sonnet-20241022 --review gpt-4o --research --lang javascript --tags "react,typescript"
# Use GPT-4 for both generation and review
rules4 cursor --primary gpt-4-turbo --review gpt-4o --lang python --tags "async,testing"
# Use Claude for both generation and review
rules4 claude --primary claude-3-opus-20240229 --review claude-3-5-sonnet-20241022 --lang go --tags "concurrency"
These commands demonstrate the flexibility:
- You can use any combination of OpenAI and Anthropic models
- The same model can be used for both primary generation and review
- Research always uses Perplexity's
sonar-promodel
🤖 Automatic Project Analysis (rules4 auto)
The auto command is the smartest way to generate rules. It analyzes your project structure and automatically determines the best settings:
What It Detects:
Languages (50+):
- Python, JavaScript, TypeScript, Java, Go, Rust, C#, PHP, Ruby, C++, Swift, Kotlin, Dart, Elixir, Scala, Clojure, Haskell, R, Julia, and more...
Frameworks & Libraries (50+):
- Frontend: React, Vue, Angular, Svelte, Next.js, Nuxt.js
- Backend: Django, Flask, FastAPI, Express, Spring Boot, ASP.NET, Laravel
- Mobile: React Native, Flutter, Ionic, Xamarin
- Testing: Jest, pytest, Mocha, Cypress, Selenium
- Build Tools: webpack, Vite, Rollup, Parcel, Cargo, Maven, Gradle
Smart Tags Generated:
- Architecture: microservices, monolith, serverless, api
- Development: testing, security, performance, documentation
- Technologies: database, web-development, mobile, machine-learning
- Practices: ci-cd, devops, containerization, cloud-native
Auto Command Examples:
# Basic auto-detection for all configured tools
rules4 auto
# Tool-specific auto-generation
rules4 auto cursor
rules4 auto claude
# Auto-detection with research and review
rules4 auto --research --review claude-3-5-sonnet-20241022
# Override auto-detected language but keep detected frameworks
rules4 auto --lang typescript
# Override auto-detected tags but keep detected language
rules4 auto --tags "performance,security,testing"
# Combination with all features
rules4 auto cursor --primary gpt-4-turbo --research --dry-run
How It Works:
- 🔍 Scans your project directory structure
- 🎯 Detects programming languages from file extensions and content
- 📦 Analyzes package files (package.json, requirements.txt, etc.)
- 🛠️ Identifies frameworks and build tools
- 🏷️ Generates intelligent tags based on project characteristics
- ⚡ Executes the same high-quality generation pipeline as manual commands
Generating Rules for All Configured Tools
If you have a .rules4rc file configured (created with rules4 init), you can generate rules for all specified tools:
rules4 generate --lang go --tags "code style"
This command will:
- Read the list of tools from your
.rules4rcfile. - Generate rules for each tool, focusing on
code stylefor Go projects.
Note: The generate command requires a .rules4rc configuration file. Individual tool commands (like rules4 cursor, rules4 claude) and the auto command work without any configuration.
Command-Line Options
--primary <model_name>: Specify the primary AI model for rule generation. Supports both OpenAI and Anthropic models (e.g.,gpt-4-turbo,gpt-4o,claude-3-5-sonnet-20241022).--review <model_name>: Specify an AI model for reviewing and refining the generated rules. Also supports both OpenAI and Anthropic models.--research: Enable research using Perplexity AI before rule generation.--lang <language>: Specify the programming language for rule generation (e.g.,python,javascript,go).--tags <tag1,tag2,...>: Comma-separated list of tags or topics for rule generation (e.g.,pytest,langgraph,react,typescript,code style).--dry-run: Preview the changes without actually writing any files.--yes,-y: Overwrite existing files without prompting for confirmation.--project-path <path>: (Optional) Specify the target project directory. Defaults to the current directory.
Listing Available Models
To see all available models for use with --primary and --review:
rules4 list-models
This will display models grouped by provider (OpenAI, Anthropic, and Perplexity).
This project is in early development. For contributions, see CONTRIBUTING.md.
Publishing
For maintainers, this project includes a comprehensive publishing system:
Prerequisites
# Install publishing dependencies
pip install build twine
# Set up API tokens
export PYPI_API_TOKEN="your-pypi-token" # For PyPI
export TEST_PYPI_API_TOKEN="your-test-pypi-token" # For TestPyPI
Publishing Commands
# Test publish (recommended first)
./publish.sh --test --dry-run # Preview what would be published to TestPyPI
./publish.sh --test # Publish to TestPyPI
# Production publish
./publish.sh --dry-run # Preview what would be published to PyPI
./publish.sh # Publish to PyPI
# With version update
./publish.sh --version 1.2.3 # Update version and publish
Make Commands
make publish-test # Publish to TestPyPI
make publish # Publish to PyPI
Publishing Features
The enhanced publish.sh script includes:
- ✅ Pre-flight checks: Virtual environment, dependencies, API tokens
- ✅ Quality assurance: Runs all tests and linting before publishing
- ✅ Version management: Automatic version updates in both
pyproject.tomland CLI - ✅ Dual repositories: Support for both PyPI and TestPyPI
- ✅ Safety features: Dry-run mode, build validation, error handling
- ✅ User experience: Colored output, progress indicators, helpful messages
Development
Setup
# Clone and setup
git clone https://github.com/dimitritholen/airules.git
cd airules
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
Quality Assurance
make test # Run tests
make lint # Run all linting checks
make lint-fix # Auto-fix formatting issues
make format # Format code with black
make type-check # Run mypy type checking
License
MIT License - see LICENSE file for details.
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Run
make test lintto ensure quality - Submit a pull request
Support
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rules4-1.2.0.tar.gz.
File metadata
- Download URL: rules4-1.2.0.tar.gz
- Upload date:
- Size: 124.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6745d00cc585838a2913ec4059a7c997c62a5a120140661b7e8d9f32315a5e89
|
|
| MD5 |
1992467c1591eb45326c543b6e405813
|
|
| BLAKE2b-256 |
16c7931324890138a5c52100a30a81ddd03056334cfc09fb51ac662f1513fcd5
|
File details
Details for the file rules4-1.2.0-py3-none-any.whl.
File metadata
- Download URL: rules4-1.2.0-py3-none-any.whl
- Upload date:
- Size: 77.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
960f678620e4d9cbf68280afc73efec9b4a8187427105558847df9fbaa6220e1
|
|
| MD5 |
8bfbf1b0800c498ea4faee8a70e3af86
|
|
| BLAKE2b-256 |
23a658e3f0b463e63ac89b335c72433f818e3138422376b9738da3c9851d2489
|