skills_categorized/education/positron-issue-creator/SKILL.md
This skill should be used when drafting GitHub issues for the Positron repository. It provides workflows for searching duplicates, selecting appropriate labels, gathering complete context through questioning, and writing terse, fluff-free issues that precisely describe what is needed or wrong. The skill prepares issues for manual submission by the user. Use this skill when the user asks to draft or prepare an issue for Positron.
npx skillsauth add activer007/ordinary-claude-skills positron-issue-creatorInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
This skill guides the drafting of high-quality GitHub issues for the Positron IDE repository. It ensures issues are:
Use this skill when:
Do NOT use this skill for:
positron-intake-rotation instead)Read operations (ALLOWED):
gh CLIgh CLIWrite operations (NOT ALLOWED):
gh issue createInstead: Prepare issues in markdown files or clipboard-ready format for manual user submission.
Important: This skill prepares issues for manual submission. It does NOT automatically create GitHub issues. The user maintains full control over submitting to GitHub.
Follow this workflow for every issue drafting request:
Before drafting anything, ensure all necessary information is available. Use iterative questioning if needed.
For Bug Reports, obtain:
For Feature Requests, obtain:
Ask specific questions when information is missing:
Never make assumptions. If unclear, ask rather than guess.
Use scripts/search_duplicates.sh to search for existing issues and discussions:
cd /path/to/positron/.claude/skills/positron-issue-creator
./scripts/search_duplicates.sh "keywords from issue"
Review results carefully:
Present findings to user:
If duplicate found:
If no duplicates:
Use scripts/fetch_labels.sh to retrieve current repository labels:
cd /path/to/positron/.claude/skills/positron-issue-creator
./scripts/fetch_labels.sh
Choose labels based on:
Area labels (select 1-2):
area: console - Console/REPL functionalityarea: notebook - Jupyter notebook integrationarea: editor - Text editor functionalityarea: plots - Plot viewer and visualizationarea: data-explorer - Data viewer and explorerarea: connections - Database connectionsarea: help - Help pane and documentationarea: ui - General UI/UX issuesfetch_labels.sh for complete optionsType label (select 1):
Bug - Something doesn't work as intendedFeature Request - New capability or enhancementDocumentation - Documentation improvementsPerformance - Works but too slowlyOther considerations:
Use the templates in references/issue_templates.md as starting points, but adapt to the specific issue.
Load templates when needed:
Follow writing guidelines from references/writing_guidelines.md:
Core principles:
Title guidelines:
[Component] fails when [condition]Add [feature] to [component]Body structure:
Example bug report:
Title: Console freezes when printing dataframes with 100k+ rows
The console becomes unresponsive when printing large dataframes.
## Steps to reproduce
1. Create dataframe: `df = pd.DataFrame({'a': range(100000)})`
2. Print it: `print(df)`
3. Console freezes, UI becomes unresponsive
## System details
- Positron 2024.10.0 Build 123
- macOS 14.5
- Python 3.11.6
## Error messages
Developer Console shows: "Maximum call stack size exceeded"
Example feature request:
Title: Add keyboard shortcut to insert markdown cell in notebooks
Currently inserting markdown cells requires clicking the dropdown menu.
Keyboard shortcut would improve notebook authoring workflow.
## Proposed behavior
- Add keyboard shortcut (e.g., Cmd+M or Ctrl+M)
- Should work when focus is in notebook
- Should insert cell below current cell
## Context
Similar to Jupyter's 'M' key in command mode. Notebook workflows
frequently alternate between code and markdown cells.
Common anti-patterns to avoid:
Review checklist before presenting:
Show the complete drafted issue including:
Ask user: "Does this accurately capture the issue? Would you like any changes before I create it?"
Allow for iteration:
Make requested changes and show updated draft.
Once user approves the draft, offer options for how they want to use it:
Ask the user: "How would you like me to prepare this issue?"
Create a markdown file with all issue details:
# Create file with timestamp in name for uniqueness
cat > "positron-issue-$(date +%Y%m%d-%H%M%S).md" <<'EOF'
---
title: Issue title here
labels: area: console, Bug
repository: posit-dev/positron
---
Full issue body here
with multiple lines
EOF
After saving:
https://github.com/posit-dev/positron/issues/newPresent the issue in a format ready to copy:
**Title:**
Issue title here
**Labels:**
area: console, Bug
**Body:**
Full issue body here
with multiple lines
---
Create this issue at: https://github.com/posit-dev/positron/issues/new
After presenting:
Be thorough but not pedantic:
When uncertain:
Never guess or assume:
Be patient with iteration:
Optimize for scanability:
Respect reader's time:
Be precise:
If user describes a security vulnerability:
Treat as feature requests but focus on:
Label with Documentation type.
Use bug report template but emphasize:
Label with Performance type.
If user describes several related but distinct issues:
scripts/fetch_labels.shRetrieves all repository labels for categorization.
Usage:
./scripts/fetch_labels.sh # Human-readable output
./scripts/fetch_labels.sh --json # JSON output for parsing
scripts/search_duplicates.shSearches for potential duplicate issues and discussions.
Usage:
./scripts/search_duplicates.sh "search terms"
./scripts/search_duplicates.sh "search terms" --limit 30
Returns:
Load these reference documents when drafting issues:
references/issue_templates.md - Templates for bugs, features, and hybrid issuesreferences/writing_guidelines.md - Detailed writing guidance, anti-patterns, examplesA successful issue draft means:
1. Gather Context
↓
Ask specific questions until all info available
↓
2. Search Duplicates
↓
Run scripts/search_duplicates.sh
↓
Show results to user, confirm not duplicate
↓
3. Select Labels
↓
Run scripts/fetch_labels.sh
↓
Choose appropriate area and type labels
↓
4. Draft Issue
↓
Use templates from references/
↓
Follow writing guidelines (terse, specific, direct)
↓
5. Present Draft
↓
Show complete draft to user
↓
Iterate based on feedback
↓
6. Prepare for Submission
↓
Offer markdown file or clipboard format
↓
Save to file OR format for copying
↓
Provide GitHub link and submission instructions
Remember: The goal is to draft clear, actionable issues that respect both the reporter's intent and the development team's time. The user maintains full control over the final submission to GitHub.
tools
Generate typed TypeScript SDKs for AI agents to interact with MCP servers. Converts verbose JSON-RPC curl commands to clean function calls (docs.createDocument() vs curl). Auto-detects MCP tools from server modules, generates TypeScript types and client methods, creates runnable example scripts. Use when: building MCP-enabled applications, need typed programmatic access to MCP tools, want Claude Code to manage apps via scripts, eliminating manual JSON-RPC curl commands, validating MCP inputs/outputs, or creating reusable agent automation.
testing
Generate structured task lists from specs or requirements. IMPORTANT: After completing ANY spec via ExitSpecMode, ALWAYS ask the user: "Would you like me to generate a task list for this spec?" Use when user confirms or explicitly requests task generation from a plan/spec/PRD.
tools
Create compelling story-format summaries using UltraThink to find the best narrative framing. Support multiple formats - 3-part narrative, n-length with inline links, abridged 5-line, or comprehensive via Foundry MCP. USE WHEN user says 'create story explanation', 'narrative summary', 'explain as a story', or wants content in Daniel's conversational first-person voice.
testing
Navigate through the original three-world shamanic technology. Deploy when soul retrieval, power animal guidance, or journey between realms emerges. Deeply respectful of Tungus, Buryat, Yakut, Evenki traditions. Use for consciousness navigation, NOT cultural appropriation.