Add comprehensive Claude Code setup including: - Custom coding rules (Go, Git, Testing, Security, Patterns) - 24 installed plugins (Voltagent, Workflows, Skills) - Cross-platform installers (bash, PowerShell) - Complete documentation This configuration provides the same powerful development environment across any Claude Code installation. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
40 lines
828 B
Markdown
40 lines
828 B
Markdown
# Go Patterns
|
|
|
|
> This file extends [common/patterns.md](../common/patterns.md) with Go specific content.
|
|
|
|
## Functional Options
|
|
|
|
```go
|
|
type Option func(*Server)
|
|
|
|
func WithPort(port int) Option {
|
|
return func(s *Server) { s.port = port }
|
|
}
|
|
|
|
func NewServer(opts ...Option) *Server {
|
|
s := &Server{port: 8080}
|
|
for _, opt := range opts {
|
|
opt(s)
|
|
}
|
|
return s
|
|
}
|
|
```
|
|
|
|
## Small Interfaces
|
|
|
|
Define interfaces where they are used, not where they are implemented.
|
|
|
|
## Dependency Injection
|
|
|
|
Use constructor functions to inject dependencies:
|
|
|
|
```go
|
|
func NewUserService(repo UserRepository, logger Logger) *UserService {
|
|
return &UserService{repo: repo, logger: logger}
|
|
}
|
|
```
|
|
|
|
## Reference
|
|
|
|
See skill: `golang-patterns` for comprehensive Go patterns including concurrency, error handling, and package organization.
|