npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@jcyamacho/agent-memory

v0.5.2

Published

Persistent memory for MCP-powered coding agents.

Readme

agent-memory

Persistent memory for MCP-powered coding agents.

agent-memory is a stdio MCP server that gives your LLM durable memory backed by Markdown files on disk. It helps your agent remember preferences, project context, and prior decisions across sessions.

It exposes four tools:

  • remember: save facts, decisions, preferences, and project context
  • review: load workspace and global memories sorted by most recently updated
  • revise: update an existing memory when its content changes or when it should become global
  • forget: delete up to 50 memories that are no longer relevant

Quick Start

Claude CLI:

claude mcp add --scope user agent-memory -- npx -y @jcyamacho/agent-memory

Codex CLI:

codex mcp add agent-memory -- npx -y @jcyamacho/agent-memory

OpenCode:

{
  "$schema": "https://opencode.ai/config.json",
  "mcp": {
    "agent-memory": {
      "type": "local",
      "command": ["npx", "-y", "@jcyamacho/agent-memory"]
    }
  }
}

Install the Agent Skill

Install the optional Agent Skill to teach supported coding agents how to create small, atomic memories and maintain them conservatively:

npx skills add jcyamacho/agent-memory --skill agent-memory -g

The skill complements the MCP server instructions with a detailed durability gate, scoping rules, and guidance for choosing between remember, revise, forget, and no operation. It does not change the MCP tools or storage format.

Load Memories at Session Start (Hooks)

Some clients defer MCP tool loading until the model decides it needs a tool. That can prevent proactive review calls at session start. A session-start hook guarantees memories are loaded before the first prompt.

The CLI prints the same <memories> XML as the MCP review tool:

npx -y @jcyamacho/agent-memory review

Use --workspace <path> to override the default workspace (process.cwd()). Hook commands run with the project directory as cwd, so the default is usually enough.

Claude Code (~/.claude/settings.json or .claude/settings.json):

{
  "hooks": {
    "SessionStart": [
      {
        "hooks": [
          {
            "type": "command",
            "command": "npx -y @jcyamacho/agent-memory review"
          }
        ]
      }
    ]
  }
}

Codex CLI (~/.codex/hooks.json):

{
  "hooks": {
    "SessionStart": [
      {
        "matcher": "startup|resume|clear|compact",
        "hooks": [
          {
            "type": "command",
            "command": "npx -y @jcyamacho/agent-memory review"
          }
        ]
      }
    ]
  }
}

Notes:

  • Claude Code caps hook stdout at 10,000 characters. Larger output is written to a file the model can read.
  • npx cold-cache latency can delay session start. If the package is installed locally, call the agent-memory bin directly.
  • Claude Code users can alternatively set "alwaysLoad": true on the agent-memory server in .mcp.json (v2.1.121+) to prioritize this MCP by making its tools visible from the first turn. This leaves the decision to call review under model control.

Optional LLM Instructions

Use these fallback instructions when the Agent Skill is not installed. The server instructions and tool descriptions already cover most behavior. If a session-start hook already injected memories, the prompt avoids loading them a second time:

## Agent Memory

- If workspace memories are not already present in context, call `review` from
  the `agent-memory` MCP at session start. Continue through every page while
  `has_more` is true.
- During the session, use `remember`, `revise`, and `forget` from the
  `agent-memory` MCP to keep memories accurate.
- Pass `workspace` for project-scoped memory. Omit it only for facts that truly
  apply across projects. Promote project-scoped memory to global only when that
  is actually true.
- Remember durable preferences, confirmed approaches, and decisions with
  reasoning that would be hard to recover later. Revise memories when facts
  change and forget them when they are no longer relevant.
- Do not store secrets, temporary task state, or facts obvious from current
  code, files, or git history.

Mutating Tool Output

remember and revise return the full affected memory as XML with updated_at and scope information so clients that hide tool-call arguments can still see what changed.

forget accepts an ids array containing 1 to 50 memory IDs. It trims IDs, ignores duplicates, and deletes up to five memories concurrently. Deletion is best-effort: one failure does not stop the remaining memories. The returned <forget_results> preserves request order and contains each deleted memory with deleted="true", failed IDs and statuses, and summary counts.

How Review Works

review requires a workspace and returns memories saved in that workspace plus global memories (saved without a workspace), sorted by most recently updated. Results are paginated. Pass page to load older memories.

When you save a memory from a git worktree, agent-memory stores the main repo root as the workspace. review applies the same normalization to incoming workspace queries so linked worktrees still match repo-scoped memories exactly.

Configuration

Store Location

By default, memories are stored under:

~/.config/agent-memory/

Override it with:

AGENT_MEMORY_STORE_PATH=/absolute/path/to/agent-memory

The store layout is:

<store>/
  globals/<memory-id>.md
  workspaces/<encoded-workspace>/<memory-id>.md

Set AGENT_MEMORY_STORE_PATH when you want to:

  • keep memory in a project-specific location
  • share a memory store across multiple clients
  • keep the Markdown files somewhere easier to back up or inspect

License

MIT