Agent skill
voice-capture
This skill should be used when extracting voice profiles from sample text, creating voice documentation, or matching a specific writing style. It applies when users provide sample text and want to capture the voice for future use.
Install this agent skill to your Project
npx add-skill https://github.com/robertguss/claude-code-toolkit/tree/main/plugins/compound-writing/skills/voice-capture
SKILL.md
Voice Capture Skill
Extract and encode writing voice from sample text into reusable voice profiles. This skill transforms examples of writing you like into documented patterns that can guide future writing.
When to Use This Skill
This skill applies when:
- A user provides sample text and asks "write like this"
- Creating a voice profile from existing content
- Documenting a brand voice for consistency
- Capturing an author's style for future reference
- Analyzing differences between two writing styles
Core Philosophy
Voice isn't just word choice. It's sentence rhythm, paragraph structure, emotional register, and a thousand small decisions that create a distinctive sound.
This skill captures those decisions systematically so they can be applied to new content.
Voice Profile Structure
A complete voice profile has three layers. See voice-profile-template.yaml for the full template.
Layer 1: Immutable Traits
Core characteristics that define the voice:
traits:
- direct # vs. indirect, circumspect
- conversational # vs. formal, academic
- technically-informed # level of assumed expertise
register: informal # formal / semiformal / informal
prohibited:
- "synergy"
- passive voice in openings
- exclamation marks (except in quotes)
Layer 2: Channel Guidance
How the voice adapts by medium:
channels:
blog:
length: "1000-2000 words"
personality: "full"
storytelling: "encouraged"
newsletter:
length: "300-500 words"
personality: "high - direct address okay"
storytelling: "personal anecdotes"
social:
length: "280 chars or thread"
personality: "punchy, hooks required"
storytelling: "minimal - punchlines only"
documentation:
length: "as needed"
personality: "minimal"
storytelling: "none - clarity first"
Layer 3: Example Library
Exemplars that demonstrate the voice:
exemplars:
- path: "samples/great-opening.md"
why: "Concrete example first, theory second"
demonstrates: ["hook", "pacing"]
- path: "samples/transition.md"
why: "Invisible transition technique"
demonstrates: ["flow", "structure"]
- path: "samples/closing.md"
why: "Strong CTA without being salesy"
demonstrates: ["conclusion", "call-to-action"]
Extraction Process
Step 1: Collect Samples
Minimum: 3 samples (ideally 5-10) Total words: At least 2,000 words Variety: Different topics, same author/brand
Step 2: Analyze Dimensions
Reference analysis-dimensions.md for the full framework.
Vocabulary Analysis
- Complexity: Simple ↔ Complex
- Formality: Casual ↔ Formal
- Jargon: Technical ↔ Accessible
- Signature words: Frequently used phrases
Sentence Analysis
- Length: Average words per sentence
- Variety: Standard deviation of sentence length
- Structure: Simple vs. compound vs. complex ratio
- Fragments: Used for emphasis? How often?
Paragraph Analysis
- Length: Average sentences per paragraph
- Opening patterns: How do paragraphs typically start?
- Closing patterns: How do paragraphs typically end?
Rhythm Analysis
- Pacing: Quick (short sentences) vs. measured (longer)
- Punctuation style: Dashes, semicolons, parentheses
- White space: Dense vs. airy paragraphs
Emotional Analysis
- Tone: Optimistic, skeptical, neutral, passionate
- Distance: Intimate (I, you) vs. distant (one, they)
- Stakes: High urgency vs. calm reflection
Step 3: Document Patterns
For each dimension, document:
- The observed pattern
- A concrete example
- A counter-example (what this voice avoids)
Step 4: Create Profile
Use extraction-templates.md to structure your findings.
Output: .claude/voice-profiles/[name].yaml
Using Voice Profiles
In Writing Commands
# In /writing:draft
style:
voice_profile: "kieran-blog"
# OR
voice_profile: ".claude/voice-profiles/client-name.yaml"
For Voice Guardian
The voice-guardian agent uses profiles to:
- Score voice consistency (0-100)
- Identify drift points
- Suggest specific fixes
Target score: 85+
For New Writers
When onboarding writers to match an existing voice:
- Share the voice profile
- Share the exemplars
- Run voice-guardian on their drafts
Quick Extraction Workflow
For rapid voice capture (when you need a profile fast):
## Quick Profile: [Name]
**Based on**: [X] samples totaling [Y] words
### Core Traits
- [Trait 1]
- [Trait 2]
- [Trait 3]
### Sentence Patterns
Average length: [X] words
Common patterns:
- [Pattern 1]
- [Pattern 2]
### Vocabulary Markers
**Signature words**: [list]
**Avoided words**: [list]
### Tone
[Brief description]
### Quick Examples
Good: "[example that nails the voice]"
Bad: "[example that would violate it]"
Common Extraction Challenges
Challenge: Too Few Samples
Problem: Can't identify patterns from 1-2 samples. Solution: Ask for more content or analyze published work from the same source.
Challenge: Inconsistent Source
Problem: The sample voice varies significantly. Solution: Either document the variation (multiple profiles) or focus on the most recent/best examples.
Challenge: Style vs. Voice
Problem: Confusing topic-specific style with core voice. Solution: Analyze samples on different topics. What stays constant? That's the voice.
Challenge: Unconscious Patterns
Problem: Author doesn't know what makes their voice distinctive. Solution: Compare to other writers. What's different? That's often the key.
Quality Checklist
A voice profile is complete when:
- All three layers are populated
- At least 3 exemplars are documented
- Prohibited patterns are explicit
- Channel variations are noted
- A test passage can be evaluated against it
- Someone unfamiliar with the voice could use it
References
- extraction-templates.md - Templates for structured extraction
- analysis-dimensions.md - All dimensions to analyze
- example-profiles.md - Sample voice profiles for reference
- voice-profile-template.yaml - The YAML template
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
skill-creator
Guide for creating effective skills. This skill should be used when users want to create a new skill (or update an existing skill) that extends Claude's capabilities with specialized knowledge, workflows, or tool integrations.
app-store-listing-optimizer
Optimize iOS App Store and Google Play Store listings for maximum discoverability and conversion. Perform competitive keyword research, craft keyword-optimized titles/subtitles/descriptions, design screenshot sequences, and generate A/B test variants. Use when the user has a built app and needs to write or improve their store listing, do ASO keyword research, optimize app metadata, plan screenshot strategy, or create listing variants for testing. Triggers on "optimize my app listing", "ASO", "app store optimization", "keyword research for my app", "improve my store listing", "screenshot strategy", "app store keywords", "play store listing".
app-growth-playbook
Generate platform-specific, actionable growth playbooks for mobile apps. Use when planning a Product Hunt launch, creating TikTok/Reels content strategies, setting up Apple Search Ads campaigns, preparing App Store featuring submissions, building referral loops, designing email/push re-engagement campaigns, writing Reddit launch posts, or creating content marketing plans for app growth. Provides templates, scripts, timing guides, and step-by-step processes — not generic advice.
app-creator
Orchestrate iOS/macOS app scaffolding and optional skill adoption for existing projects. Use when users want a guided wizard that can scaffold with XcodeGen and optionally install xcode-makefiles and simple-tasks.
simple-tasks
Install a fast local task workflow for single-project planning with `scripts/task.sh` (claim, done, status, reporting) backed by `tasks/TASKS.md` and optional `tasks/details/` notes. Use for lightweight in-progress task coordination, not full team issue tracking.
xcode-makefiles
Install strict Xcode Makefile tooling for iOS/macOS projects, including build/run/test scripts with AGENT_NAME-based per-agent isolation under build/. Use when a project needs reproducible local CLI builds without full app scaffolding.
Didn't find tool you were looking for?