opencode/skills/software-architect/SKILL.md
Pragmatic software architecture guidance focused on constraints, trade-offs, and simple, secure, reliable designs.
npx skillsauth add mbuyco/dotfiles software-architectInstall 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 turns the agent into a pragmatic software architect who designs systems to solve real business problems with clear constraints, explicit trade-offs, and operationally safe defaults.
Input: "Should we use MongoDB or PostgreSQL for a new e-commerce product catalog?"
Output (condensed):
Constraints & assumptions
Trade-offs | Option | Pros | Cons | | :--- | :--- | :--- | | PostgreSQL | Strong consistency, transactions, mature indexing, JSONB flexibility, easier joins/reporting. | Horizontal write scaling takes more work; schema changes need discipline. | | MongoDB | Flexible documents, straightforward horizontal scaling patterns. | Complex relational queries become app-level work; consistency needs careful design. |
Recommendation Use PostgreSQL. It fits the relational edges (inventory/orders) while keeping flexibility via JSONB for catalog attributes, and it reduces long-term operational complexity.
development
# SKILL.md ## Name VimReaper ## Description VimReaper is a dead‑code cleanup skill that systematically scans a codebase to identify and safely remove unused code—dead functions, unreachable blocks, obsolete variables, redundant imports, and leftover comments—while preserving the intended logic and test suite. As its name suggests, VimReaper wields the **vim editor** as its primary scalpel: code removal is performed using vim’s precise ex commands, search patterns, and scripted editing modes, m
development
Test-driven development with red-green-refactor loop. Use when user wants to build features or fix bugs using TDD, mentions "red-green-refactor", wants integration tests, or asks for test-first development.
development
Find deepening opportunities in a codebase, informed by the domain language in CONTEXT.md and the decisions in docs/adr/. Use when the user wants to improve architecture, find refactoring opportunities, consolidate tightly-coupled modules, or make a codebase more testable and AI-navigable.
testing
Interview the user relentlessly about a plan or design until reaching shared understanding, resolving each branch of the decision tree. Use when user wants to stress-test a plan, get grilled on their design, or mentions "grill me".