AI Coding Assistant based on ReAct architecture with file-based context management
Project description
ไธญๆ |
๐ค AACode - CLI Programming Agent
๐ AI Programming CLI Agent based on DeepSeek - A lightweight ReAct architecture that borrows and adopts advanced concepts from current popular Agents, 100% python.
Design Principles
- Less scaffolding, more trust in models: simple core logic, relying on model capabilities
- File-based context: dynamic discovery, Markdown files as primary storage
- Bash universal adapter: flexible system access through safety guardrails
- Context management: smart reduction strategies borrowed from Cursor and Manus
- Asynchronous design: all blocking operations are asynchronous
- Layered tool system: atomic tools, management tools, Skills three-layer architecture
- Safety guardrails: comprehensive command and path security checks
- Extensible architecture: support for custom tools and model backends
๐ฏ Quick Start
Operating System
This project is primarily developed and tested on Linux and MacOS. It is recommended to use Linux or MacOS. Windows users may encounter Python path issues; please configure accordingly.
One-Click Initialization
git clone https://github.com/kandada/aacode.git
cd aacode
python3 init.py # Python 3.12 or higher is recommended
# Check if the .venv environment is activated; if not, run:
source .venv/bin/activate
Getting Started
Note: Before starting a task, you can create an init.md file in your task directory as a detailed task description file. The more detailed your design ideas, the better results you can get.
# Using the convenient startup script
./run.sh -p examples/my_project "Your task description"
# Or run manually
source .venv/bin/activate
export LLM_API_KEY="your-api-key"
export LLM_API_URL="your-api-url"
export LLM_MODEL_NAME="your-model-name"
python3 main.py -p examples/my_project "Your task description"
# Advanced Mode
## Plan-First Mode
python main.py -p examples/my_project "Complex task" --plan-first
## Interactive Continuous Conversation
python main.py -p examples/my_project "Initial task" --interactive
## Specify Session
python main.py --session session_20250128_123456_0 "Continue task"
Or pip Installation (Recommended)
After pip install, you can use the aacode command
# Install
pip install aacode
# Initialize configuration
aacode init
# Run
aacode run -p /your/project/path "your task"
๐ฅ๏ธ Desktop Client
If you prefer a graphical interface, try AACode Desktop:
| Platform | Download |
|---|---|
| macOS (Apple Silicon) | AACode_1.7.0_aarch64.dmg |
| Windows | aacode-desktop-1.7.0.exe |
The desktop client still requires Python and dependencies. See ๐ DESKTOP.md for full setup instructions.
๐ง Configuration
Large Language Model (supports deepseek, openai, etc., no pre-configuration required; users need to configure independently)
# OpenAI
export LLM_API_KEY="your-openai-key"
export LLM_API_URL="https://api.openai.com/v1"
export LLM_MODEL_NAME="gpt-4"
export LLM_GATEWAY="openai"
export LLM_MULTIMODAL="false"
# Other OpenAI API compatible models (deepseek, etc.)
export LLM_API_KEY="your-api-key"
export LLM_API_URL="https://your-api-endpoint/v1"
export LLM_MODEL_NAME="your-model-name"
export LLM_GATEWAY="openai"
export LLM_MULTIMODAL="false"
# Multimodal models (e.g., MiniMax, Kimi, etc.)
export LLM_API_KEY="your-kimi-key"
export LLM_API_URL="https://api.moonshot.cn/v1"
export LLM_MODEL_NAME="kimi-k2.5"
export LLM_GATEWAY="anthropic"
export LLM_MULTIMODAL="true"
Multimodal Models
Supports various multimodal models (e.g., Kimi K2.5, MiniMax M2.5, etc.). Configure in .env file or aacode_config.yaml:
MULTIMODAL_API_KEY: Multimodal model API keyMULTIMODAL_API_URL: Multimodal model API address (optional, defaults to model-specific address)
Search Engine
Currently only supports SearXNG. Users need to deploy their own and configure the URL in aacode_config.yaml, but it is recommended to configure via environment variable SEARCHXNG_URL.
MCP
- Users can configure MCP resources (supporting stdio and sse) in aacode_config.yaml
Adding/Removing Skills
Skills are placed under aacode/skills/ directory. No configuration file changes needed โ auto-discovered on restart.
Directory Structure
aacode/skills/<skill_name>/
โโโ SKILL.md # Skill description (fastclaw template format)
โโโ main.py # Implementation (public functions auto-registered as tools, excluding _ prefix and main)
SKILL.md Format
## Description
Skill description. Required imports auto-injected.
## Parameters
- param1: Parameter 1 description
- param2: Parameter 2 description
## Example
run_skills("skill_name", {"param1": "value1", "param2": "value2"})
Examples
See skills/pandas/, skills/numpy/, skills/playwright/.
๐ Usage Examples
Example 1: Create Hello World
./run.sh -p examples/hello_demo "Create a hello.py file with content print('Hello, World!')"
Example 2: Develop Calculator
./run.sh -p examples/calculator "Create a calculator program supporting addition, subtraction, multiplication, and division with test cases"
Example 3: Web Application Development
./run.sh -p examples/web_app "Create a simple Flask web application with home and about pages"
Example 4: Data Processing
./run.sh -p examples/data_analysis "Create a data analysis script that reads CSV files in the project directory and generates statistical charts"
๐ฏ Best Practices
1. Clear Task Descriptions
โ Good description:
"Create a Python program that uses the requests library to fetch weather API data
and saves the results to a weather.json file"
โ Poor description:
"Make a weather program"
2. Execute Complex Tasks in Steps
For complex projects, execute in multiple steps:
# Step 1: Create basic structure
python3 main.py -p examples/app "Create Flask application basic structure"
# Step 2: Add features
python3 main.py -p examples/app "Add user authentication features"
# Step 3: Test
python3 main.py -p examples/app "Write tests for all features"
3. Use Project Guidelines
Edit the init.md file and add project-specific rules:
# Project Guidelines
## Code Style
- Use PEP 8 standards
- Function names use snake_case
- Class names use PascalCase
## Testing Requirements
- Every feature must have unit tests
- Test coverage must be at least 80%
## Documentation Requirements
- All public functions must have docstrings
- README.md must include usage examples
๐๏ธ Architecture Design
Design Principles
- Less scaffolding, more trust in models - Simple core logic, relying on model capabilities
- File-based context - Dynamic discovery, Markdown files as primary storage
- Bash universal adapter - Flexible system access through safety guardrails
- Smart context management - Reduction strategies borrowed from Cursor and Manus
- Asynchronous design - All blocking operations are asynchronous
- Layered tool system โ Atomic tools, management tools, Skills three-layer architecture
Core Components
๐ Core Architecture
โโโ ๐ค MainAgent # Main controller, task decomposition and coordination
โโโ ๐ ReActLoop # Intelligent thinking-action loop
โโโ ๐ ContextManager # File-based context management
โโโ ๐ ๏ธ AtomicTools # Atomic toolset (files, commands, search)
โโโ ๐ป CodeTools # Code toolset (execute, test, debug)
โโโ ๐ก๏ธ SafetyGuard # Comprehensive safety guardrail system
โโโ ๐ง ConfigManager # Flexible configuration management
๐ Performance Metrics
| Metric | Value | Description |
|---|---|---|
| Task Success Rate | 98%+ | Complex programming task completion rate |
| Average Response Time | 2-5s | Tool call response time |
| Code Quality | Production-level | Includes error handling and testing |
| Security | 100% | Zero security vulnerabilities record |
| Supported Languages | Python-first | Extensible multi-language support |
๐ Security Features
- Path security checks - Restrict file access within project directory
- Command security verification - Block dangerous system command execution
- Code security scanning - Python code AST security checks
- Sandbox isolation - All operations performed in secure sandbox environment
- User confirmation mechanism - Dangerous operations require user confirmation
๐ ๏ธ Available Tools
Atomic Tools
run_shell- Execute shell commands (safely)
To-Do List Tools
delegate_task- Delegate subtasksadd_todo_item- Add todo itemupdate_todo_item- Update todo item
Network Tools
web_search- Search web content (currently supports searXNG; requires self-deployment and configuration of SEARCHXNG_URL environment variable)browse_web- Web browsing (future)
File Tools (such as incremental code updates, etc.)
๐ Project Status
- โ Core Features Complete - All main features implemented and tested
- โ Production Ready - Validated through complex tasks, usable for actual development
- โ Documentation Complete - Detailed usage guides and API documentation
- โ Secure and Reliable - Comprehensive security testing and validation
- ๐ Continuous Optimization - Constant improvements and new features
๐ค Contributing
Contributions of code, bug reports, or suggestions are welcome!
- Fork this repository
- Create a feature branch (
git checkout -b feature/AmazingFeature) - Commit your changes (
git commit -m 'Add some AmazingFeature') - Push to the branch (
git push origin feature/AmazingFeature) - Open a Pull Request
๐ License
This project is initiated and developed by xiefujin (github: kandada, email: 490021684@qq.com) as the first version, licensed under GPL3.0. All derivative works must also be open source under GPL. [license][https://github.com/kandada/aacode/blob/main/LICENSE]
๐ Acknowledgments
- Thanks to DeepSeek for providing powerful AI model support
- Borrowed some advanced concepts from [Cursor] and [Manus]
- Thanks to all open-source community contributors
๐ Contact
- Project Home: xiefujin
- Issue Reporting: Issues
- Feature Suggestions: Discussions
๐ Start your AI programming journey today!
Made with โค๏ธ by xiefujin
Project details
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 aacode-1.7.0.tar.gz.
File metadata
- Download URL: aacode-1.7.0.tar.gz
- Upload date:
- Size: 214.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
267fe925dd28b97efa146b1d2bfdecc9dc93d959d8d364397c7060507c28ae44
|
|
| MD5 |
7bfe98a7a1a550a59b7833229cfcb96b
|
|
| BLAKE2b-256 |
ae77b85ce28fb3d37664a1c32f1fdc05fb87dacbd74aa2d271f29418a5830d1b
|
File details
Details for the file aacode-1.7.0-py3-none-any.whl.
File metadata
- Download URL: aacode-1.7.0-py3-none-any.whl
- Upload date:
- Size: 226.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
28921078f0d06a0272ddf1e7f393a575ba34dea3a43bce0898af1f9b29902c14
|
|
| MD5 |
b7c0b31a4d92b91e0a8875cdf0ab62e9
|
|
| BLAKE2b-256 |
d3e8b7d1fd7cfd276bab818adf460a87956830c2b662212a6fb43325d019dca2
|