Skip to main content

Simple coding agent.

Project description

CI Release PyPI Status Badge

Source Agent

A simple coding agent.

How it Works

Source Agent operates as a stateless entity, guided by clear directives and external context. Its behavior is primarily defined by AGENTS.md, which serves as the core system prompt.


Prerequisites

  • Python 3.10 or higher
  • An API key from one of the supported AI providers (see Supported Providers)
  • Git (for .gitignore support)

Installation

Quick Start

# Clone the repository
git clone https://github.com/christopherwoodall/source-agent
cd source-agent

# Create virtual environment (recommended)
python -m venv .venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate

# Install in development mode
pip install -e ".[developer]"

# Verify the installation
source-agent --help

Basic Usage

# Analyze the current codebase
source-agent --prompt "Analyze this codebase and identify potential improvements"

# Analyze with specific focus
source-agent --prompt "Review the authentication system for security issues"

Advanced Usage

# Use OpenAI with GPT-4
source-agent \
  --provider openai \
  --model gpt-4o \
  --temperature 0.1 \
  --prompt "Create unit tests for the utils.py file"

# Use Claude for code review
source-agent \
  --provider anthropic \
  --model claude-3-5-sonnet \
  --prompt "Review the error handling in this codebase"

Interactive Mode

source-agent --interactive

Supported Providers

Source Agent supports multiple AI providers. Set the corresponding environment variable:

Provider Environment Variable
OpenRouter OPENROUTER_API_KEY
OpenAI OPENAI_API_KEY
Anthropic ANTHROPIC_API_KEY
Google GEMINI_API_KEY
Mistral MISTRAL_API_KEY
DeepSeek DEEPSEEK_API_KEY
Cerebras CEREBRAS_API_KEY
Groq GROQ_API_KEY
Vercel VERCEL_API_KEY
xAI XAI_API_KEY

Available Tools

Source Agent provides these built-in tools for code analysis:

  • file_list_tool - List files/directories in a given path (respects .gitignore)
  • file_read_tool - Read contents of any file
  • file_write_tool - Write content to a file (creates/overwrites)
  • file_delete_tool - Safely delete a file
  • file_search_tool - Search files by name pattern and optionally search within files using text/regex
  • directory_create_tool - Create directories (with optional parent creation)
  • directory_delete_tool - Safely delete directories (recursive option available)
  • calculate_expression - Evaluate mathematical expressions (supports sqrt, pi, etc.)
  • web_search_tool - Search the web using DuckDuckGo (returns snippets and optional page content)
  • task_mark_complete - REQUIRED tool to signal task completion and exit the agent loop

These tools are automatically available to the AI agent during analysis.


Core Architecture

  • Entry Point: src/source_agent/entrypoint.py - CLI interface with argument parsing
  • Agent Engine: src/source_agent/agents/code.py - OpenAI-compatible client with tool integration
  • System Prompt: AGENTS.md - Defines agent behavior, roles, and constraints

Project Structure

source-agent/
├── src/source_agent/
│   ├── entrypoint.py      # CLI interface
│   ├── agents/
│   │   └── code.py        # Main agent logic
│   └── tools/             # File system tools
└── AGENTS.md              # System prompt & behavior rules

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

source_agent-0.0.12-py3-none-any.whl (26.1 kB view details)

Uploaded Python 3

File details

Details for the file source_agent-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: source_agent-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 26.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for source_agent-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 6264e926e4c1951beb3ab6d9858c7d083292359fa3c3304cac85af9f9499079e
MD5 d8caeaad1953ebcc5dfec6ea006342dd
BLAKE2b-256 28087864b2fa8c8001bda396d8e772503f0d7ad7c833514a7d8a51c88b95c77a

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