prototype

tarafından mattpocock

Bir tasarımı uygulamaya geçmeden önce geliştirmek için atılabilir bir prototip oluşturun. İki dal arasında yönlendirme yapar — durum/iş mantığı soruları için çalıştırılabilir bir terminal uygulaması veya tek bir rotadan değiştirilebilen birkaç radikal farklı UI varyasyonu. Kullanıcı prototip yapmak, bir veri modelini veya durum makinesini doğrulamak, bir UI taslağı oluşturmak, tasarım seçeneklerini keşfetmek istediğinde veya "bunu prototiple", "oynayayım", "birkaç tasarım dene" dediğinde kullanın.

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.

mattpocock tarafından daha fazla skill

grill-me
mattpocock
Kullanıcıyı bir plan veya tasarım hakkında ortak bir anlayışa varılana kadar amansızca sorgulayın, karar ağacının her dalını çözümleyin. Kullanıcı bir planı strese test etmek, tasarımı hakkında sorgulanmak istediğinde veya "grill me" dediğinde kullanın.
researchcommunicationproject-management
grill-with-docs
mattpocock
Mevcut alan modeline karşı planınızı sorgulayan, terminolojiyi netleştiren ve kararlar netleştikçe belgeleri (CONTEXT.md, ADR'ler) anında güncelleyen bir ızgara oturumu. Kullanıcı, projesinin dili ve belgelenmiş kararlarına karşı bir planı teste tabi tutmak istediğinde kullanın.
developmentdocumentresearch
improve-codebase-architecture
mattpocock
Bir kod tabanında derinleşme fırsatlarını bulur; CONTEXT.md dosyasındaki alan diline ve docs/adr/ içindeki kararlara dayanır. Kullanıcı mimariyi iyileştirmek, yeniden düzenleme fırsatları bulmak, sıkı bağlı modülleri birleştirmek veya kod tabanını daha test edilebilir ve yapay zeka tarafından gezilebilir hale getirmek istediğinde kullanılır.
developmentcode-reviewapi
teach
mattpocock
Kullanıcıya bu çalışma alanı içinde yeni bir beceri veya konsept öğret.
communicationproductivity
tdd
mattpocock
Kırmızı-yeşil-yeniden düzenleme döngüsüyle test odaklı geliştirme. Kullanıcı TDD kullanarak özellik geliştirmek veya hata düzeltmek istediğinde, "kırmızı-yeşil-yeniden düzenleme"den bahsettiğinde, entegrasyon testleri istediğinde veya test-ilk geliştirme talep ettiğinde kullanılır.
developmenttesting
to-prd
mattpocock
Mevcut konuşma bağlamını bir PRD'ye dönüştürün ve proje sorun takipçisine yayınlayın. Kullanıcının mevcut bağlamdan bir PRD oluşturmak istediğinde kullanın.
developmentdocumentproject-management
handoff
mattpocock
Mevcut konuşmayı, başka bir agent'ın devralması için bir handoff belgesine sıkıştır.
communicationproject-managementdocument
diagnose
mattpocock
Zor hatalar ve performans gerilemeleri için disiplinli teşhis döngüsü. Tekrarla → küçült → hipotez kur → enstrüman ekle → düzelt → regresyon testi yap. Kullanıcı "bunu teşhis et" / "bunu hata ayıkla" dediğinde, bir hata bildirdiğinde, bir şeyin bozuk/throw atan/başarısız olduğunu söylediğinde veya bir performans gerilemesi tanımladığında kullan.
developmenttestingcode-review