Skip to main content

AI Coding Assistant based on ReAct architecture with file-based context management

Project description

ไธญๆ–‡ |

๐Ÿค– AACode - CLI Programming Agent

Python Version

๐Ÿš€ 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 key
  • MULTIMODAL_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 subtasks
  • add_todo_item - Add todo item
  • update_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!

  1. Fork this repository
  2. Create a feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. 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


๐Ÿš€ 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

aacode-1.7.0.tar.gz (214.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aacode-1.7.0-py3-none-any.whl (226.1 kB view details)

Uploaded Python 3

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

Hashes for aacode-1.7.0.tar.gz
Algorithm Hash digest
SHA256 267fe925dd28b97efa146b1d2bfdecc9dc93d959d8d364397c7060507c28ae44
MD5 7bfe98a7a1a550a59b7833229cfcb96b
BLAKE2b-256 ae77b85ce28fb3d37664a1c32f1fdc05fb87dacbd74aa2d271f29418a5830d1b

See more details on using hashes here.

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

Hashes for aacode-1.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28921078f0d06a0272ddf1e7f393a575ba34dea3a43bce0898af1f9b29902c14
MD5 b7c0b31a4d92b91e0a8875cdf0ab62e9
BLAKE2b-256 d3e8b7d1fd7cfd276bab818adf460a87956830c2b662212a6fb43325d019dca2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page