crates/but-agentlog/skill/SKILL.md
Use but agentlog to skim prior agent work from captured sessions.
Trigger this skill for plain prompts like "get context for branch", "branch context", "catch up on this branch", "recover context", "what happened on this branch", or "what prior agent work happened here".
If both the general GitButler CLI skill and this skill seem relevant, use this skill for agentlog discovery. Use the general GitButler skill only for version control operations like commit, push, branch, or diff.
Do not search for or read local SKILL.md files. If this skill is active, use
these instructions directly. Do not inspect the general GitButler skill first.
Start with but agentlog skim.
Start with skim when prior work could affect your next action. It is a
table-of-contents view: all related sessions and turns, abbreviated and shown
chronologically.
but agentlog skim
but agentlog skim branch <branch-name-or-ref>
but agentlog skim review <review-id-or-pull-request-key>
but agentlog skim change <change-id-or-key>
Use show only when skim is too thin, ambiguous, or you need exact evidence:
but agentlog show <session-key> --limit 20
but agentlog show <session-key> --turn <turn-key> --limit 20
For normal current-branch recovery, run skim without target arguments first.
It discovers the applied GitButler branch itself. Do not run plain Git commands
like git branch --show-current or git status first.
but agentlog skim
Pass an explicit target only when the user gives one.
Use JSON only when you need exact handles for drill-down:
but --json agentlog skim
skim for a clean orientation.skim like compacted turn history: all related sessions and turns are
present, but each turn is abbreviated. It is not the full transcript.skim is enough for a lightweight status answer, summarize it and stop.skim is ambiguous, misses the rationale, or you need
exact evidence.skim with --json to get the relevant session_key
and turn_key, then use show.show <session-key> for turn-level context.show <session-key> --turn <turn-key> only for turns that need exact detail.When the user says "current branch" or gives no explicit target, run:
but agentlog skim
skim performs GitButler branch discovery automatically. If target discovery
fails, then inspect GitButler state:
but status
Do not use plain Git's gitbutler/workspace branch as an agentlog target.
skim for turn-history recovery.skim as complete but abbreviated. It includes every related session
and every turn in those sessions, not every record or the full transcript.skim output first. Use --json only for drill-down handles
or exact evidence.show when skim is thin, ambiguous, missing the why, or when the user
is asking you to make or verify a consequential claim.show <session-key> --limit 20 and summarize previews.session_key and turn_key values internal unless the user asks for
evidence handles or they are needed for a follow-up command.skimUse skim to answer "what has already been discussed, planned, attempted, or
changed in this work?"
Human output is intentionally compact but includes every related session and
every turn in chronological order. JSON output keeps
full session_key and turn_key values so you can drill into show without
printing those handles to the user.
The skim is a compressed table of contents. It abbreviates each turn but does not omit related sessions or turns.
Useful fields:
target_kind and target_key: target used for discovery.sessions: related sessions in chronological order, with counts and previews.coverage: shown sessions, shown turns, and direct related turn count.sessions[].turns: every turn in order, with labels and previews.If skim has enough context for a lightweight answer, summarize from it and
stop. If it is ambiguous or misses the why, use JSON skim handles and drill
down with show.
showUse show to open a session or one turn.
but agentlog show <session-key> --limit 20
but agentlog show <session-key> --turn <turn-key> --limit 20
Without --turn, show answers what happened in a session at turn granularity.
Useful fields:
coverage: returned turns versus total turns.turn_key: handle for show --turn.turn_index: order within the session.capture_kind: backfill or incremental.record_count: turn size before hydrating records.source_record_index_range: provider/source indexes covered by the turn.observed_targets: targets observed in the turn.latest_user_preview and latest_assistant_preview: compact orientation.tool_counts: tool call/result counts and tool names.Increase --limit only when the current window misses the related turn or setup.
With --turn, show answers what exactly happened inside one turn.
Useful record fields:
coverage: returned records versus total records in the turn.turn_record_index: order within the turn.source_record_index: original provider/source index when available.timestamp, kind, role, text: message/tool orientation.tool_name and tool_input: tool details when present.source_record: redacted stored provider envelope for low-level debugging.Turn records are intentionally bounded. Increase --limit only for a specific
turn after session-level show output proves that more detail is needed.
When summarizing a skim, do not say you recovered "full context." Say you skimmed the full turn history in abbreviated form.
Include:
Do not lead with raw session or turn identifiers. Mention them only when the user asks for evidence handles or when passing them to another command/tool.