agenticscope
Provides workspace awareness tools (list projects, subagents, plans, git status, grep memory, pack context) for ChatGPT and OpenAI agents.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@agenticscopelist all projects and their current git status"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
agenticscope
A directory-as-context standard plus a read-only MCP server that gives any AI agent live, structured awareness of your workspace — without burning your tokens re-reading everything.
Status: Draft 0.1.0 · License: MIT · Requires: Node.js ≥ 22
Why I built this
I kept hitting the same wall.
Every AI coding tool I used — Claude Code, Cursor, Gemini, ChatGPT — wanted me to hand it context. So I did what everyone does: I wrote an AGENTS.md, a CLAUDE.md, a .cursorrules. Then those files grew. Soon a single "context file" held my coding standards, my database schema, my architecture decisions, my current task notes, and a persona prompt — all stacked into one wall of text.
Then I saw what was actually happening under the hood: the agent re-read the whole thing on almost every turn. I'd be tweaking some CSS and the model would drag my entire Postgres schema into context to do it. I paid for that — in tokens, in latency, and in hitting my plan limits faster than I should have.
That frustration started this project. I want my AI tools to know more about my work while reading less of it.
Related MCP server: cctx-mcp
The pain points I set out to kill
I wrote these down first, and they became my design checklist. A monolithic context file:
Wastes tokens. The agent reads irrelevant information — schemas while I touch CSS, deploy notes while I fix a unit test. Most of what loads is noise.
Mixes up priority. When behavioral rules ("never use
any") share a file with static reference data (an API spec), the model can't tell a hard rule from background knowledge.Breeds tool noise. Every vendor wants its own folder —
.claude/,.gemini/,.cursor/— and they drift out of sync.Ignores the workspace. I work across many repos. Nothing could tell an agent "here's every project, here's which have uncommitted changes, here's what's in flight." Each session started blind.
How I built it
I started cheap and let each pain point push the design forward:
I split the monolith into small files — but the agent still over-read, so organization alone didn't fix tokens.
I made it an index, not a convention. A tiny
agenticscope.tomlmanifest is the only always-loaded file. It maps triggers → fragments, each with a type, priority, and token cost, under a hard budget.I made fragments typed (
rule/knowledge/spec/persona) with explicit precedence, so behavioral rules stop drowning in reference dumps.I added a
buildstep that compiles the one.scope/source into every vendor's native file — edit once, stay in sync.I wrote a read-only MCP server so an agent can ask structured questions about the whole workspace instead of swallowing files.
What agenticscope is
Two parts that work together.
1. The .scope/ standard
A predictable layout for everything an agent needs, driven by a tiny manifest:
my-app/
├── agenticscope.toml # the manifest — tiny, the only file always loaded
└── .scope/
├── rules/ # type: rule — behavioral, high priority
├── knowledge/ # type: knowledge — static reference, lazy
├── specs/ # type: spec — current task requirements
├── personas/ # type: persona — swappable agent "hats"
└── memory/ # persistent project knowledge (decisions, prefs)The manifest maps triggers → fragments, each typed and costed, under a global budget:
[scope]
version = "0.1.0"
name = "my-project"
budget = 4000 # hard cap (estimated tokens) per context pack
[[fragment]]
id = "coding-rules"
type = "rule"
path = ".scope/rules/coding.md"
triggers = ["**/*.ts", "**/*.tsx"]
priority = 100
[[fragment]]
id = "db-schema"
type = "knowledge"
path = ".scope/knowledge/schema.sql"
triggers = ["**/*.sql", "db/**", "migration"]
priority = 202. The read-only MCP server
It gives an AI host live, structured awareness of a multi-project workspace. It only reads — it never writes.
Tool | What it answers |
| Which projects exist in the workspace |
| Which personas/subagents a project defines |
| Which plans/specs are in flight |
| The git state of each repo (branch, ahead/behind, dirty count) |
| A fast grep over |
| A task → a token-budgeted set of fragments |
How to use it
Install
# Run without installing:
npx agenticscope init
# Or install the CLI + MCP server globally:
npm i -g agenticscopeThis gives you two commands: agenticscope (the CLI) and agenticscope-mcp (the server).
Quick start
agenticscope init # scaffold agenticscope.toml + .scope/ in the current dir
# edit the manifest + fragment files to match your project
agenticscope lint # validate the manifest and check every fragment path
agenticscope build # compile .scope/ into CLAUDE.md / GEMINI.md / AGENTS.md / .cursorrulesPack context for a task
pack resolves a task into a budgeted context block. Only matching fragments load, and only until the budget runs out:
$ agenticscope pack "fix the sql migration" -d ./my-app
► "fix the sql migration" — matched 1 fragment(s) (budget 4000, used 86)
[knowledge] db-schema 86 tok
— skipped coding-rules (no trigger match)
— skipped qa-persona (no trigger match)
<!-- [knowledge] db-schema (86 tok) -->
CREATE TABLE users ( ... );Pipe the packed context straight into any model — including raw web chats:
agenticscope pack "fix auth bug" --raw | pbcopy # then paste into ChatGPT, Gemini, etc.Pass concrete file paths so glob triggers match precisely:
agenticscope pack "refactor handler" -p src/api/handler.ts -p src/db/schema.sqlCLI reference
Command | Does |
| Scaffold a manifest + |
| Validate the manifest; flag missing paths, dupe ids, dead fragments |
| Compile |
| Resolve a task into a budgeted context block ( |
Wire up the MCP server
Point any MCP-capable host at the server and give it your workspace root. The host then calls the tools live.
Claude Code / Claude Desktop — add to your MCP config (.mcp.json or claude_desktop_config.json):
{
"mcpServers": {
"agenticscope": {
"command": "npx",
"args": ["-y", "agenticscope-mcp", "--workspace", "~/Documents"]
}
}
}The same server works in Gemini (Gemini CLI), ChatGPT / OpenAI agents, Cursor, Zed, and Windsurf — each just has its own config file. You can also set the workspace with the AGENTICSCOPE_WORKSPACE environment variable instead of --workspace.
Once connected, I ask things like "what's in flight across my workspace?" and the host calls list_plans + git_status and answers from structured data — no file dumps, no token burn. That's the whole point delivered.
How you can leverage this
You don't need my exact setup to benefit. There are three ways in.
Use it as-is. Scaffold .scope/ in your projects and point an MCP host at the server. You get progressive, budgeted context and live workspace awareness immediately.
Use it with any vendor.
MCP path (live tools): any host that speaks MCP — Claude Code/Desktop, Gemini, ChatGPT/OpenAI agents, Cursor, Zed, Windsurf.
CLI path (works everywhere, even raw web chats):
buildgenerates each vendor's file from one source;packprints a budgeted block you can paste into any model.
Use it as a base for your own. Everything here is intentionally simple and MIT-licensed. Fork it and:
Define your own fragment types beyond rule/knowledge/spec/persona.
Swap the token estimator — it ships with a dependency-free
chars/4heuristic; drop in a real tokenizer if you need exact counts.Add your own MCP tools — the server is read-only by design, but the pattern extends cleanly.
Replace the resolver — the trigger/priority/budget model is a starting point, not a cage.
Requirements
Node.js ≥ 22 (active LTS; Node 18 and 20 are end-of-life).
An AI tool you already use — Claude Code, Claude Desktop, Gemini, ChatGPT/OpenAI, Cursor, etc.
No API key, no extra credits. agenticscope runs entirely locally and never calls a model itself. Driving it through Claude Code on a Pro plan needs nothing more — the MCP tools run inside your normal session.
Project layout
agenticscope/
├── src/
│ ├── cli.ts # init / lint / build / pack
│ ├── core/ # manifest parsing, fragment resolution, token budget, vendor build
│ └── mcp/ # read-only MCP server + tools (workspace scan, git, grep)
└── examples/
└── sample-workspace/ # a working .scope/ project to try the commands againstChangelog
I keep this log for my own reference — what shipped, what I fixed, and what others contributed. Newest first.
0.1.0 — Initial release
Added
The
.scope/standard: aagenticscope.tomlmanifest mapping triggers → typed, priced fragments under a token budget.CLI:
init,lint,build,pack.Vendor build: compile one
.scope/source intoCLAUDE.md,GEMINI.md,AGENTS.md, and.cursorrules.Read-only MCP server with
list_projects,list_subagents,list_plans,git_status,grep_memory, andpack_context.A sample workspace under
examples/to try the commands against.
Fixed
Required Node ≥ 22 (Node 18 and 20 are end-of-life).
Stopped tracking the
.idea/IDE directory.
When I fix an issue or merge a contribution, I add it here under a new version with Added / Changed / Fixed and link the issue or PR, e.g.
- Fixed empty-trigger crash in pack (#12, thanks @contributor).
Contributing
Contributions are welcome.
Found a bug or have an idea? Open an issue: https://github.com/jessn-dev/agenticscope/issues
Sending a pull request? Fork, branch, run
npm run typecheckbefore you push, and describe the change. I record merged PRs in the Changelog above.Local setup:
npm install npm run typecheck npm run dev:cli -- lint examples/sample-workspace/api # run the CLI from source npm run dev:mcp # run the MCP server from source
Status & roadmap
This is an early draft (0.1.0). The standard and the MCP tool surface come first; expect the resolver and tooling to keep evolving. Feedback, forks, and competing designs are all welcome — I want a better way to feed agents context, not a walled garden.
I built this because I was tired of watching a context file I never read eat tokens I couldn't spare.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/jessn-dev/agentic-scope'
If you have feedback or need assistance with the MCP directory API, please join our Discord server