Personal AI coding agent with memory, tool execution, and safety controls
Project description
__ __ _
| \/ | ___ ___ __| | ___
| |\/| |/ __/ _ \ / _` |/ _ \
| | | | (_| (_) | (_| | __/
|_| |_|\___\___/ \__,_|\___|
──────────────────────────────────────────────────────────────────────
Mcode — Your local AI coding agent
› /help for commands
› Project: default — /project rename <name> to name this session
› Model: minimax (MiniMax-M2.7) — /model to switch
──────────────────────────────────────────────────────────────────────
Features
| Agentic loop | Native function calling, stuck detection, fully autonomous auto mode |
| Memory | 4-layer cross-session memory with compression, recall, and Ebbinghaus forgetting |
| Projects | Multiple projects, each with isolated memory DB and working directory |
| Resource registry | Index local files by topic; reference them with @name in any message |
| Image support | Attach images via @path for multimodal turns with vision-capable models |
| Safety | Human / Auto / Bypass modes with zone checks, whitelists, and file backups |
| Extensible | Drop .py files into ~/.mcode/tools/ to add custom tools |
Installation
pip install memocode
Optional dependencies
| Feature | Package |
|---|---|
JS-heavy pages (playwright=true) |
pip install playwright (uses system Chrome/Edge — no browser download needed) |
On first run, ~/.mcode/agent.json is created. Add your model:
{
"active_model": "gpt4o",
"models": {
"gpt4o": {
"provider": "openai",
"model": "gpt-4o",
"api_key_env": "OPENAI_API_KEY",
"context_window": 128000
}
}
}
export OPENAI_API_KEY=your_key_here
mcode
Any OpenAI-compatible endpoint works — OpenAI, Anthropic, DeepSeek, local models via vLLM/Ollama, etc. Multiple models can be defined and switched with /model.
Quick Start
mcode # Start (auto-resumes last project)
mcode --project myapp # Start with a specific project
mcode --verbose # Show full tracebacks on errors
Type naturally. Use /help to see all commands.
Slash Commands
Session
| Command | Description |
|---|---|
/help |
Show all commands |
/status |
Show current settings |
/end |
End session and save to memory |
/quit / /exit |
Exit |
Conversation
| Command | Description |
|---|---|
/btw <question> |
Quick one-shot question — no memory, no tools |
/undo |
Undo last turn — restore files and/or rewind conversation |
/rewind [N] |
Rewind to turn N; /rewind 0 clears conversation |
/rollback |
Restore a specific backed-up file version |
/history [N] |
Show audit log |
Auto mode
| Command | Description |
|---|---|
/auto [on|off] |
Toggle autonomous mode |
/auto whitelist [list|add|remove|reset] |
Manage whitelisted shell commands |
/template [example] |
Show recommended task prompt template |
Projects
| Command | Description |
|---|---|
/project new [name] |
Create a new project |
/project switch <name> |
Switch to another project |
/project list |
List all projects |
/project workdir [path] |
Set working directory |
/project rename [<old>] <new> |
Rename a project |
/project delete <name> |
Delete a project |
Memory
| Command | Description |
|---|---|
/memory |
Show core memory (user profile) |
/memory set <key> <value> |
Write an entry |
/memory del <key> |
Delete an entry |
/memory pin <key> |
Pin an entry (never forgets) |
Resources
| Command | Description |
|---|---|
/resource add [-r] <path|dir> |
Register a file or directory (recursive with -r) |
/resource search <query> |
Search registered resources |
/resource list |
List all resources |
/resource tree [path] |
Directory tree view of all resources |
/resource sync [name] |
Re-classify changed files |
/resource del <index|name> |
Delete a resource |
/resource watch |
List watched directories |
/resource unwatch <dir> |
Stop watching a directory |
Other
| Command | Description |
|---|---|
/model [name] |
Show or switch LLM model |
/tools |
List all loaded tools |
/safety [on|off] |
Toggle safety bypass (DANGEROUS, session-only) |
!<command> |
Run a shell command directly (safety-checked) |
@<path or name> |
Attach a file or registered resource inline |
@*<query> |
Inject all resources matching a search query |
@<dir>/ |
Inject a directory file listing |
@<N> |
Reference resource by global index number |
Memory System
mcode maintains four memory layers across sessions:
| Layer | Scope | Contents |
|---|---|---|
| Core memory | Global | User traits: interaction style, delegation preference |
| Project memory | Per-project | Decisions, architecture, conventions, progress |
| Recent memory | Per-project | Compressed summaries of past sessions |
| Session history | Per-project | Current session verbatim; older turns compressed in-place |
Recall — Recent summaries are injected every turn (newest-first, 4k token cap) with timestamps. memory_search is called automatically when context is missing. Core and project memory are always in the system prefix (prompt-cache eligible).
Compression — When context reaches 50% of context_window, old turns are summarised with explicit markers (Rejected X — reason, Changed from X to Y — reason) so negations and reversals remain retrievable. Mode is auto-detected: plan mode for conversations without code (preserves dates, values, identifiers), code mode for code-heavy sessions (focuses on decisions and rationale).
Forgetting — Core memory decays via the Ebbinghaus curve. Frequently confirmed traits resist forgetting; entries never reinforced eventually fade below threshold and are dropped. Project memory does not decay.
Resource Registry
Register local files once; reference them by name from any message.
/resource add ~/Documents/specs # register a directory (also auto-watches for new files)
/resource add -r ~/Documents # recursive
/resource search kubernetes # find by keyword
After searching, reference a result directly in your message:
@API设计规范 根据规范帮我 review 这段代码
The file content is injected automatically — no copy-paste needed. New files added to a watched directory are auto-registered on the next startup.
Auto Mode
Auto mode runs the agent fully autonomously — no confirmation prompts, hard sandbox boundaries (whitelist-only shell commands, writes restricted to work_dir).
Enable with /auto on, then use /template for the recommended task structure:
Task: <one-line goal>
Context: work_dir, language/framework, entry point
Acceptance criteria: 1) ... 2) ... 3) ...
Constraints: do NOT modify <files>
Verify by running: <test command>
Safety Modes
| Mode | Behavior |
|---|---|
| Human (default) | Prompts before risky ops; backs up files before destructive edits |
Auto (/auto on) |
No prompts; blocks non-whitelisted commands and out-of-work_dir writes |
Bypass (/safety off) |
Skips all checks; session-only; requires typing yes to confirm |
Built-in Tools
| Tool | Description |
|---|---|
shell_exec |
Run shell commands with streaming output |
file_read |
Read file with optional pagination |
file_write |
Write or append to a file |
file_edit |
Targeted string replacement |
glob |
Find files by pattern (**/*.py) |
grep |
Search file content by regex |
web_fetch |
Fetch a URL — GET/POST/PUT/PATCH/DELETE, custom headers, JSON body; HTML converted to readable text via Mozilla Readability; playwright=true renders JS-heavy pages via system browser (Chrome/Edge/WebKit) |
web_search |
Search the web via DuckDuckGo — no API key required |
pdf_read |
Extract text from PDF files |
excel_read |
Read Excel / CSV files as formatted table |
excel_write |
Write data to Excel / CSV files |
calc |
Safe arithmetic evaluator |
memory_search |
Search past session summaries |
activity_log_query |
Query recent activity log |
project_query |
Read structured project memory |
Custom Tools
Drop a .py file in ~/.mcode/tools/:
from tools.registry import Tool, ToolSchema
def _my_tool(param: str) -> str:
return f"result: {param}"
MY_TOOL = Tool(
schema=ToolSchema(
name="my_tool",
description="Description shown to the model",
parameters={
"type": "object",
"properties": {"param": {"type": "string"}},
"required": ["param"],
},
),
fn=_my_tool,
)
Project Structure
mcode/
├── run.py # CLI entry point (~1035 lines)
├── cmds/ # Slash command handlers
│ ├── memory.py # /memory
│ ├── tasks.py # /tasks
│ ├── rewind.py # /rewind, /context
│ ├── email.py # /email
│ ├── project.py # /project
│ ├── resource.py # /resource
│ ├── at_expand.py # @mention expansion
│ └── _utils.py # shared utilities
├── control/
│ ├── brain.py # Agent loop, tool dispatch, safety
│ ├── llm.py # LLM adapter (OpenAI-compatible + Anthropic)
│ ├── project_manager.py # Project registry
│ ├── audit.py # Audit log
│ ├── resources/ # Local resource registry
│ │ ├── manager.py # ResourceManager
│ │ ├── db.py # SQLite storage + BM25 search
│ │ └── scanner.py # File content extraction
│ └── chatmem/ # Memory system
│ ├── context_manager.py # History, compression, injection
│ ├── compressor.py # LLM-based summarization
│ └── memory/
│ ├── core_memory.py # User traits (global, Ebbinghaus forgetting)
│ ├── recent_memory.py # Cross-session summaries (per-project)
│ ├── consolidation.py # Pattern extraction → core memory
│ └── forgetting.py # Decay engine
├── tools/
│ ├── file.py # file_read/write/edit, glob, grep
│ ├── shell.py # shell_exec
│ ├── web.py # web_fetch, web_search
│ ├── calc.py # safe arithmetic evaluator
│ └── registry.py # Tool registry + loader
└── safety/
├── safety.py # Zone checks, auto mode rules
├── backup.py # File backup
└── policy.py # Persistent always-allow policies
License
Apache License 2.0 — see LICENSE.
Project details
Release history Release notifications | RSS feed
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 memocode-0.7.3.tar.gz.
File metadata
- Download URL: memocode-0.7.3.tar.gz
- Upload date:
- Size: 223.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
669596666621cadf53647d40f531612b7d0493d264f0ed4fe0a092667877a031
|
|
| MD5 |
db43a8034b243f89a61e19ba75ee9b5b
|
|
| BLAKE2b-256 |
1ee57bde307ec5e934bd57edb83158244ba24ea8b894876ef684e975be8bb758
|
File details
Details for the file memocode-0.7.3-py3-none-any.whl.
File metadata
- Download URL: memocode-0.7.3-py3-none-any.whl
- Upload date:
- Size: 186.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
89aba2d63d0d38b495da78a09976e73f619699c4b4036a225ae2fc9bed73a42d
|
|
| MD5 |
fca8a7a5e9cacb50672beade1cc3e379
|
|
| BLAKE2b-256 |
7187a67582e6fb6cc5dc8efa0329c961e39e7a0e691a07549975e4d5ec503d73
|