with one click
Load context from paused session
npx skills add https://github.com/bobmatnyc/claude-mpm --skill mpm-session-resumeCopy and paste this command into Claude Code to install the skill
Load context from paused session
npx skills add https://github.com/bobmatnyc/claude-mpm --skill mpm-session-resumeCopy and paste this command into Claude Code to install the skill
Access Claude MPM functionality and manage multi-agent orchestration
Access Claude MPM functionality and manage multi-agent orchestration
Branch protection and PR creation workflow
Spec-Linked Documentation (SLD): Language-agnostic discipline for maintaining bidirectional traceability between functional specifications and source-code docstrings via stable identifiers and CI validation. Optional/opt-in adoption. Builds on OpenFastTrace and DO-178C Requirements Traceability Matrix traditions.
Use multiple Claude agents to investigate and fix independent problems concurrently
Pause session and save current work state for later resume
| name | mpm-session-resume |
| description | Load context from paused session |
| user-invocable | true |
| version | 1.2.0 |
| category | mpm-command |
| tags | ["mpm-command","session","pm-recommended"] |
| effort | medium |
Load and display context from a paused session, with optional browsing and selection when multiple sessions exist.
When invoked, this skill:
.claude-mpm/sessions/ for paused sessions--selectproject_path matches the current project — sessions from other projects are skippedNote: Resume always validates that the session belongs to the current project. You will never accidentally resume a session from a different project.
/mpm-session-resume # resume most recent session (existing behaviour)
/mpm-session-resume # with no args: also lists sessions when >1 exists
/mpm-session-resume --select 2 # resume the 2nd most-recent session (1-based index)
/mpm-session-resume --select 20240101 # resume by partial session ID match
/mpm-session-resume <session-id> # resume by exact session ID (backward-compatible)
What it shows (listing mode — no args, multiple sessions):
What it shows (resume mode):
Before executing, detect which Python runtime has claude_mpm installed, then use that runtime. Check in priority order:
uv run python -c "import claude_mpm" — preferred; claude-mpm is typically installed as a uv tool.venv/bin/python -c "import claude_mpm" — if the project venv has an editable installpython3 -c "import claude_mpm" — if claude_mpm is on the system PythonRun whichever passes first, then execute the code below with that runtime. Parse the user's invocation arguments first, then dispatch to the appropriate code path.
import sys
from pathlib import Path
try:
from claude_mpm.services.cli.session_resume_helper import SessionResumeHelper
except ImportError:
print(
"ERROR: claude_mpm is not importable in the current Python environment.\n"
"If you installed via 'uv tool install claude-mpm', run:\n"
" uv run python -c 'from claude_mpm.services.cli.session_resume_helper "
"import SessionResumeHelper'\n"
"Or invoke directly: claude-mpm session-resume\n"
"Alternatively, activate the virtual environment where claude-mpm is installed."
)
raise SystemExit(1)
# --------------------------------------------------------------------------
# Argument parsing
# Invocation forms:
# /mpm-session-resume → list_mode=True if >1 session, else resume most recent
# /mpm-session-resume --select <value> → select by index or partial ID
# /mpm-session-resume <session-id> → exact session-id (backward-compatible)
# --------------------------------------------------------------------------
# The skill receives user arguments via the 'args' variable set by the harness,
# or you can parse from the invocation line. Use whichever is available.
# For safety, default to an empty list if 'args' is not defined.
try:
raw_args = args # type: ignore[name-defined] # set by skill harness
except NameError:
raw_args = []
select_value: str | None = None
exact_session_id: str | None = None
i = 0
while i < len(raw_args):
token = str(raw_args[i])
if token == "--select" and i + 1 < len(raw_args):
select_value = str(raw_args[i + 1])
i += 2
elif not token.startswith("--"):
exact_session_id = token
i += 1
else:
i += 1
# --------------------------------------------------------------------------
# Create helper scoped to the current project.
# --------------------------------------------------------------------------
helper = SessionResumeHelper(project_path=Path.cwd())
# --------------------------------------------------------------------------
# Dispatch
# --------------------------------------------------------------------------
if select_value is not None:
# --select <index-or-partial-id>
session_data, error_msg = helper.resolve_session_by_selection(select_value)
if session_data is None:
print(error_msg)
else:
prompt_text = helper.format_resume_prompt(session_data)
print(prompt_text)
session_id = session_data.get("session_id", "unknown")
file_path = session_data.get("file_path")
print(f"Loaded session: {session_id}")
if file_path:
print(f"Source: {file_path}")
elif exact_session_id is not None:
# Exact session ID supplied (backward-compatible form).
all_sessions = helper.list_all_sessions()
matched = [
s for s in all_sessions
if s.get("session_id") == exact_session_id
]
if not matched:
print(f"No session found with ID: {exact_session_id}")
print("")
print(helper.format_session_list())
else:
session_data = matched[0]
prompt_text = helper.format_resume_prompt(session_data)
print(prompt_text)
file_path = session_data.get("file_path")
print(f"Loaded session: {exact_session_id}")
if file_path:
print(f"Source: {file_path}")
else:
# No arguments — list when multiple sessions exist, else resume most recent.
session_count = helper.get_session_count()
if session_count == 0:
print("No paused sessions found for this project in .claude-mpm/sessions/")
print("")
print("To create a paused session, use: /mpm-pause")
elif session_count > 1:
# Show numbered list so the user can pick.
print(helper.format_session_list())
print("")
print("Resuming the most recent session automatically…")
session_data = helper.check_and_display_resume_prompt()
if session_data:
session_id = session_data.get("session_id", "unknown")
file_path = session_data.get("file_path")
print(f"Loaded session: {session_id}")
if file_path:
print(f"Source: {file_path}")
else:
# Only one session — resume it directly (existing behaviour).
session_data = helper.check_and_display_resume_prompt()
if session_data is None:
print("No paused sessions found for this project in .claude-mpm/sessions/")
print("")
print("To create a paused session, use: /mpm-pause")
else:
session_id = session_data.get("session_id", "unknown")
file_path = session_data.get("file_path")
print(f"")
print(f"Loaded session: {session_id}")
if file_path:
print(f"Source: {file_path}")
Session location: project-local .claude-mpm/sessions/session-*.md (and .json/.yaml)
Sessions are stored relative to the project root so each project has its own isolated session history. Resume always validates that the session belongs to the current project — you will never accidentally load a session from another checkout.
The store contains:
<project-root>/.claude-mpm/sessions/
├── LATEST-SESSION.txt # Pointer to most recent session
├── session-YYYYMMDD-HHMMSS.md # Human-readable
├── session-YYYYMMDD-HHMMSS.json # Machine-readable (loaded by resume)
└── session-YYYYMMDD-HHMMSS.yaml # Config format
Resume reads the .json file (authoritative machine-readable format). The .md file is for humans; resume will not attempt to parse it as JSON.
Token usage: ~20-40k tokens (10-20% of context budget)
This loads the session summary, accomplishments, next steps, git history, and pending task list into context so the PM can continue work without rediscovering state.
From the paused session:
Calculated at resume time:
helper.clear_session(session_data) explicitly./mpm-pause - Pause current session and save state/mpm-init resume - Alternative resume entry pointSee docs/features/session-auto-resume.md for auto-pause behavior.