go-google-style-decisions
go-google-style-decisions
This skill provides expert guidance on the "Decisions" portion of the Google Go Style Guide. It focuses on the specific choices and trade-offs made to ensure consistency, readability, and maintainability across large Go codebases.
Core Mandates
- Clarity over Conciseness: While Go favors brevity, never sacrifice clarity.
- Consistency is Key: Adhere to established patterns in the codebase.
- Idiomaticity: Follow Go-specific patterns (e.g., error handling, interface usage).
- No Underscores: Avoid underscores in names except in specifically allowed cases (tests, generated code).
Developer Workflow
- Design: Plan APIs following the "Least Mechanism" principle.
- Implement: Write code adhering to the style decisions detailed below.
- Lint: Use
golangci-lintorgo vetto catch common style violations. - Test: Include runnable examples in
_test.gofiles for public APIs. - Review: Ensure changes align with the "Core Principles" of clarity and consistency.
Detailed Guidance
For the complete guide, consult references/decisions.md.
1. Naming Conventions
- Underscores: Do not use underscores in Go names (e.g.,
pkg_nameorvar_name).- Exceptions:
_test.gofiles, generated code, and low-level interop.
- Exceptions:
- Package Names:
- Short, lowercase, single word. No
utilorcommon. - Avoid common variable names (e.g.,
useras a package name ifuseris a common variable).
- Short, lowercase, single word. No
- Receiver Names:
- Short (1-2 letters).
- Consistently used throughout the type's methods.
- Usually an abbreviation of the type (e.g.,
cforClient).
- Constant Names:
- Use
MixedCaps(e.g.,ExportedConst,internalConst). - Do NOT use
ALL_CAPSorkPrefix.
- Use
- Initialisms:
- Maintain consistent casing (e.g.,
HTTPClient,urlPath,XMLParser).
- Maintain consistent casing (e.g.,
- Getters:
- Omit
Getprefix (e.g., useobj.Field()instead ofobj.GetField()). - Use
Getonly if the method is truly "getting" something that isn't a simple field (e.g.,GetURL).
- Omit
- Variable Names:
- Length should be proportional to scope. Short names for small scopes (e.g.,
iin a loop), more descriptive names for larger scopes. - Omit types from names (e.g.,
usersinstead ofuserSlice).
- Length should be proportional to scope. Short names for small scopes (e.g.,
2. Commentary
- Line Length: Aim for ~80 characters. Wrap long comments.
- Doc Comments: Every top-level exported name MUST have a doc comment.
- Must start with the name of the object.
- Must be a complete sentence.
- Examples: Provide
ExampleXxxfunctions in test files to document public APIs.
3. Error Handling
- Error as Last Return: Always return
erroras the final value. - Returning Nil: Return
nilfor the error value on success. - Error Interfaces: Exported functions should return the
errorinterface, not a concrete type. - Error Strings:
- No capitalization (unless proper nouns/acronyms).
- No trailing punctuation.
- Indentation: Handle errors early and return/continue. Keep the "happy path" at the minimal level of indentation.
- No In-band Errors: Do not use special values (like
-1) to signal errors. Use(value, error)or(value, ok).
4. Language Constructs
- Composite Literals: Use them for struct initialization. Always specify field names when the struct is from another package.
- Nil Slices: Prefer
var s []int(nil slice) overs := []int{}(empty slice).- Avoid APIs that distinguish between nil and empty slices.
- Braces:
- Closing braces should align with the opening statement.
- Avoid "cuddling" (e.g.,
if err != nil { ... } else { ... }is fine, but don't over-compact).
- Function Formatting: Keep signatures on one line if possible. If they must wrap, indent the arguments.
5. Panic and Recovery
- Avoid Panic: Do not use
panicfor normal error handling. - Exceptional Only: Use
paniconly for truly unrecoverable states (e.g., internal invariant failure). - Program Termination: Use
log.Exitorlog.Fatal(which callsos.Exit) only inmainorinitfunctions. - MustXYZ: Helper functions that terminate the program on failure should be prefixed with
Must(e.g.,template.Must).
6. Copying
- Structs with Locks: Be extremely careful copying structs that contain
sync.Mutexor other synchronization primitives. - Pointer Receivers: If a type has methods with pointer receivers, avoid copying values of that type.
References
More from metalagman/agent-skills
go-goose
Use this skill to plan, write, or run database migrations with the pressly/goose CLI and Go library (SQL/Go migrations, env vars, provider API, embedded migrations).
27go-uber-style-guide
Use this skill to write, refactor, or review Go code according to the Uber Go Style Guide. It ensures strict adherence to correctness, safety, and idiomatic patterns.
23beads
Use this skill to manage work in Beads (`bd`) 1.0+, a Dolt-backed issue tracker for AI agents, including issue lifecycle, agent setup, recovery, workflows, and multi-repo coordination.
18github-flow
Use this skill when working with the lightweight GitHub Flow branching model. Ideal for projects with continuous deployment where 'main' is always deployable.
17go-senior-developer
Expert senior-level Go guidance for architecture, API-first design/codegen, advanced concurrency, performance tuning, testing/quality, cloud-native 12-factor practices, and Go 1.24+ tooling for large-scale systems.
17go-google-style-guide
Expertise in Go programming according to the Google Go Style Guide. Use when the user needs to write, refactor, or review Go code for clarity, simplicity, and maintainability. This skill ensures adherence to Google's official Go idioms, formatting, and the "Least Mechanism" principle.
16