返回顶部
b

bubbletea-code-review

Reviews BubbleTea TUI code for proper Elm architecture, model/update/view patterns, and Lipgloss styling. Use when reviewing terminal UI code using charmbracelet/bubbletea.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 2.3.0
安全检测
已通过
94
下载量
0
收藏
概述
安装方式
版本历史

bubbletea-code-review

# BubbleTea Code Review ## Quick Reference | Issue Type | Reference | |------------|-----------| | Elm architecture, tea.Cmd as data | [references/elm-architecture.md](references/elm-architecture.md) | | Model state, message handling | [references/model-update.md](references/model-update.md) | | View rendering, Lipgloss styling | [references/view-styling.md](references/view-styling.md) | | Component composition, Huh forms | [references/composition.md](references/composition.md) | | Bubbles components (list, table, etc.) | [references/bubbles-components.md](references/bubbles-components.md) | ## CRITICAL: Avoid False Positives **Read [elm-architecture.md](references/elm-architecture.md) first!** The most common review mistake is flagging correct patterns as bugs. ### NOT Issues (Do NOT Flag These) | Pattern | Why It's Correct | |---------|------------------| | `return m, m.loadData()` | `tea.Cmd` is returned immediately; runtime executes async | | Value receiver on `Update()` | Standard BubbleTea pattern; model returned by value | | Nested `m.child, cmd = m.child.Update(msg)` | Normal component composition | | Helper functions returning `tea.Cmd` | Creates command descriptor, no I/O in Update | | `tea.Batch(cmd1, cmd2)` | Commands execute concurrently by runtime | ### ACTUAL Issues (DO Flag These) | Pattern | Why It's Wrong | |---------|----------------| | `os.ReadFile()` in Update | Blocks UI thread | | `http.Get()` in Update | Network I/O blocks | | `time.Sleep()` in Update | Freezes UI | | `<-channel` in Update (blocking) | May block indefinitely | | `huh.Form.Run()` in Update | Blocking call | ## Review Checklist ### Architecture - [ ] **No blocking I/O in Update()** (file, network, sleep) - [ ] Helper functions returning `tea.Cmd` are NOT flagged as blocking - [ ] Commands used for all async operations ### Model & Update - [ ] Model is immutable (Update returns new model, not mutates) - [ ] Init returns proper initial command (or nil) - [ ] Update handles all expected message types - [ ] WindowSizeMsg handled for responsive layout - [ ] tea.Batch used for multiple commands - [ ] tea.Quit used correctly for exit ### View & Styling - [ ] View is a pure function (no side effects) - [ ] Lipgloss styles defined once, not in View - [ ] Key bindings use key.Matches with help.KeyMap ### Components - [ ] Sub-component updates propagated correctly - [ ] Bubbles components initialized with dimensions - [ ] Huh forms embedded via Update loop (not Run()) ## Critical Patterns ### Model Must Be Immutable ```go // BAD - mutates model func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { m.items = append(m.items, newItem) // mutation! return m, nil } // GOOD - returns new model func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { newItems := make([]Item, len(m.items)+1) copy(newItems, m.items) newItems[len(m.items)] = newItem m.items = newItems return m, nil } ``` ### Commands for Async/IO ```go // BAD - blocking in Update func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { data, _ := os.ReadFile("config.json") // blocks UI! m.config = parse(data) return m, nil } // GOOD - use commands func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { return m, loadConfigCmd() } func loadConfigCmd() tea.Cmd { return func() tea.Msg { data, err := os.ReadFile("config.json") if err != nil { return errMsg{err} } return configLoadedMsg{parse(data)} } } ``` ### Styles Defined Once ```go // BAD - creates new style each render func (m Model) View() string { style := lipgloss.NewStyle().Bold(true).Foreground(lipgloss.Color("205")) return style.Render("Hello") } // GOOD - define styles at package level or in model var titleStyle = lipgloss.NewStyle().Bold(true).Foreground(lipgloss.Color("205")) func (m Model) View() string { return titleStyle.Render("Hello") } ``` ## When to Load References - **First time reviewing BubbleTea** → [elm-architecture.md](references/elm-architecture.md) (prevents false positives) - Reviewing Update function logic → [model-update.md](references/model-update.md) - Reviewing View function, styling → [view-styling.md](references/view-styling.md) - Reviewing component hierarchy → [composition.md](references/composition.md) - Using Bubbles components → [bubbles-components.md](references/bubbles-components.md) ## Review Questions 1. Is Update() free of blocking I/O? (NOT: "is the cmd helper blocking?") 2. Is the model immutable in Update? 3. Are Lipgloss styles defined once, not in View? 4. Is WindowSizeMsg handled for resizing? 5. Are key bindings documented with help.KeyMap? 6. Are Bubbles components sized correctly?

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 bubbletea-code-review-1776097458 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 bubbletea-code-review-1776097458 技能

通过命令行安装

skillhub install bubbletea-code-review-1776097458

下载 Zip 包

⬇ 下载 bubbletea-code-review v2.3.0

文件大小: 15.9 KB | 发布时间: 2026-4-14 10:31

v2.3.0 最新 2026-4-14 10:31
- Added comprehensive skill documentation (SKILL.md) with patterns, reference links, and a detailed review checklist for BubbleTea TUI code reviews.
- Clarified critical patterns to avoid common false positives when reviewing Elm architecture, model/update/view patterns, and Lipgloss styling.
- Included tables distinguishing correct (NOT issues) and incorrect (DO flag) usage patterns.
- Provided code examples and targeted review questions to assist reviewers in identifying best practices.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部