← 返回 Skills 市场
Bubbletea Code Review
作者
Kevin Anderson
· GitHub ↗
· v2.3.1
· MIT-0
164
总下载
0
收藏
1
当前安装
2
版本数
在 OpenClaw 中安装
/install 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 charmbrac...
使用说明 (SKILL.md)
BubbleTea Code Review
Hard gates (sequence)
Advance only when each pass condition is objectively true (reduces false positives on tea.Cmd and unsubstantiated blocking claims):
| Gate | Pass condition |
|---|---|
| G1 — Anti–false-positive | You skimmed NOT Issues below or read references/elm-architecture.md before recording a finding about tea.Cmd returns, value receivers on Update, or nested child Update. |
| G2 — Evidence for blocking / suspicious I/O | Each Critical/Major finding names file path + line (or a short quoted snippet) showing the blocking call, huh.Form.Run in the wrong place, or other asserted anti-pattern—not a hypothetical. |
| G3 — Verification | Before publishing review output, you applied beagle-go:review-verification-protocol to each proposed finding. |
Quick Reference
| Issue Type | Reference |
|---|---|
| Elm architecture, tea.Cmd as data | references/elm-architecture.md |
| Model state, message handling | references/model-update.md |
| View rendering, Lipgloss styling | references/view-styling.md |
| Component composition, Huh forms | references/composition.md |
| Bubbles components (list, table, etc.) | references/bubbles-components.md |
CRITICAL: Avoid False Positives
Read 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 |
\x3C-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.Cmdare 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
// 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
// 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
// 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 (prevents false positives)
- Reviewing Update function logic → model-update.md
- Reviewing View function, styling → view-styling.md
- Reviewing component hierarchy → composition.md
- Using Bubbles components → bubbles-components.md
Review Questions
- Is Update() free of blocking I/O? (NOT: "is the cmd helper blocking?")
- Is the model immutable in Update?
- Are Lipgloss styles defined once, not in View?
- Is WindowSizeMsg handled for resizing?
- Are key bindings documented with help.KeyMap?
- Are Bubbles components sized correctly?
安全使用建议
This is an instruction-only code-review helper for BubbleTea/TUI code and appears coherent and low-risk. Before enabling: 1) confirm the agent will only be given access to the repositories you want reviewed (the skill expects to read source files and report file/line locations); 2) note the SKILL.md references a 'beagle-go:review-verification-protocol' but doesn't include its implementation—ask the skill author what that entails if you need to rely on it; 3) run the skill on a non-sensitive or sample repo first to verify output and behavior; and 4) avoid granting the agent access to private credentials or unrelated project roots while running reviews.
功能分析
Type: OpenClaw Skill
Name: bubbletea-code-review
Version: 2.3.1
The skill bundle is a comprehensive tool for reviewing Go code using the BubbleTea TUI framework. It contains detailed instructions (SKILL.md) and reference documentation (references/*.md) designed to help an AI agent identify common anti-patterns like blocking I/O in the UI thread while avoiding false positives related to the Elm architecture. No malicious indicators, data exfiltration attempts, or prompt-injection attacks were found.
能力评估
Purpose & Capability
Name/description (BubbleTea code review) matches the SKILL.md and the included reference docs. There are no unexpected binaries, env vars, or config paths requested — everything requested is appropriate for a static/code-review helper.
Instruction Scope
Runtime instructions are a focused review workflow: read the project's source files, consult bundled reference docs, and produce findings that cite file paths and lines. This scope fits the stated purpose. One minor note: the SKILL.md mandates applying a 'beagle-go:review-verification-protocol' for verification but does not define that protocol in the package; this is a procedural requirement (not a credential or network endpoint) and does not itself demand extra privileges.
Install Mechanism
No install spec and no code files that execute on the host; this instruction-only skill does not pull external artifacts or write to disk, which is the lowest-risk pattern for skills.
Credentials
The skill declares no environment variables, credentials, or config paths. Its guidance asks the agent to read code files (expected for a review) but does not request unrelated secrets or system access.
Persistence & Privilege
always:false and no install behavior that modifies other skills or global agent settings. The skill may be invoked autonomously by the agent (platform default), but it does not request permanent presence or elevated privileges.
如何使用
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install bubbletea-code-review - 安装完成后,直接呼叫该 Skill 的名称或使用
/bubbletea-code-review触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v2.3.1
- Adds a new “Hard gates (sequence)” section, requiring review findings to meet anti–false-positive, evidence, and verification gates.
- Requires citation of specific code evidence (file path, line, or snippet) for critical/major findings.
- Mandates use of the beagle-go:review-verification-protocol before publishing review output.
- Existing guidance and checklists for correct BubbleTea patterns and anti-patterns remain unchanged.
v2.3.0
- 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.
元数据
常见问题
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 charmbrac... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 164 次。
如何安装 Bubbletea Code Review?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install bubbletea-code-review」即可一键安装,无需额外配置。
Bubbletea Code Review 是免费的吗?
是的,Bubbletea Code Review 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
Bubbletea Code Review 支持哪些平台?
Bubbletea Code Review 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 Bubbletea Code Review?
由 Kevin Anderson(@anderskev)开发并维护,当前版本 v2.3.1。
推荐 Skills