Skip to main content

Autonomous AI Coding Agent powered by Google Gemini

Project description

askgem — Autonomous AI Coding Agent for the Terminal

Python 3.10+ License: GPL v3 Powered by Gemini Code style: ruff Security Scan CD - Release

askgem banner


WORK IN PROGRESS


askgem is a professional, autonomous coding agent that lives in your terminal. Powered by Google Gemini, it reads your files, edits your code, runs shell commands, and navigates your filesystem — all within an interactive session and with hardened safety guardrails that keep you in control.

No GUI. No cloud sync. No bloat. Just a fast, opinionated CLI agent you can trust with your codebase.


Contents


How it works

askgem runs an advanced asynchronous reasoning loop powered by the AgentOrchestrator and a modular manager-based core. On each turn:

  1. Environmental Awareness: At startup, the ContextManager performs a Project Blueprint scan, discovering the project type, structure, and key files to build a proactive system instruction.
  2. Cognitive Loop: Your message is processed by the AgentOrchestrator, which manages the Thinking -> Action -> Observation cycle.
  3. Tool Reasoning: The model calls specialized tools (read, edit, execute). askgem intercepts these via the ToolDispatcher.
  4. Safety Guard: Every action passes through the Security Layer for real-time risk analysis and path validation.
  5. Stream Processing: The StreamProcessor extracts function calls and text mid-flight, showing you the agent's "thought process" in real-time.
  6. Persistence: The full session, including tool results and metrics, is auto-saved to your Workspace history.

This autonomous loop repeats until the mission is accomplished or you interrupt it.


Features

Agentic tool engine

Tool Description
list_directory Explore filesystem trees with depth control
read_file Read any file with optional line ranges — 30k char cap prevents token overflow
edit_file Find-and-replace with atomic writing, uniqueness guard, and automatic .bkp backup
execute_bash Run shell commands with 60s timeout and full Risk Analysis
manage_memory Save important project facts to memory.md for long-term recall
manage_mission Track complex goals and sub-tasks via heartbeat.md mission control
manage_workspace Detects and initializes local project knowledge bases

Workspace Isolation & Local Intelligence

AskGem now distinguishes between your Global Persona and your Project Context:

  • Local Priority: If a .askgem/ folder exists in your project, it takes precedence for settings, memory, and history.
  • Project Memory: Knowledge saved via manage_memory is stored within the project, preventing context leakage between repositories.
  • Mission Persistence: Track specific dev-missions per project without cluttering your global space.

Human-in-the-loop safety

Every destructive action is categorized by risk level (SAFE, NOTICE, WARNING, DANGEROUS). Switch modes anytime mid-session:

  • /mode manual (default) — approve each file edit and shell command.
  • /mode auto — trust the agent fully; all actions execute without prompts.

Streaming terminal UX

AskGem now runs through a Rich-based terminal renderer:

  • Real-time Markdown streaming in the terminal.
  • Inline confirmations for file edits and shell commands.
  • Focus on a fast, scriptable CLI flow instead of a separate dashboard app.

Persistent session history

Every conversation auto-saves to ~/.askgem/history/ as JSON. Reload any past session with /history load <id>. A rolling context window and proactive summarization keep reloaded sessions within token budget.


New in v0.16.x: The Golden Path

The v0.16.x release cycle ("The Golden Path") consolidates the "Bene Gesserit" initiative, introducing a professional-grade TUI, real-time autonomous linting, and a highly optimized On-Demand Knowledge Hub.

1. Professional TUI Renderer

A sophisticated CLI rendering engine with support for dynamic visual identities ("Smuffle" and "Snuggles") and high-fidelity Markdown streaming.

2. Autonomous LSP Integration

Native integration with the Ruff Language Server Protocol (LSP) allowing the AgentOrchestrator to verify syntax and fix diagnostics in real-time.

3. On-Demand Knowledge Hub

Refactored the Knowledge Hub from full-text injection to an on-demand retrieval system via the query_knowledge tool. This significantly reduces token consumption while maintaining deep context awareness.

4. Stream Speed Control

Added a configurable stream_delay setting to calibrate the output velocity of the agent's responses for better readability.


Installation

Prerequisites

From source (recommended)

git clone https://github.com/julesklord/askgem.py
cd askgem.py
python -m venv venv
# On Windows: venv\Scripts\activate
source venv/bin/activate
pip install -e ".[dev]"

Configuration

API key (Standardized)

askgem loads your key from these sources, in order:

  1. Environment variableGEMINI_API_KEY=your_key askgem (Preferred)
  2. System Keyring — Secure storage via Windows Credential Manager or macOS Keychain (Recommended).
  3. Saved file~/.askgem/settings.json (Local fallback).

On first launch without a key, askgem prompts interactively and saves it securely in your system's keyring.

Settings file

You can find the global configuration at ~/.askgem/settings.json.


🧠 Core Knowledge Hub

AskGem now features a Hierarchical Knowledge Hub, separating core behavioral rules from user-specific customizations. The agent reloads its intelligence every turn from three layers:

  1. 📦 Standard Hub (Internal): Built-in modules defining the "Staff Engineer" persona, operational safety rules, and multimodal guidelines (audio/video/vision).
  2. 🌍 Global Hub (~/.askgem/*.md): Your cross-project technical preferences, API guidelines, or personal style.
  3. 🚀 Project Hub (.askgem/*.md): Project-specific context, build commands, architecture rules, and "Mission" specifics.

[!TIP] Just drop a .md file in any of these locations to instantly update AskGem's cognitive behavior without touching the code.

👁️ Multimodal Intelligence

Fully optimized for Gemini 1.5 Pro and 2.0 Flash:

  • Screenshots: Analyze UI layouts and design systems.
  • Video: Summarize technical demos and terminal recordings.
  • Audio: Digest project discussions and voice notes.

Usage

Stored at ~/.askgem/settings.json (POSIX) or %APPDATA%\askgem\settings.json (Windows):

{
    "model_name": "gemini-1.5-flash",
    "edit_mode": "manual"
}

Configuration paths

Path Purpose
~/.askgem/settings.json Model name, edit mode, and user preferences
~/.askgem/history/ Auto-saved session JSON files
~/.askgem/askgem.log Debug log — tool execution events and retry details

Usage

Launch the agent:

askgem

Common Workflows

  • Context Analysis: "Read my pyproject.toml and explain the dependencies."
  • Code Generation: "Create a src/utils.py file with a function to calculate SHA256 hashes."
  • Refactoring: "Refactor authenticate() in src/auth.py to use JWT instead of sessions."
  • Exploration: "Find all TODO comments in the project and group them by file."

Exiting

Type exit, quit, q, or press Ctrl+C.


Slash commands

Command Description
/help Show the full command reference and examples
/model <name> Switch Gemini models mid-conversation (history preserved)
/mode [auto/manual] Toggle between approving actions or automatic execution
/clear Reset the context window to free up tokens without ending session
/usage Show detailed token consumption and estimated USD cost
/stats Summary of session accomplishments (messages, tools, files)
/stop Interrupt the current generation immediately
/reset Restart the entire session and reset all counters
/history [list/load/delete] Manage saved conversation sessions
/trust [path] Add a directory to the permanent whitelist
/untrust [path] Remove a directory from the whitelist

Safety model

Always, regardless of mode (Sandboxed Environment):

  • Trust Management Layer: askgem now implements a strict whitelist for file operations. By default, it can only touch the current workspace. Use /trust to authorize external paths.
  • Cross-Drive Protection: On Windows, the agent is blocked from crossing drive letters (e.g., C: to G:) unless the target is explicitly trusted, preventing unintended system-wide access.
  • Risk Analysis Engine: Powered by core/security.py, every command is categorized:
    • SAFE: Informative commands (ls, git status).
    • NOTICE: Standard operations.
    • WARNING: High-risk patterns (sudo, sensitive file access).
    • DANGEROUS: Critical risk (rm -rf, fork bombs, world-writable chmod).
  • Atomic Writing: edit_file uses a temporary file + rename strategy to prevent corruption.
  • Automatic Backups: Every file modification creates a .bkp backup at <path>.bkp.
  • Hard Timeouts: Shell commands have a strict 60-second execution limit.

Architecture

AskGem operates across three tightly decoupled layers enforcing strong logical boundaries. As of version 0.16.0, the system has evolved into an Orchestrated Architecture, where a central engine manages cognitive managers, security centinels, and an autonomous LSP verification loop.

High-Level System Diagram

flowchart TD
    CLI(["User execution (askgem)"]) --> Main(cli/main.py)
    Main --> Renderer(cli/renderer.py)
    Renderer <--> Orchestrator(agent/orchestrator.py: AgentOrchestrator)
    
    subgraph Cognitive_Layer [Cognitive Managers]
        Orchestrator --> Session[agent/core/session.py]
        Orchestrator --> Context[agent/core/context.py]
        Orchestrator --> Stream[agent/core/stream.py]
        Orchestrator --> Commands[agent/core/commands.py]
        Orchestrator --> Simulation[agent/core/simulation.py]
    end

    Orchestrator <--> GenAI[Google Gemini API]
    
    subgraph Security_Layer [Security & Trust Centinel]
        GenAI -. function calls .-> Trust[core/trust_manager.py]
        Trust --> SecurityCheck[core/security.py]
        SecurityCheck --> Tools(tools/)
    end

    Tools --> localDisk[(Local Workspace)]
    Context -. Blueprint .-> localDisk

Layer Breakdown

  1. Presentation Layer (cli/): Handles CLI startup, interactive prompts, audit views, and real-time Markdown rendering.
  2. Cognitive Layer (agent/): The "Brain". Powered by the AgentOrchestrator, it manages state, context blueprints, and mission tracking.
  3. Security Layer (core/): The "Guard". Gathers risk analysis and whitelisting logic to ensure the agent never exceeds its authority.

Project Structure (v0.16.2)

askgem.py/
├── src/askgem/
│   ├── __init__.py              # Single source of truth for version (0.16.2)
│   ├── agent/
│   │   ├── orchestrator.py      # The Reasoning Brain — Thinking/Action/Observation
│   │   ├── schema.py            # Unified message and tool schemas
│   │   └── core/                # Cognitive Managers
│   │       ├── session.py       # API lifecycle, Retries and Error handling
│   │       ├── context.py       # Blueprint, Memory and Mission management
│   │       ├── commands.py      # Slash command handler
│   │       └── simulation.py    # Deterministic loop recording
│   ├── cli/
│   │   ├── main.py              # Entry point and session initialization
│   │   ├── renderer.py          # Rich streaming renderer and interactive prompts
│   ├── core/
│   │   ├── security.py          # Hardened safety engine
│   │   ├── trust_manager.py     # Directory trust whitelist control
│   │   ├── paths.py             # OS-agnostic path resolution (Workspace aware)
│   ├── tools/                   # Atomic agentic tools
│   └── locales/                 # i18n JSON data (8 languages supported)
├── tests/                       # Reliable unit and integration tests
├── scripts/                     # Maintenance and diagnostic utilities
├── docs/                        # Rich documentation and assets
└── pyproject.toml

Development & Simulation

Setup

git clone https://github.com/julesklord/askgem.py
cd askgem.py
pip install -e ".[dev]"

Reliable Testing Protocol

AskGem introduces a Simulation Layer. You can record agent turns and play them back deterministically:

  1. Record: Set SIMULATION_MODE=record to capture interactions.
  2. Playback: Run pytest tests/integration/test_full_agent_loop.py to verify the logic against the recorded transcript without hitting the real API.

Tests & Linting

pytest tests/                   # full reliable suite
ruff check src/ tests/ --fix    # auto-fix linting violations

Internationalization

AskGem is English-First at the SDK/System level for maximum model reliability, but the entire user interface supports 8 languages:

Code Language File
en English (Standard) en.json
es Español es.json
fr Français fr.json
pt Português pt.json
de Deutsch de.json
it Italiano it.json
ja 日本語 ja.json
zh 中文 (简体) zh.json

Repository Standard

askgem.py is now the reference repo for structure, hygiene, and architecture conventions in this workspace.

See STANDARD.md for the operating standard to apply across the other repositories.


Roadmap

Version Theme Status
v0.14.0 Stability, Renderer Polish ✅ Done
v0.15.0 Kwisatz Haderach - LSP Integration ✅ Done
v0.16.0 The Golden Path - Professional Recovery ✅ Done
v0.16.2 Stabilization - Knowledge Optimization ✅ Done
v0.17.0 Shai-Hulud - Scalable Memory 📋 Planned
v1.0.0 Stable Release — Full docs, PyPI publication 📋 Planned

License

GNU General Public License v3.0 — see LICENSE for full terms.

Built by julesklord.

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

askgem-0.16.4.tar.gz (109.0 kB view details)

Uploaded Source

Built Distribution

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

askgem-0.16.4-py3-none-any.whl (119.1 kB view details)

Uploaded Python 3

File details

Details for the file askgem-0.16.4.tar.gz.

File metadata

  • Download URL: askgem-0.16.4.tar.gz
  • Upload date:
  • Size: 109.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for askgem-0.16.4.tar.gz
Algorithm Hash digest
SHA256 169a320212d9b101c8c67532df0aaa4b242b98b1472770eefd8063767106e042
MD5 5d01346091e3e2d430661a6dfeed9747
BLAKE2b-256 394c59fda814b7df50f7bea677b0aaf07b1f3fd7eb6e44e6236df8761f317254

See more details on using hashes here.

Provenance

The following attestation bundles were made for askgem-0.16.4.tar.gz:

Publisher: deploy.yml on julesklord/askgem.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file askgem-0.16.4-py3-none-any.whl.

File metadata

  • Download URL: askgem-0.16.4-py3-none-any.whl
  • Upload date:
  • Size: 119.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for askgem-0.16.4-py3-none-any.whl
Algorithm Hash digest
SHA256 bab48d9629249c338314a165263ed7ecf13fe48512660d97e21467b9b8beadaa
MD5 bd882455660c58f3f6c0c9b8bd08300a
BLAKE2b-256 dd9232938d90c863d7a6a94ef90c161f3992cad9e560ae7bfb0c813e13a1f1f4

See more details on using hashes here.

Provenance

The following attestation bundles were made for askgem-0.16.4-py3-none-any.whl:

Publisher: deploy.yml on julesklord/askgem.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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