← Back to Skills Marketplace
ivangdavila

Go

by Iván · GitHub ↗ · v1.0.2
linuxdarwinwin32 ✓ Security Clean
1541
Downloads
2
Stars
8
Active Installs
3
Versions
Install in OpenClaw
/install go
Description
Write reliable Go code avoiding goroutine leaks, interface traps, and common concurrency bugs.
README (SKILL.md)

Quick Reference

Topic File
Concurrency patterns concurrency.md
Interface and type system interfaces.md
Slices, maps, strings collections.md
Error handling patterns errors.md

Goroutine Leaks

  • Goroutine blocked on channel with no sender = leak forever—always ensure channel closes or use context
  • Unbuffered channel send blocks until receive—deadlock if receiver never comes
  • for range on channel loops forever until channel closed—sender must close(ch)
  • Context cancellation doesn't stop goroutine automatically—must check ctx.Done() in loop
  • Leaked goroutines accumulate memory and never garbage collect

Channel Traps

  • Sending to nil channel blocks forever—receiving from nil also blocks forever
  • Sending to closed channel panics—closing already closed channel panics
  • Only sender should close channel—receiver closing causes sender panic
  • Buffered channel full = send blocks—size buffer for expected load
  • select with multiple ready cases picks randomly—not first listed

Defer Traps

  • Defer arguments evaluated immediately, not when deferred function runs—defer log(time.Now()) captures now
  • Defer in loop accumulates—defers stack, run at function end not iteration end
  • Defer runs even on panic—good for cleanup, but recover only in deferred function
  • Named return values modifiable in defer—defer func() { err = wrap(err) }() works
  • Defer order is LIFO—last defer runs first

Interface Traps

  • Nil concrete value in interface is not nil interface—var p *MyType; var i interface{} = p; i != nil is true
  • Type assertion on wrong type panics—use comma-ok: v, ok := i.(Type)
  • Empty interface any accepts anything but loses type safety—avoid when possible
  • Interface satisfaction is implicit—no compile error if method signature drifts
  • Pointer receiver doesn't satisfy interface for value type—only *T has the method

Error Handling

  • Errors are values, not exceptions—always check returned error
  • err != nil after every call—unchecked errors are silent bugs
  • errors.Is for wrapped errors—== doesn't work with fmt.Errorf("%w", err)
  • Sentinel errors should be var ErrFoo = errors.New() not recreated
  • Panic for programmer errors only—return error for runtime failures

Slice Traps

  • Slice is reference to array—modifying slice modifies original
  • Append may or may not reallocate—never assume capacity
  • Slicing doesn't copy—a[1:3] shares memory with a
  • Nil slice and empty slice differ—var s []int vs s := []int{}
  • copy() copies min of lengths—doesn't extend destination

Map Traps

  • Reading from nil map returns zero value—writing to nil map panics
  • Map iteration order is random—don't rely on order
  • Maps not safe for concurrent access—use sync.Map or mutex
  • Taking address of map element forbidden—&m[key] doesn't compile
  • Delete from map during iteration is safe—but add may cause issues

String Traps

  • Strings are immutable byte slices—each modification creates new allocation
  • range over string iterates runes, not bytes—index jumps for multi-byte chars
  • len(s) is bytes, not characters—use utf8.RuneCountInString()
  • String comparison is byte-wise—not Unicode normalized
  • Substring shares memory with original—large string keeps memory alive

Struct and Memory

  • Struct fields padded for alignment—field order affects memory size
  • Zero value is valid—var wg sync.WaitGroup works, no constructor needed
  • Copying struct with mutex copies unlocked mutex—always pass pointer
  • Embedding is not inheritance—promoted methods can be shadowed
  • Exported fields start uppercase—lowercase fields invisible outside package

Build Traps

  • go build caches aggressively—use -a flag to force rebuild
  • Unused imports fail compilation—use _ import for side effects only
  • init() runs before main, order by dependency—not file order
  • go:embed paths relative to source file—not working directory
  • Cross-compile: GOOS=linux GOARCH=amd64 go build—easy but test on target
Usage Guidance
This is a documentation-only skill with Go best-practice notes and no hidden installs or network endpoints. The only minor mismatch is the declared required binary (go): it is reasonable for a Go helper but the skill text does not actually instruct running the go tool. If you plan to allow the agent to execute commands on your machine, be aware the agent could still choose to run local binaries (including go) at runtime — review and control the agent's execution permissions. Otherwise, the skill is internally coherent and does not request secrets or external access.
Capability Analysis
Type: OpenClaw Skill Name: go Version: 1.0.2 The skill bundle contains only metadata and documentation files related to Go programming best practices and common pitfalls. There is no executable code, no instructions for the AI agent to perform any actions beyond providing information, no attempts at data exfiltration, persistence, or malicious execution. The content is purely educational and aligns with the stated purpose of helping an agent write reliable Go code.
Capability Assessment
Purpose & Capability
Skill name/description and included docs all describe Go coding guidance. The declared dependency on the go binary is reasonable for a Go helper, but the SKILL.md text itself does not contain runtime steps that invoke the go tool — so the binary requirement is plausible but not strictly used by the provided instructions.
Instruction Scope
SKILL.md and the additional .md files contain static guidance about goroutines, channels, interfaces, errors, collections, and build behaviour. They do not instruct the agent to read arbitrary files, access environment variables, or transmit data to external endpoints.
Install Mechanism
No install spec and no code files are included (instruction-only). Nothing is downloaded or written to disk by the package itself.
Credentials
No environment variables, credentials, or config paths are required. The skill does not request secrets or unrelated service tokens.
Persistence & Privilege
Defaults are used (not always: true). The skill does not request persistent/system-wide changes or elevated privileges in its metadata or instructions.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install go
  3. After installation, invoke the skill by name or use /go
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.2
Initial release
v1.0.1
Initial release
v1.0.0
Initial release
Metadata
Slug go
Version 1.0.2
License
All-time Installs 9
Active Installs 8
Total Versions 3
Frequently Asked Questions

What is Go?

Write reliable Go code avoiding goroutine leaks, interface traps, and common concurrency bugs. It is an AI Agent Skill for Claude Code / OpenClaw, with 1541 downloads so far.

How do I install Go?

Run "/install go" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Go free?

Yes, Go is completely free (open-source). You can download, install and use it at no cost.

Which platforms does Go support?

Go is cross-platform and runs anywhere OpenClaw / Claude Code is available (linux, darwin, win32).

Who created Go?

It is built and maintained by Iván (@ivangdavila); the current version is v1.0.2.

💬 Comments