pi-context-loader

Config-driven context injection for Pi agents. Loads files at session start and injects them as system prompt or message.

Packages

Package details

extension

Install pi-context-loader from npm and Pi will load the resources declared by the package manifest.

$ pi install npm:pi-context-loader
Package
pi-context-loader
Version
0.1.0
Published
Jun 20, 2026
Downloads
not available
Author
juanjeojeda
License
MIT
Types
extension
Size
10 KB
Dependencies
0 dependencies · 2 peers
Pi manifest JSON
{
  "extensions": [
    "./extensions"
  ]
}

Security note

Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.

README

pi-context-loader

Config-driven context injection for Pi agents. Loads files at session start and injects them as system prompt or message — the Pi equivalent of a sessionStart hook.

Install

From npm:

pi install npm:pi-context-loader

From git:

pi install git+https://github.com/juanje/pi-context-loader.git

Or load directly without installing:

pi -e /path/to/pi-context-loader/extensions/context-loader.ts

Quick start

Create .pi/context-loader.json in your project:

{
  "files": [
    "context/user-profile.md",
    "context/current-state.md"
  ]
}

Start Pi — the listed files are read at session start and injected into the agent's context (system prompt by default, or as a message with "inject": "message").

How it works

The extension hooks into two Pi events:

  1. session_start — loads the config, reads all listed files and optional latest log, caches the combined context
  2. before_agent_start — injects the cached context via the configured mode

Injection modes

The inject field controls how context reaches the agent:

Mode Behavior Survives compaction LLM weight
"systemPrompt" (default) Appended to system prompt Yes — always present High — treated as instructions
"message" Injected as a conversation message No — may be summarized Normal — treated as context

When to use each:

  • systemPrompt — for identity, rules, or context that must be present on every turn (e.g., user profile, agent guidelines)
  • message — for operational state that's useful at the start but shouldn't permanently occupy the context budget (e.g., active incidents, current sprint items)

Config format

Config file: .pi/context-loader.json

interface ContextLoaderConfig {
  files?: string[];        // paths relative to project root
  latestLog?: {
    index: string;         // path to an index file (e.g. "logs/index.md")
    dir: string;           // directory containing log files (e.g. "logs")
    marker: string;        // marker to match in index lines (e.g. "active")
  };
  separator?: string;      // join string (default: "\n\n---\n\n")
  inject?: "systemPrompt" | "message";  // injection mode (default: "systemPrompt")
}

files

Array of file paths relative to the project root. Each file is read and its content is included in the context. Missing files are silently skipped.

latestLog

Optional dynamic log finder. Scans the index file for lines matching marker (case-insensitive), extracts the last YYYY-MM-DD date found, and loads {dir}/{date}.md.

Useful for agents with session logs where you want to inject the most recent active log automatically.

separator

String used to join all loaded content. Defaults to "\n\n---\n\n" (markdown horizontal rule).

inject

How context is delivered to the agent. Either "systemPrompt" (default) or "message". See Injection modes for details.

Examples

Memory agent (Agentic Buddy-style)

{
  "files": [
    "agent_brain/identity/USER.md"
  ],
  "latestLog": {
    "index": "logs/index.md",
    "dir": "logs",
    "marker": "active"
  }
}

Diagnostic agent (active incidents as message)

{
  "files": ["kb/active/index.md"],
  "inject": "message"
}

Diagnostic agent (reference context in system prompt)

{
  "files": [
    "context/team-roster.md",
    "context/known-issues-summary.md"
  ]
}

Minimal

{
  "files": ["CONTEXT.md"]
}

Static context

This extension handles dynamic context — files that change between sessions. For static context, Pi has built-in support:

  • .pi/SYSTEM.md — replaces the default system prompt (agent identity)
  • AGENTS.md / CLAUDE.md — hierarchical context files loaded automatically

Use pi-context-loader for content that needs to be assembled from multiple files or includes dynamic elements like "latest active log."

Development

git clone https://github.com/juanje/pi-context-loader.git
cd pi-context-loader
npm install
npm run check    # typecheck + lint + test

License

MIT — see LICENSE.