Yet-another-agent-harness pull-request-msg-with-gh
install
source · Clone the upstream repo
git clone https://github.com/dirien/yet-another-agent-harness
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/dirien/yet-another-agent-harness "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/pull-request-msg" ~/.claude/skills/dirien-yet-another-agent-harness-pull-request-msg-with-gh && rm -rf "$T"
manifest:
.claude/skills/pull-request-msg/SKILL.mdsource content
<!-- Copyright 2025-2026 Richard Shade. Licensed under Apache-2.0. -->
<!-- SPDX-License-Identifier: Apache-2.0 -->
Pull Request Message Generator
Generate a
PR_MESSAGE.md file summarizing the current session's work.
Requires gh CLI authenticated with the target repository.
Prerequisite check
gh --version 2>/dev/null && gh auth status 2>/dev/null
If
gh is not installed, stop and report:
- Install from https://cli.github.com
cannot be installed via npmgh- After install, run
to authenticategh auth login
Do not proceed without a working, authenticated
gh CLI.
Workflow
- Analyze session context — review changes made in the current
session. Explore changed files with
andgit diff
to understand the full scope of work, in addition to reviewing conversation history. Both sources inform the PR message.git status - Detect issue number — use the issue detection algorithm below.
If the user indicates there is no associated issue, omit the
footer entirely.Closes #<issue-number> - Determine commit type — based on the nature of changes (see
for the list of types)references/pr-message-format.md - Write PR_MESSAGE.md — using the format in
references/pr-message-format.md - Add to .gitignore — add
if not already presentPR_MESSAGE.md - Validate — run commitlint and markdownlint checks
Issue number detection
The issue number MUST be determined by searching GitHub, NOT by extracting numbers from branch names.
Algorithm
# Step 1: Get branch name BRANCH=$(git branch --show-current) # Step 2: Extract keywords (strip leading numbers and hyphens) # Example: "125-greenops-equivalencies" → "greenops equivalencies" KEYWORDS=$(echo "$BRANCH" | sed 's/^[0-9]*-//' | tr '-' ' ') # Step 3: Search GitHub issues gh issue list --search "$KEYWORDS" --state all \ --json number,title --limit 5
Evaluation rules
- Exactly 1 result with title containing most keywords → use it
- 0 results → ask the user for the issue number
- 2+ results → show options and ask the user to pick
- Ambiguous match → ask the user to confirm
Never extract issue numbers from
- Branch name digits (e.g.,
is NOT issue #125)125- - Spec folder names (e.g.,
)specs/125-xyz/ - Worktree folder names
These are internal identifiers, not GitHub issue numbers.
Critical rules
- No redundancy — summary must add context beyond the commit subject
- No
section — the first line IS the commit message## Commit Message - Never modify
— use CLI flags instead.markdownlint.json - Trailing newline — file must end with a single newline
- Ask when ambiguous — if issue search returns 0, 2+, or unclear results, ask the user
Validation
If the commitlint and markdownlint skills are available in the current context, use them to validate PR_MESSAGE.md. Otherwise, run directly:
# Validate commit message format cat PR_MESSAGE.md | npx commitlint # Validate markdown (MD041 disabled — first line is commit subject, # not heading) npx markdownlint --disable MD041 -- PR_MESSAGE.md
If neither the skills nor
npx are available, fail hard:
- Install commitlint:
npm install -g @commitlint/cli @commitlint/config-conventional - Install markdownlint:
npm install -g markdownlint-cli
Do not silently skip validation.
Fix any issues and re-validate before reporting success.