Opendirectory pr-description-writer

PR Description Writer

install
source · Clone the upstream repo
git clone https://github.com/Varnan-Tech/opendirectory
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/Varnan-Tech/opendirectory "$T" && mkdir -p ~/.claude/skills && cp -r "$T/packages/cli/skills/pr-description-writer" ~/.claude/skills/varnan-tech-opendirectory-pr-description-writer && rm -rf "$T"
manifest: packages/cli/skills/pr-description-writer/SKILL.md
source content

PR Description Writer

Read the current branch diff and write a complete GitHub pull request description. Create or update the PR with one command.

Writing Style

Apply to all generated PR descriptions:

  • Active voice. "Adds X" not "X has been added."
  • Present tense for summary ("Adds caching layer"), past tense for context ("The old approach caused N requests per render")
  • Short sentences, one idea per bullet
  • No em dashes — use a comma or period instead
  • No filler: "this PR", "this commit", "as per the discussion"
  • Specifics beat generalities: "reduces p95 latency from 800ms to 90ms" beats "improves performance"

Step 1: Check Setup

Confirm

gh
is authenticated:

gh auth status

If not authenticated:

gh auth login
and follow the prompts.

Confirm the current directory is a git repo with an active branch:

git branch --show-current

If detached HEAD or no branch, stop and ask the user which branch they want to describe.


Step 2: Gather Diff Context

Run all three commands to build context:

File summary (what changed):

git diff main...HEAD --stat

Commit messages (why it changed):

git log main...HEAD --oneline

Full diff (how it changed):

Use

origin/main
first (always up to date), fall back to local
main
, then
master
:

if git rev-parse origin/main &>/dev/null 2>&1; then
  BASE=origin/main
elif git rev-parse main &>/dev/null 2>&1; then
  BASE=main
else
  BASE=master
fi
git diff $BASE...HEAD

If the diff is very large (over 500 lines), read the

--stat
summary and the commit messages only. Also read the first 200 lines of the diff to understand the primary changes without processing the entire output.

Also check for an existing PR and read its current title/body:

gh pr view --json title,body,baseRefName 2>/dev/null

Step 3: Read the Format Guide

Read

references/pr-format-guide.md
in full before writing anything. Internalize:

  • Required sections and their order
  • How to write each section
  • What to include vs omit
  • The testing section format

Step 4: Generate the Description

Write the PR description using the format from

references/pr-format-guide.md
.

Rules:

  • Every bullet in the Changes section must trace to something in the diff
  • Do not invent testing steps that are not implied by the code changes
  • If a section has no relevant content, omit it entirely (do not write "N/A" or leave it empty)
  • Screenshots section: only include if there are UI changes visible in the diff
  • If commit messages explain the "why", use that context in the Summary

QA checkpoint: Before presenting, verify:

  • Summary is 1-2 sentences, active voice, no filler
  • Every change bullet is specific and traces to the diff
  • No invented metrics or outcomes
  • Testing steps are actionable (someone could follow them)
  • No em dashes in any line

Step 5: Create or Update the PR

Present the description to the user and ask: "Ready to create the PR, update the existing one, or output only?"

Create a new PR:

Pass the body via stdin to handle backticks, quotes, and newlines safely:

gh pr create --title "TITLE_HERE" --body-file - << 'EOF'
BODY_HERE
EOF

Suggest a title based on the commit messages and diff summary. The title should be imperative mood, under 72 characters: "Add Redis caching for user session lookups" not "Added caching".

Update an existing PR:

gh pr edit --body-file - << 'EOF'
BODY_HERE
EOF

Output only: Present the title and body in a code block for manual copy-paste.

After creating or updating, confirm: "PR description updated. View it at: [URL]"