skills/open-source-marketing/SKILL.md
When the user wants to market an open source project authentically. Trigger phrases include "open source marketing," "OSS marketing," "GitHub marketing," "promote my library," "grow stars," "launch open source," "open source growth," or "contributor marketing."
npx skillsauth add jonathimer/devmarketing-skills open-source-marketingInstall 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 helps you market open source projects without being cringe. Covers GitHub optimization, community building, contributor experience, launch strategies, and sustainable growth.
Load your audience context first. Read .agents/developer-audience-context.md to understand:
If the context file doesn't exist, run the developer-audience-context skill first.
| Works | Doesn't Work | |-------|--------------| | Building in public | Spamming "check out my project" | | Solving real problems | Building solutions seeking problems | | Genuine community engagement | Transactional follows/unfollows | | Great docs and DX | "The code is self-documenting" | | Celebrating contributors | Taking sole credit | | Consistent presence | Launch and disappear |
Growth = (Real value) × (Discoverability) × (First-use experience)
If any factor is zero, growth is zero.
Your README is your landing page. Optimize it.
Structure:
# Project Name
[One-line description that explains what it does]
[Badges: build status, version, license, downloads]
[Screenshot or GIF showing it in action]
## Why [Project Name]?
- ✅ [Benefit 1 - specific, not fluffy]
- ✅ [Benefit 2]
- ✅ [Benefit 3]
## Quick Start
\`\`\`bash
npm install project-name
\`\`\`
\`\`\`javascript
// 5 lines that show immediate value
\`\`\`
## Installation
[Detailed installation for all platforms]
## Usage
[Core usage patterns with examples]
## Documentation
[Link to full docs]
## Contributing
We love contributions! See [CONTRIBUTING.md](CONTRIBUTING.md).
## License
[License type] - see [LICENSE](LICENSE)
| Element | Why It Matters | |---------|---------------| | Clear name | Memorable, searchable, spellable | | One-liner | "A [type] for [audience] that [does what]" | | Badges | Social proof, health signals | | Visual | GIF > Screenshot > Nothing | | Quick start | <5 lines to first value | | Why this? | Differentiation from alternatives | | Installation | All platforms, copy-paste | | Examples | Real use cases, not contrived | | Docs link | More detail available | | Contributing | Community welcome |
| Element | Best Practice | |---------|--------------| | Description | 100 chars max, keyword-rich | | Topics | 5-10 relevant tags for discoverability | | Website | Link to docs or landing page | | Releases | Semantic versioning, changelogs | | Issues | Templates for bugs/features | | Discussions | Enable for community Q&A | | Sponsors | Enable if you want funding |
Bug report template:
---
name: Bug Report
about: Report a bug to help us improve
---
## Bug Description
[Clear description]
## Steps to Reproduce
1.
2.
3.
## Expected Behavior
[What should happen]
## Actual Behavior
[What actually happens]
## Environment
- OS:
- Node version:
- Package version:
## Additional Context
[Screenshots, logs, etc.]
Feature request template:
---
name: Feature Request
about: Suggest an idea for this project
---
## Problem
[What problem does this solve?]
## Proposed Solution
[How would you like it to work?]
## Alternatives Considered
[Other approaches you've thought about]
## Additional Context
[Examples, mockups, etc.]
| Platform | Best For | Setup Effort | |----------|----------|--------------| | GitHub Discussions | Q&A, announcements | Low | | Discord | Real-time chat, community feel | Medium | | Slack | Enterprise communities | Medium | | Forum (Discourse) | Async, searchable discussions | High |
Start with GitHub Discussions. Add Discord when you have 50+ active users.
| Principle | Implementation | |-----------|----------------| | Be responsive | Respond to issues within 48 hours (even if just "looking into it") | | Celebrate contributions | Thank every contributor publicly | | Be transparent | Share roadmap, explain decisions | | Set expectations | Clear SLA for maintainer response | | Welcome newcomers | "good first issue" labels, mentorship |
User → Star → Issue → PR → Regular Contributor → Maintainer
Optimize each transition:
| Transition | How to Improve | |------------|----------------| | User → Star | Great README, visible value | | Star → Issue | Clear issue templates, welcoming tone | | Issue → PR | "good first issue" labels, CONTRIBUTING.md | | PR → Regular | Quick review, encouraging feedback | | Regular → Maintainer | Trust, shared ownership |
# Contributing to [Project]
First off, thanks for considering contributing! ❤️
## Quick Start
1. Fork the repo
2. Clone your fork
3. Install dependencies: `npm install`
4. Create a branch: `git checkout -b my-feature`
5. Make your changes
6. Run tests: `npm test`
7. Commit: `git commit -m "Add my feature"`
8. Push: `git push origin my-feature`
9. Open a Pull Request
## Development Setup
[Detailed setup instructions]
## Code Style
- We use [Prettier/ESLint config]
- Run `npm run lint` before committing
- [Other conventions]
## Commit Messages
We follow [Conventional Commits](https://conventionalcommits.org/):
- `feat: add new feature`
- `fix: resolve bug`
- `docs: update readme`
- `chore: update dependencies`
## Pull Request Process
1. Update docs if needed
2. Add tests for new features
3. Ensure CI passes
4. Get one approval
## Good First Issues
Look for issues labeled `good first issue` — these are great starting points!
## Questions?
Open a Discussion or reach out on Discord.
Create genuinely approachable issues:
| Good | Not Good | |------|----------| | "Add TypeScript types for X function" | "Refactor the entire codebase" | | "Fix typo in README" | "Performance optimization" | | "Add test for Y method" | "Debug intermittent CI failure" | | "Update dependency Z" | "Implement feature from RFC" |
For each good first issue:
| Task | Done? | |------|-------| | README polished | ☐ | | Quick start works | ☐ | | Docs exist | ☐ | | 3+ examples/demos | ☐ | | Tests passing | ☐ | | License chosen | ☐ | | CONTRIBUTING.md | ☐ | | Issue templates | ☐ | | Social preview image | ☐ | | 5-10 GitHub topics | ☐ |
Timeline:
| Time | Action | |------|--------| | Day before | Final README review, prep all posts | | Launch morning | HN post (best: 6-8am PT, Tuesday-Thursday) | | +1 hour | Twitter thread | | +2 hours | Reddit post to relevant subreddits | | Throughout day | Respond to all comments/questions | | End of day | Thank everyone, share metrics |
Hacker News:
Reddit:
Twitter/X:
Dev.to / Hashnode:
| Week | Focus | |------|-------| | Week 1 | Respond to all feedback, fix bugs | | Week 2 | Blog post: "What I learned from launch" | | Week 3 | Start regular updates, ship new feature | | Month 1 | Community building, contributor docs | | Ongoing | Consistent presence, regular releases |
| Tactic | Effort | Impact | Timeline | |--------|--------|--------|----------| | SEO-optimized docs | Medium | High | 3-6 months | | Integration tutorials | Medium | High | 1-2 months | | Conference talks | High | Medium | 3-6 months | | Comparison content | Low | Medium | 1-2 months | | Guest blog posts | Medium | Medium | 1-2 months | | Newsletter features | Low | Low-Medium | 2-4 weeks | | Twitter presence | Medium | Medium | Ongoing |
| Content Type | Purpose | |--------------|---------| | "Why we built X" | Launch story, motivation | | "X vs Y vs Z" | Capture comparison searches | | "Migrating from Y to X" | Convert competitor users | | "X + [Popular Tool]" | Capture integration searches | | "How We Use X at [Company]" | Social proof, real use case | | "X Performance Benchmarks" | Technical credibility |
| Risk | Mitigation | |------|------------| | Overwhelming issues | Set response SLA expectations | | Feature demands | Public roadmap, RFC process | | Solo maintenance | Actively recruit co-maintainers | | Always-on pressure | Scheduled "office hours" vs. 24/7 | | Negative feedback | Code of conduct, moderation |
| Vanity Metric | Value Metric | |---------------|--------------| | Stars | Active issues + PRs | | Forks | Returned contributors | | Downloads | Weekly active users | | Twitter followers | Community engagement |
| Metric | Where to Find It | |--------|------------------| | Stars over time | GitHub Insights, Star History | | Clones | GitHub Traffic | | Referrers | GitHub Traffic | | npm downloads | npm-stat.com | | Community size | Discord/Slack member count | | Contributor count | GitHub Insights | | Issue response time | Manual tracking |
| Tool | Use Case | |------|----------| | Octolens | Monitor mentions of your project across GitHub, HN, Reddit, Twitter, and Stack Overflow. Track competitor projects. Find contributors asking questions. | | Star History | Track star growth over time | | npm-stat | Download statistics | | GitHub Traffic | Views, clones, referrers | | Shield.io | Dynamic badges | | All Contributors | Recognize all contributors | | Probot | Automate GitHub workflows |
developer-audience-context — Know who your users arecommunity-building — Build Discord/Slack communitydevrel-content — Create supporting contentdeveloper-advocacy — Conference talks, podcastshacker-news-strategy — Launch and engage on HNdevelopment
When the user wants to create developer YouTube content, technical screencasts, or video tutorials. Trigger phrases include "YouTube," "developer video," "screencast," "video tutorial," "live coding," "YouTube for developers," "tech YouTube," or "YouTube thumbnails."
development
When the user wants to build a developer following on Twitter/X, write technical threads, or understand what works for dev audiences on X. Trigger phrases include "Twitter," "X," "developer Twitter," "tech Twitter," "technical threads," "building dev following," or "Twitter for developers."
development
Design pricing models that developers understand, accept, and can predict. Trigger phrases: usage-based pricing, API pricing, metered billing, developer pricing, pricing page, cost calculator, pay as you go, pricing transparency, competitive pricing, developer billing
development
When the user wants to create step-by-step technical tutorials, quickstarts, or code walkthroughs. Trigger phrases include "tutorial," "quickstart," "getting started guide," "walkthrough," "step by step," "how to guide," "hands-on guide," or "code tutorial."