README.md•11.2 kB
# CTX: Professional AI Development for Every Developer
> Create LLM-ready contexts in minutes
<p>
<a href="https://docs.ctxgithub.com/"><img alt="Docs" src="https://img.shields.io/badge/docs-green"></a>
<a href="https://raw.githubusercontent.com/context-hub/generator/refs/heads/main/json-schema.json"><img alt="Json schema" src="https://img.shields.io/badge/json_schema-blue"></a>
<a href="https://discord.gg/YmFckwVkQM"><img src="https://img.shields.io/badge/discord-chat-magenta.svg"></a>
<a href="https://t.me/spiralphp/2504"><img alt="Telegram" src="https://img.shields.io/badge/telegram-blue.svg?logo="></a>
<a href="https://packagist.org/packages/context-hub/generator"><img alt="License" src="https://img.shields.io/packagist/l/context-hub/generator"></a>
<a href="https://packagist.org/packages/context-hub/generator"><img alt="Latest Version" src="https://img.shields.io/packagist/v/context-hub/generator"></a>
</p>

## Table of Contents
- [Quick Start](#quick-start)
- [Full Documentation](https://docs.ctxgithub.com)
- [License](#license)
During development, your codebase constantly evolves. Files are added, modified, and removed. Each time you need to
continue working with an LLM, you need to regenerate context to provide updated information about your current codebase
state.
**CTX** is a context management tool that gives developers full control over what AI sees from their codebase. Instead
of letting AI tools guess what's relevant, you define exactly what context to provide - making your AI-assisted
development more predictable, secure, and efficient.
It helps developers organize contexts and automatically collect information from their codebase into structured
documents that can be easily shared with LLM.
For example, a developer describes what context they need:
```yaml
# context.yaml
documents:
- description: User Authentication System
outputPath: auth.md
sources:
- type: file
description: Authentication Controllers
sourcePaths:
- src/Auth
filePattern: "*.php"
- type: file
description: Authentication Models
sourcePaths:
- src/Models
filePattern: "*User*.php"
- description: Another Document
outputPath: another-document.md
sources:
- type: file
sourcePaths:
- src/SomeModule
```
This configuration will gather all PHP files from the `src/Auth` directory and any PHP files containing "**User**" in
their name from the `src/Models` directory into a single context file `.context/auth.md`. This file can then be pasted
into a chat session or provided via the built-in [MCP server](https://docs.ctxgithub.com/mcp/).
### Why CTX?
Current AI coding tools automatically scan your entire codebase, which creates several issues:
- **Security risk**: Your sensitive files (env vars, tokens, private code) get uploaded to cloud services
- **Context dilution**: AI gets overwhelmed with irrelevant code, reducing output quality
- **No control**: You can't influence what the AI considers when generating responses
- **Expensive**: Premium tools charge based on how much they scan, not how much you actually need
### The CTX Approach
You know your code better than any AI. CTX puts you in control:
- ✅ Define exactly what context to share - no more, no less
- ✅ Keep sensitive data local - works with local LLMs or carefully curated cloud contexts
- ✅ Generate reusable, shareable contexts - commit configurations to your repo
- ✅ Improve code architecture - designing for AI context windows naturally leads to better modular code
- ✅ Works with any LLM - Claude, ChatGPT, local models, or future tools
## Quick Start
Download and install the tool using our installation script:
```bash
curl -sSL https://raw.githubusercontent.com/context-hub/generator/main/download-latest.sh | sh
```
This installs the `ctx` command to your system (typically in `/usr/local/bin`).
> **Want more options?** See the complete [Installation Guide](https://docs.ctxgithub.com/getting-started.html) for
> alternative installation methods.
## 5-Minute Setup
1. **Initialize your project:**
```bash
cd your-project
ctx init
```
This generates a `context.yaml` file with a basic configuration and shows your project structure, helping you understand
what contexts might be useful.
> Check the [Command Reference](https://docs.ctxgithub.com/getting-started/command-reference.html) for all available
> commands and options.
2. Create your first context:
```bash
ctx generate
```
3. Use with your favorite AI:
- Copy the generated markdown files to your AI chat
- Or use the built-in MCP server with Claude Desktop
- Or process locally with open-source models
## Real-World Use Cases
### 🚀 Onboarding New Team Member
```yaml
# Quick project overview for new developers
documents:
- description: "Project Architecture Overview"
outputPath: "docs/architecture.md"
sources:
- type: tree
sourcePaths: [ "src" ]
maxDepth: 2
- type: file
description: "Core interfaces and main classes"
sourcePaths: [ "src" ]
filePattern: "*Interface.php"
```
### 📝 Feature Development
```yaml
# Context for developing a new feature
documents:
- description: "User Authentication System"
outputPath: "contexts/auth-context.md"
sources:
- type: file
sourcePaths: [ "src/Auth", "src/Models" ]
filePattern: "*.php"
- type: git_diff
description: "Recent auth changes"
commit: "last-week"
```
### 📚 Documentation Generation
```yaml
# Generate API documentation
documents:
- description: "API Documentation"
outputPath: "docs/api.md"
sources:
- type: file
sourcePaths: [ "src/Controllers" ]
modifiers: [ "php-signature" ]
contains: [ "@Route", "@Api" ]
```
## Key Features
### 🎯 **Precise Context Control**
- Define exactly which files, directories, or code patterns to include
- Filter by content, file patterns, date ranges, or size
- Apply modifiers to extract only relevant parts (e.g., function signatures)
### 🔒 **Security by Design**
- **Local-first**: Generate contexts locally, choose what to share
- **No automatic uploads**: Unlike tools that scan everything, you control what gets sent
- **Works with local models**: Use completely offline with Ollama, LM Studio, etc.
### 🔄 **Version Control Integration**
- Context configurations are part of your project
- Team members get the same contexts
- Evolve contexts as your codebase changes
- Include git diffs to show recent changes
### 🛠 **Developer Experience**
- **Fast**: Generate contexts in seconds, not minutes of manual copying
- **Flexible**: Works with any AI tool or local model
- **Shareable**: Commit configurations, share with team
- **Extensible**: Plugin system for custom sources and modifiers
## Architecture
CTX follows a simple pipeline:
```
Configuration → Sources → Filters → Modifiers → Output
```
- **Sources**: Where to get content (files, GitHub, git diffs, URLs, etc.)
- **Filters**: What to include/exclude (patterns, content, dates, sizes)
- **Modifiers**: How to transform content (extract signatures, remove comments)
- **Output**: Structured markdown ready for AI consumption
## Connect to Claude Desktop (Optional)
For a more seamless experience, you can connect Context Generator directly to Claude AI using the MCP server.
```bash
# Auto-detect OS and generate configuration
ctx mcp:config
```
This command:
- 🔍 **Auto-detects your OS** (Windows, Linux, macOS, WSL)
- 🎯 **Generates the right config** for your environment
- 📋 **Provides copy-paste ready** JSON for Claude Desktop
- 🧭 **Includes setup instructions** and troubleshooting tips
**Global Registry Mode** (recommended for multiple projects):
```json
{
"mcpServers": {
"ctx": {
"command": "ctx",
"args": [
"server"
]
}
}
}
```
If you prefer manual setup, point the MCP client to the Context Generator server:
```json
{
"mcpServers": {
"ctx": {
"command": "ctx",
"args": [
"server",
"-c",
"/path/to/project"
]
}
}
}
```
> **Note:** Read more about [MCP Server](https://docs.ctxgithub.com/mcp/#setting-up) for detailed setup
> instructions and troubleshooting.
Now you can ask Claude questions about your codebase without manually uploading context files!
## Custom Tools
Define project-specific commands that can be executed through the MCP interface:
```yaml
tools:
- id: run-tests
description: "Run project tests with coverage"
type: run
commands:
- cmd: npm
args: [ "test", "--coverage" ]
```
## Full Documentation
For complete documentation, including all available features and configuration options, please visit:
https://docs.ctxgithub.com
## Join Our Community
Join hundreds of developers using CTX for professional AI-assisted coding:
[](https://discord.gg/YmFckwVkQM)
**What you'll find in our Discord:**
- 💡 Share and discover context configurations
- 🛠️ Get help with setup and advanced usage
- 🚀 Showcase your AI development workflows
- 🤝 Connect with like-minded developers
- 📢 First to know about new releases and features
---
### License
This project is licensed under the MIT License.