plugins/languages/golang/skills/core/SKILL.md
Go 1.26 核心开发规范——强制约定、代码格式、Go 1.21-1.26 新特性(range-over-func、slog、generic aliases、Green Tea GC、new(expr)、自引用泛型)、提交前检查清单。编写 Go 代码、设置项目骨架、做代码评审、回答 "Go 应该怎么写" 时触发。
npx skillsauth add lazygophers/ccplugin golang-coreInstall 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.
适用于 Go 1.26(2026-02 发布),向下兼容 1.21+。
| 场景 | Skill |
| --- | --- |
| 错误处理 | golang-error |
| 工具库选型 | golang-libs |
| 命名 | golang-naming |
| 项目结构 | golang-structure |
| 测试 | golang-testing |
| 并发 | golang-concurrency |
| Lint 配置 | golang-lint |
| 工具链 | golang-tooling |
| 数据库 | golang-db |
| HTTP API | golang-api |
if err != nil { return err }。candy、字符串经 stringx、文件经 osx,禁止手写 for 循环遍历做 Map/Filter。log/slog + 内置函数import "log/slog"
slog.Info("user registered", "username", name, "email", email)
m := min(a, b)
M := max(a, b)
clear(mySlice)
clear(myMap)
for i := range 10 { /* 0..9 */ }
mux.HandleFunc("GET /api/users/{id}", getUser)
mux.HandleFunc("POST /api/users", createUser)
// 1.22+ 循环变量每轮新建,无需再 item := item
for _, item := range items {
go func() { handle(item) }()
}
iter 包import "iter"
import "maps"
import "slices"
for k, v := range maps.All(m) { fmt.Println(k, v) }
func (t *Tree[V]) All() iter.Seq2[string, V] {
return func(yield func(string, V) bool) { /* ... */ }
}
tool 指令 + os.Root + testing.B.Looptype Set[T comparable] = map[T]struct{}
// go.mod 中: tool golang.org/x/tools/cmd/stringer
root, _ := os.OpenRoot("/data")
defer root.Close()
f, _ := root.Open("config.json") // 越界拒绝
func BenchmarkFoo(b *testing.B) {
for b.Loop() { foo() }
}
WaitGroup.Go + testing/synctest GAvar wg sync.WaitGroup
wg.Go(func() { doWork() }) // 自动 Add(1)/Done()
wg.Wait()
synctest.Test(t, func(t *testing.T) {
// bubble 内 time 为假时钟,goroutine 全 durably blocked 后 Wait 返回
})
new(expr) + 自引用泛型 + Green Tea GC 默认 + go fix 现代化p := new(42) // *int = 42
q := new(Point{1,2}) // *Point
type Node[T Node[T]] interface {
Children() []T
}
go fix 重写为现代化工具,配合 //go:fix inline 做 API 迁移GOEXPERIMENT=goroutineleakprofile(goroutine 泄漏剖析)、GOEXPERIMENT=simd(向量 SIMD)package mypkg
import (
// 标准库
"context"
"log/slog"
"os"
// 第三方
"github.com/lazygophers/log"
"github.com/lazygophers/utils/candy"
"gorm.io/gorm"
// 项目内
"github.com/your/project/internal/state"
)
const (...)
var (...)
type Foo struct {...}
type Bar interface {...}
func New() *Foo {...}
.go 文件 ≤500 行,推荐 200-400 行。// Foo 表示...。| 模式 | 替代 |
| --- | --- |
| if err != nil { return err } 单行 | 多行 + log.Errorf("err:%v", err) |
| fmt.Errorf("...: %w", err) | 直接 return err,禁止包装 |
| 手写 for _, x := range xs 做 Map/Filter | candy.Map/candy.Filter |
| os.Stat/手写 os.OpenFile + close 检查存在 | osx.IsFile/osx.IsDir |
| sync/atomic 直接用 | go.uber.org/atomic |
| 业务流程用 panic/recover | log.Errorf + return error;初始化用 log.Fatalf |
| Repository 接口 + 依赖注入 | state 包全局变量 |
gofmt -w . + goimports -w . 已跑go vet ./... 无告警golangci-lint run ./... 通过(见 golang-lint)govulncheck ./... 无 HIGHgo test -race -cover ./... 通过fmt.Errorf 包装if errcandy,字符串走 stringxmin/max、for i := range N、slog、WaitGroup.Go)| AI 借口 | 实际应验证 | | --- | --- | | "单行 if err 更简洁" | 是否所有 error 多行 + 日志? | | "fmt.Errorf 加上下文更清晰" | 是否禁止包装、直接 return? | | "for 循环更直观" | 集合操作是否走 candy? | | "Repository 接口更好测试" | 是否用 state 全局? | | "Go 1.18 泛型够用了" | 是否启用 1.23 iter / 1.26 new(expr) 等? | | "导出函数不用注释" | 所有导出 API 是否有名字开头注释? |
tools
--- name: trellisx-workspace description: 维护 `.trellis/task.md` 任务看板 —— trellis 缺的跨任务总览。**一个表格, 一行一个任务**, 列为 id/名称/描述/状态/阶段/进度/worktree (状态/阶段中文显示)。在 task create/start/阶段切换/archive 后**及时更新**对应行; 并**自动清理超 7 天的已完成行**防膨胀。保持看板与 task.json 实时一致。 when_to_use: 维护 / 创建 / 更新 `.trellis/task.md` 任务看板时; task 生命周期任一节点 (create/start/阶段推进/archive) 之后同步看板时; 用户问"当前有哪些任务 / 任务进度 / 任务看板"时。被 trellisx-flow 与 trellisx-apply 注入的流程引用。 user-invocable: true argument-hint: [show|update|sync|cleanup ...] [task id] arguments:
testing
强制以 Trellis task 闭环处理用户指定的请求 (自判新建/并入 → plan→exec→check→finish 全程不跳步)。**仅用户显式主动调用** (/trellisx-flow 或明确要求"强制走 task 处理这个"); **禁止自动 / 被动 / 推断式调用** —— 不要因为某个请求"看起来该建 task"就自动触发本 skill, 那是 apply 注入的 no_task 倾向的职责。
testing
把 强推task + subtask拆分 + worktree隔离 + 闭环收尾 四维度增量注入当前项目 .trellis/ (workflow.md 的 no_task/planning/in_progress 块 + spec 背书文档 + trellis 生命周期 hook worktree 自动化)。强推 task 与闭环为纯 prompt 软约束 (非平台 hook 硬拦截)。**纯增量追加, 绝不替换 trellis 原生文本** (no_task 分类+征同意/check/finish/前缀全保留)。幂等 (marker 包裹)。
development
Claude Code 会话历史整理 — 扫 ~/.claude/projects/**/*.jsonl 全部 session transcripts, 提取学习增量 (用户校正/决策/踩坑/L0 规则) → 全局记忆库 ~/.cortex/.wiki/memory/. 默认 --apply 落盘 (--dry-run opt-in 仅出 JSON plan 预览). 与 cortex-extract (L4-inbox 内部) 互补.