prototype

Construye un prototipo desechable para desarrollar un diseño antes de comprometerse con él. Enruta entre dos ramas: una aplicación de terminal ejecutable para preguntas de estado/lógica de negocio, o varias variaciones de interfaz de usuario radicalmente diferentes que se puedan alternar desde una ruta. Úsalo cuando el usuario quiera prototipar, verificar un modelo de datos o máquina de estados, maquetar una interfaz, explorar opciones de diseño, o diga "prototipa esto", "déjame jugar con ello", "prueba algunos diseños".

npx skills add https://github.com/mattpocock/skills --skill prototype

Prototype

A prototype is throwaway code that answers a question. The question decides the shape.

Pick a branch

Identify which question is being answered — from the user's prompt, the surrounding code, or by asking if the user is around:

  • "Does this logic / state model feel right?"LOGIC.md. Build a tiny interactive terminal app that pushes the state machine through cases that are hard to reason about on paper.
  • "What should this look like?"UI.md. Generate several radically different UI variations on a single route, switchable via a URL search param and a floating bottom bar.

The two branches produce very different artifacts — getting this wrong wastes the whole prototype. If the question is genuinely ambiguous and the user isn't reachable, default to whichever branch better matches the surrounding code (a backend module → logic; a page or component → UI) and state the assumption at the top of the prototype.

Rules that apply to both

  1. Throwaway from day one, and clearly marked as such. Locate the prototype code close to where it will actually be used (next to the module or page it's prototyping for) so context is obvious — but name it so a casual reader can see it's a prototype, not production. For throwaway UI routes, obey whatever routing convention the project already uses; don't invent a new top-level structure.
  2. One command to run. Whatever the project's existing task runner supports — pnpm <name>, python <path>, bun <path>, etc. The user must be able to start it without thinking.
  3. No persistence by default. State lives in memory. Persistence is the thing the prototype is checking, not something it should depend on. If the question explicitly involves a database, hit a scratch DB or a local file with a clear "PROTOTYPE — wipe me" name.
  4. Skip the polish. No tests, no error handling beyond what makes the prototype runnable, no abstractions. The point is to learn something fast and then delete it.
  5. Surface the state. After every action (logic) or on every variant switch (UI), print or render the full relevant state so the user can see what changed.
  6. Delete or absorb when done. When the prototype has answered its question, either delete it or fold the validated decision into the real code — don't leave it rotting in the repo.

When done

The answer is the only thing worth keeping from a prototype. Capture it somewhere durable (commit message, ADR, issue, or a NOTES.md next to the prototype) along with the question it was answering. If the user is around, that capture is a quick conversation; if not, leave the placeholder so they (or you, on the next pass) can fill in the verdict before deleting the prototype.

Más skills de mattpocock

grill-me
mattpocock
Entrevista al usuario sin descanso sobre un plan o diseño hasta alcanzar un entendimiento compartido, resolviendo cada rama del árbol de decisiones. Úsalo cuando el usuario quiera poner a prueba un plan, ser interrogado sobre su diseño, o mencione "grill me".
researchcommunicationproject-management
grill-with-docs
mattpocock
Sesión de parrilla que pone a prueba tu plan contra el modelo de dominio existente, afina la terminología y actualiza la documentación (CONTEXT.md, ADRs) en línea a medida que las decisiones se cristalizan. Úsalo cuando el usuario quiera poner a prueba un plan contra el lenguaje de su proyecto y las decisiones documentadas.
developmentdocumentresearch
improve-codebase-architecture
mattpocock
Encuentra oportunidades de profundización en una base de código, informado por el lenguaje del dominio en CONTEXT.md y las decisiones en docs/adr/. Úsalo cuando el usuario quiera mejorar la arquitectura, encontrar oportunidades de refactorización, consolidar módulos fuertemente acoplados o hacer que una base de código sea más testeable y navegable por IA.
developmentcode-reviewapi
teach
mattpocock
Enseñar al usuario una nueva habilidad o concepto, dentro de este espacio de trabajo.
communicationproductivity
tdd
mattpocock
Desarrollo guiado por pruebas con el ciclo rojo-verde-refactorizar. Úsalo cuando el usuario quiera construir funcionalidades o corregir errores usando TDD, mencione "rojo-verde-refactorizar", quiera pruebas de integración o solicite desarrollo basado en pruebas primero.
developmenttesting
to-prd
mattpocock
Convierte el contexto actual de la conversación en un PRD y publícalo en el rastreador de incidencias del proyecto. Úsalo cuando el usuario quiera crear un PRD a partir del contexto actual.
developmentdocumentproject-management
handoff
mattpocock
Compacta la conversación actual en un documento de handoff para que otro agente lo retome.
communicationproject-managementdocument
diagnose
mattpocock
Bucle de diagnóstico disciplinado para errores difíciles y regresiones de rendimiento. Reproducir → minimizar → hipotetizar → instrumentar → corregir → prueba de regresión. Usar cuando el usuario dice "diagnostica esto" / "depura esto", reporta un error, dice que algo está roto/lanzando una excepción/fallando, o describe una regresión de rendimiento.
developmenttestingcode-review