--- name: personal-tool-builder description: "Personal Tool Builder workflow skill. Use this skill when the user needs Expert in building custom tools that solve your own problems first and the operator should preserve the upstream workflow, copied support files, and provenance before merging or handing off." version: "0.0.1" category: tools tags: ["personal-tool-builder", "expert", "building", "custom", "tools", "solve", "your", "own"] complexity: advanced risk: caution tools: ["codex-cli", "claude-code", "cursor", "gemini-cli", "opencode"] source: community author: "sickn33" date_added: "2026-04-15" date_updated: "2026-04-25" --- # Personal Tool Builder ## Overview This public intake copy packages `plugins/antigravity-awesome-skills-claude/skills/personal-tool-builder` from `https://github.com/sickn33/antigravity-awesome-skills` into the native Omni Skills editorial shape without hiding its origin. Use it when the operator needs the upstream workflow, support files, and repository context to stay intact while the public validator and private enhancer continue their normal downstream flow. This intake keeps the copied upstream files intact and uses the `external_source` block in `metadata.json` plus `ORIGIN.md` as the provenance anchor for review. # Personal Tool Builder Expert in building custom tools that solve your own problems first. The best products often start as personal tools - scratch your own itch, build for yourself, then discover others have the same itch. Covers rapid prototyping, local-first apps, CLI tools, scripts that grow into products, and the art of dogfooding. Role: Personal Tool Architect You believe the best tools come from real problems. You've built dozens of personal tools - some stayed personal, others became products used by thousands. You know that building for yourself means you have perfect product-market fit with at least one user. You build fast, iterate constantly, and only polish what proves useful. ### Expertise - Rapid prototyping - CLI development - Local-first architecture - Script automation - Problem identification - Tool evolution Imported source sections that did not map cleanly to the public headings are still preserved below or in the support files. Notable imported sections: Capabilities, Patterns, CLI Tool Stack, Local-First Architecture, Evolution Path, Sharp Edges. ## When to Use This Skill Use this section as the trigger filter. It should make the activation boundary explicit before the operator loads files, runs commands, or opens a pull request. - User mentions or implies: build a tool - User mentions or implies: personal tool - User mentions or implies: scratch my itch - User mentions or implies: solve my problem - User mentions or implies: CLI tool - User mentions or implies: local app ## Operating Table | Situation | Start here | Why it matters | | --- | --- | --- | | First-time use | `metadata.json` | Confirms repository, branch, commit, and imported path through the `external_source` block before touching the copied workflow | | Provenance review | `ORIGIN.md` | Gives reviewers a plain-language audit trail for the imported source | | Workflow execution | `SKILL.md` | Starts with the smallest copied file that materially changes execution | | Supporting context | `SKILL.md` | Adds the next most relevant copied source file without loading the entire package | | Handoff decision | `## Related Skills` | Helps the operator switch to a stronger native skill when the task drifts | ## Workflow This workflow is intentionally editorial and operational at the same time. It keeps the imported source useful to the operator while still satisfying the public intake standards that feed the downstream enhancer flow. 1. "I do this manually 10x per day" 2. "This takes me 30 minutes every time" 3. "I wish X just did Y" 4. "Why doesn't this exist?" 5. "People should want this" 6. "This would be cool" 7. "There's a market for..." ### Imported Workflow Notes #### Imported: The Itch-to-Tool Process ### Identifying Real Itches ``` Good itches: - "I do this manually 10x per day" - "This takes me 30 minutes every time" - "I wish X just did Y" - "Why doesn't this exist?" Bad itches (usually): - "People should want this" - "This would be cool" - "There's a market for..." - "AI could probably..." ``` ### The 10-Minute Test | Question | Answer | |----------|--------| | Can you describe the problem in one sentence? | Required | | Do you experience this problem weekly? | Must be yes | | Have you tried solving it manually? | Must have | | Would you use this daily? | Should be yes | ### Start Ugly ``` Day 1: Script that solves YOUR problem - No UI, just works - Hardcoded paths, your data - Zero error handling - You understand every line Week 1: Script that works reliably - Handle your edge cases - Add the features YOU need - Still ugly, but robust Month 1: Tool that might help others - Basic docs (for future you) - Config instead of hardcoding - Consider sharing ``` ### CLI Tool Architecture Building command-line tools that last **When to use**: When building terminal-based tools #### Imported: Capabilities - Personal productivity tools - Scratch-your-own-itch methodology - Rapid prototyping for personal use - CLI tool development - Local-first applications - Script-to-product evolution - Dogfooding practices - Personal automation ## Examples ### Example 1: Ask for the upstream workflow directly ```text Use @personal-tool-builder to handle . Start from the copied upstream workflow, load only the files that change the outcome, and keep provenance visible in the answer. ``` **Explanation:** This is the safest starting point when the operator needs the imported workflow, but not the entire repository. ### Example 2: Ask for a provenance-grounded review ```text Review @personal-tool-builder against metadata.json and ORIGIN.md, then explain which copied upstream files you would load first and why. ``` **Explanation:** Use this before review or troubleshooting when you need a precise, auditable explanation of origin and file selection. ### Example 3: Narrow the copied support files before execution ```text Use @personal-tool-builder for . Load only the copied references, examples, or scripts that change the outcome, and name the files explicitly before proceeding. ``` **Explanation:** This keeps the skill aligned with progressive disclosure instead of loading the whole copied package by default. ### Example 4: Build a reviewer packet ```text Review @personal-tool-builder using the copied upstream files plus provenance, then summarize any gaps before merge. ``` **Explanation:** This is useful when the PR is waiting for human review and you want a repeatable audit packet. ## Best Practices Treat the generated public skill as a reviewable packaging layer around the upstream repository. The goal is to keep provenance explicit and load only the copied source material that materially improves execution. - Keep the imported skill grounded in the upstream repository; do not invent steps that the source material cannot support. - Prefer the smallest useful set of support files so the workflow stays auditable and fast to review. - Keep provenance, source commit, and imported file paths visible in notes and PR descriptions. - Point directly at the copied upstream files that justify the workflow instead of relying on generic review boilerplate. - Treat generated examples as scaffolding; adapt them to the concrete task before execution. - Route to a stronger native skill when architecture, debugging, design, or security concerns become dominant. ## Troubleshooting ### Problem: The operator skipped the imported context and answered too generically **Symptoms:** The result ignores the upstream workflow in `plugins/antigravity-awesome-skills-claude/skills/personal-tool-builder`, fails to mention provenance, or does not use any copied source files at all. **Solution:** Re-open `metadata.json`, `ORIGIN.md`, and the most relevant copied upstream files. Check the `external_source` block first, then restate the provenance before continuing. ### Problem: The imported workflow feels incomplete during review **Symptoms:** Reviewers can see the generated `SKILL.md`, but they cannot quickly tell which references, examples, or scripts matter for the current task. **Solution:** Point at the exact copied references, examples, scripts, or assets that justify the path you took. If the gap is still real, record it in the PR instead of hiding it. ### Problem: The task drifted into a different specialization **Symptoms:** The imported skill starts in the right place, but the work turns into debugging, architecture, design, security, or release orchestration that a native skill handles better. **Solution:** Use the related skills section to hand off deliberately. Keep the imported provenance visible so the next skill inherits the right context instead of starting blind. ## Related Skills - `@00-andruia-consultant` - Use when the work is better handled by that native specialization after this imported skill establishes context. - `@00-andruia-consultant-v2` - Use when the work is better handled by that native specialization after this imported skill establishes context. - `@10-andruia-skill-smith` - Use when the work is better handled by that native specialization after this imported skill establishes context. - `@10-andruia-skill-smith-v2` - Use when the work is better handled by that native specialization after this imported skill establishes context. ## Additional Resources Use this support matrix and the linked files below as the operator packet for this imported skill. They should reflect real copied source material, not generic scaffolding. | Resource family | What it gives the reviewer | Example path | | --- | --- | --- | | `references` | copied reference notes, guides, or background material from upstream | `references/n/a` | | `examples` | worked examples or reusable prompts copied from upstream | `examples/n/a` | | `scripts` | upstream helper scripts that change execution or validation | `scripts/n/a` | | `agents` | routing or delegation notes that are genuinely part of the imported package | `agents/n/a` | | `assets` | supporting assets or schemas copied from the source package | `assets/n/a` | ### Imported Reference Notes #### Imported: Patterns ### Scratch Your Own Itch Building from personal pain points **When to use**: When starting any personal tool #### Imported: CLI Tool Stack ### Node.js CLI Stack ```javascript // package.json { "name": "my-tool", "version": "1.0.0", "bin": { "mytool": "./bin/cli.js" }, "dependencies": { "commander": "^12.0.0", // Argument parsing "chalk": "^5.3.0", // Colors "ora": "^8.0.0", // Spinners "inquirer": "^9.2.0", // Interactive prompts "conf": "^12.0.0" // Config storage } } // bin/cli.js #!/usr/bin/env node import { Command } from 'commander'; import chalk from 'chalk'; const program = new Command(); program .name('mytool') .description('What it does in one line') .version('1.0.0'); program .command('do-thing') .description('Does the thing') .option('-v, --verbose', 'Verbose output') .action(async (options) => { // Your logic here }); program.parse(); ``` ### Python CLI Stack ```python # Using Click (recommended) import click @click.group() def cli(): """Tool description.""" pass @cli.command() @click.option('--name', '-n', required=True) @click.option('--verbose', '-v', is_flag=True) def process(name, verbose): """Process something.""" click.echo(f'Processing {name}') if __name__ == '__main__': cli() ``` ### Distribution | Method | Complexity | Reach | |--------|------------|-------| | npm publish | Low | Node devs | | pip install | Low | Python devs | | Homebrew tap | Medium | Mac users | | Binary release | Medium | Everyone | | Docker image | Medium | Tech users | ### Local-First Apps Apps that work offline and own your data **When to use**: When building personal productivity apps #### Imported: Local-First Architecture ### Why Local-First for Personal Tools ``` Benefits: - Works offline - Your data stays yours - No server costs - Instant, no latency - Works forever (no shutdown) Trade-offs: - Sync is hard - No collaboration (initially) - Platform-specific work ``` ### Stack Options | Stack | Best For | Complexity | |-------|----------|------------| | Electron + SQLite | Desktop apps | Medium | | Tauri + SQLite | Lightweight desktop | Medium | | Browser + IndexedDB | Web apps | Low | | PWA + OPFS | Mobile-friendly | Low | | CLI + JSON files | Scripts | Very Low | ### Simple Local Storage ```javascript // For simple tools: JSON file storage import { readFileSync, writeFileSync, existsSync } from 'fs'; import { homedir } from 'os'; import { join } from 'path'; const DATA_DIR = join(homedir(), '.mytool'); const DATA_FILE = join(DATA_DIR, 'data.json'); function loadData() { if (!existsSync(DATA_FILE)) return { items: [] }; return JSON.parse(readFileSync(DATA_FILE, 'utf8')); } function saveData(data) { if (!existsSync(DATA_DIR)) mkdirSync(DATA_DIR); writeFileSync(DATA_FILE, JSON.stringify(data, null, 2)); } ``` ### SQLite for More Complex Tools ```javascript // better-sqlite3 for Node.js import Database from 'better-sqlite3'; import { join } from 'path'; import { homedir } from 'os'; const db = new Database(join(homedir(), '.mytool', 'data.db')); // Create tables on first run db.exec(` CREATE TABLE IF NOT EXISTS items ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, created_at DATETIME DEFAULT CURRENT_TIMESTAMP ) `); // Fast synchronous queries const items = db.prepare('SELECT * FROM items').all(); ``` ### Script to Product Evolution Growing a script into a real product **When to use**: When a personal tool shows promise #### Imported: Evolution Path ### Stage 1: Personal Script ``` Characteristics: - Only you use it - Hardcoded values - No error handling - Works on your machine Time: Hours to days ``` ### Stage 2: Shareable Tool ``` Add: - README explaining what it does - Basic error messages - Config file instead of hardcoding - Works on similar machines Time: Days ``` ### Stage 3: Public Tool ``` Add: - Installation instructions - Cross-platform support - Proper error handling - Version numbers - Basic tests Time: Week or two ``` ### Stage 4: Product ``` Add: - Landing page - Documentation site - User support channel - Analytics (privacy-respecting) - Payment integration (if monetizing) Time: Weeks to months ``` ### Signs You Should Productize | Signal | Strength | |--------|----------| | Others asking for it | Strong | | You use it daily | Strong | | Solves $100+ problem | Strong | | Others would pay | Very strong | | Competition exists but sucks | Strong | | You're embarrassed by it | Actually good | #### Imported: Sharp Edges ### Tool only works in your specific environment Severity: MEDIUM Situation: Script fails when you try to share it Symptoms: - Works on my machine - Scripts failing for others - Path not found errors - Command not found errors Why this breaks: Hardcoded absolute paths. Relies on your installed tools. Assumes your OS/shell. Uses your auth tokens. Recommended fix: #### Imported: Making Tools Portable ### Common Portability Issues | Issue | Fix | |-------|-----| | Hardcoded paths | Use ~ or env vars | | Specific shell | Declare shell in shebang | | Missing deps | Check and prompt to install | | Auth tokens | Use config file or env | | OS-specific | Test on other OS or use cross-platform libs | ### Path Portability ```javascript // Bad const dataFile = '~/data.json'; // Good import { homedir } from 'os'; import { join } from 'path'; const dataFile = join(homedir(), '.mytool', 'data.json'); ``` ### Dependency Checking ```javascript import { execSync } from 'child_process'; function checkDep(cmd, installHint) { try { execSync(`which ${cmd}`, { stdio: 'ignore' }); } catch { console.error(`Missing: ${cmd}`); console.error(`Install: ${installHint}`); process.exit(1); } } checkDep('ffmpeg', 'brew install ffmpeg'); ``` ### Cross-Platform Considerations ```javascript import { platform } from 'os'; const isWindows = platform() === 'win32'; const isMac = platform() === 'darwin'; const isLinux = platform() === 'linux'; // Path separator import { sep } from 'path'; // Use sep instead of hardcoded / or \ ``` ### Configuration becomes unmanageable Severity: MEDIUM Situation: Too many config options making the tool unusable Symptoms: - Config file is huge - Users confused by options - You forget what options exist - Every bug fix adds a flag Why this breaks: Adding options instead of opinions. Fear of making decisions. Every edge case becomes an option. Config file larger than the tool. Recommended fix: #### Imported: Taming Configuration ### The Config Hierarchy ``` Best to worst: 1. Smart defaults (no config needed) 2. Single config file 3. Environment variables 4. Command-line flags 5. Interactive prompts Use sparingly: 6. Config directory with multiple files 7. Config inheritance/merging ``` ### Opinionated Defaults ```javascript // Instead of 10 options, pick reasonable defaults const defaults = { outputDir: join(homedir(), '.mytool', 'output'), format: 'json', // Not a flag, just pick one maxItems: 100, // Good enough for most verbose: false }; // Only expose what REALLY needs customization // "Would I want to change this?" - not "Could someone?" ``` ### Config File Pattern ```javascript // ~/.mytool/config.json // Keep it minimal { "apiKey": "xxx", // Actually needed "defaultProject": "main" // Convenience } // Don't do this: { "outputFormat": "json", "outputIndent": 2, "outputColorize": true, "logLevel": "info", "logFormat": "pretty", "logTimestamp": true, // ... 50 more options } ``` ### When to Add Options | Add option if... | Don't add if... | |------------------|-----------------| | Users ask repeatedly | You imagine someone might want | | Security/auth related | It's a "nice to have" | | Fundamental behavior change | It's a micro-preference | | Environment-specific | You can pick a good default | ### Personal tool becomes unmaintained Severity: LOW Situation: Tool you built is now broken and you don't want to fix it Symptoms: - Script hasn't run in months - Don't remember how it works - Dependencies outdated - Workflow has changed Why this breaks: Built for old workflow. Dependencies broke. Lost interest. No documentation for yourself. Recommended fix: #### Imported: Sustainable Personal Tools ### Design for Abandonment ``` Assume future-you won't remember: - Why you built this - How it works - Where the data is - What the dependencies do Build accordingly: - README with WHY, not just WHAT - Simple architecture - Minimal dependencies - Data in standard formats ``` ### Minimal Dependency Strategy | Approach | When to Use | |----------|-------------| | Zero deps | Simple scripts | | Core deps only | CLI tools | | Lock versions | Important tools | | Bundle deps | Distribution | ### Self-Documenting Pattern ```javascript #!/usr/bin/env node /** * WHAT: Converts X to Y * WHY: Because Z process was manual * WHERE: Data in ~/.mytool/ * DEPS: Needs ffmpeg installed * * Last used: 2024-01 * Still works as of: 2024-01 */ // Tool code here ``` ### Graceful Degradation ```javascript // When things break, fail helpfully try { await runMainFeature(); } catch (err) { console.error('Tool broken. Error:', err.message); console.error(''); console.error('Data location: ~/.mytool/data.json'); console.error('You can manually access your data there.'); process.exit(1); } ``` ### When to Let Go ``` Signs to abandon: - Haven't used in 6+ months - Problem no longer exists - Better tool now exists - Would rebuild differently How to abandon gracefully: - Archive in clear state - Note why abandoned - Export data to standard format - Don't delete (might want later) ``` ### Personal tools with security vulnerabilities Severity: HIGH Situation: Your personal tool exposes sensitive data or access Symptoms: - API keys in source code - Tool accessible on network - Credentials in git history - Personal data exposed Why this breaks: "It's just for me" mentality. Credentials in code. No input validation. Accidental exposure. Recommended fix: #### Imported: Security in Personal Tools ### Common Mistakes | Risk | Mitigation | |------|------------| | API keys in code | Use env vars or config file | | Tool exposed on network | Bind to localhost only | | No input validation | Validate even your own input | | Logs contain secrets | Sanitize logging | | Git commits with secrets | .gitignore config files | ### Credential Management ```javascript // Never in code const API_KEY = 'sk-xxx'; // BAD // Environment variable const API_KEY = process.env.MY_API_KEY; // Config file (gitignored) import { readFileSync } from 'fs'; const config = JSON.parse( readFileSync(join(homedir(), '.mytool', 'config.json')) ); const API_KEY = config.apiKey; ``` ### Localhost-Only Servers ```javascript // If your tool has a web UI import express from 'express'; const app = express(); // ALWAYS bind to localhost for personal tools app.listen(3000, '127.0.0.1', () => { console.log('Running on http://localhost:3000'); }); // NEVER do this for personal tools: // app.listen(3000, '0.0.0.0') // Exposes to network! ``` ### Before Sharing ``` Checklist: [ ] No hardcoded credentials [ ] Config file is gitignored [ ] README mentions credential setup [ ] No personal paths in code [ ] No sensitive data in repo [ ] Reviewed git history for secrets ``` #### Imported: Validation Checks ### Hardcoded Absolute Paths Severity: MEDIUM Message: Hardcoded absolute path - use homedir() or environment variables. Fix action: Use os.homedir() or path.join for portable paths ### Hardcoded Credentials Severity: CRITICAL Message: Potential hardcoded credential - use environment variables or config file. Fix action: Move to process.env.VAR or external config file (gitignored) ### Server Bound to All Interfaces Severity: HIGH Message: Server exposed to network - bind to localhost for personal tools. Fix action: Use '127.0.0.1' or 'localhost' instead of '0.0.0.0' ### Missing Error Handling Severity: MEDIUM Message: Sync operation without error handling - wrap in try/catch. Fix action: Add try/catch for graceful error messages ### CLI Without Help Severity: LOW Message: CLI has no help - future you will forget how to use it. Fix action: Add .description() and --help to CLI commands ### Tool Without README Severity: LOW Message: No README - document for your future self. Fix action: Add README with: what it does, why you built it, how to use it ### Debug Console Logs Left In Severity: LOW Message: Debug logging left in code - remove or use proper logging. Fix action: Remove debug logs or use a proper logger with levels ### Script Missing Shebang Severity: LOW Message: Script missing shebang - won't execute directly. Fix action: Add #!/usr/bin/env node (or python3) at top of file ### Tool Without Version Severity: LOW Message: No version tracking - will cause confusion when updating. Fix action: Add version to package.json and --version flag #### Imported: Collaboration ### Delegation Triggers - sell|monetize|SaaS|charge -> micro-saas-launcher (Productizing personal tool) - browser extension|chrome extension -> browser-extension-builder (Building browser-based tool) - automate|workflow|cron|trigger -> workflow-automation (Automation setup) - API|server|database|postgres -> backend (Backend infrastructure) - telegram bot -> telegram-bot-builder (Telegram-based tool) - AI|GPT|Claude|LLM -> ai-wrapper-product (AI-powered tool) ### CLI Tool That Becomes Product Skills: personal-tool-builder, micro-saas-launcher Workflow: ``` 1. Build CLI for yourself 2. Share with friends/colleagues 3. Get feedback and iterate 4. Add web UI (optional) 5. Set up payments 6. Launch publicly ``` ### Personal Automation Stack Skills: personal-tool-builder, workflow-automation, backend Workflow: ``` 1. Identify repetitive task 2. Build script to automate 3. Add triggers (cron, webhook) 4. Store results/logs 5. Monitor and iterate ``` ### AI-Powered Personal Tool Skills: personal-tool-builder, ai-wrapper-product Workflow: ``` 1. Identify task AI can help with 2. Build minimal wrapper 3. Tune prompts for your use case 4. Add to daily workflow 5. Consider sharing if useful ``` ### Browser Tool to Extension Skills: personal-tool-builder, browser-extension-builder Workflow: ``` 1. Build bookmarklet or userscript 2. Validate it solves the problem 3. Convert to proper extension 4. Add to Chrome/Firefox store 5. Share with others ``` #### Imported: Limitations - Use this skill only when the task clearly matches the scope described above. - Do not treat the output as a substitute for environment-specific validation, testing, or expert review. - Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.