go-context

Use when working with context.Context in Go — placement in signatures, propagating cancellation and deadlines, and storing values in context vs parameters.…

INSTALLATION
npx skills add https://github.com/cxuu/golang-skills --skill go-context
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

$27

Do not add a Context member to a struct type. Instead, pass ctx as a parameter

to each method that needs it:

// Bad: Context stored in struct

type Worker struct {

    ctx context.Context  // Don't do this

}

// Good: Context passed to methods

type Worker struct{ /* ... */ }

func (w *Worker) Process(ctx context.Context) error {

    // Context explicitly passed — lifetime clear

}

Exception: Methods whose signature must match an interface in the standard

library or a third-party library may need to work around this.

Don't Create Custom Context Types

Do not create custom Context types or use interfaces other than context.Context

in function signatures:

// Bad: Custom context type

type MyContext interface {

    context.Context

    GetUserID() string

}

// Good: Use standard context.Context with value extraction

func Process(ctx context.Context) error {

    userID := GetUserID(ctx)

}

Where to Put Application Data

Consider these options in order of preference:

  • Function parameters — most explicit and type-safe
  • Receiver — for data that belongs to the type
  • Globals — for truly global configuration (use sparingly)
  • Context value — only for request-scoped data

Context values are appropriate for:

  • Request IDs and trace IDs
  • Authentication/authorization info that flows with requests
  • Deadlines and cancellation signals

Context values are not appropriate for:

  • Optional function parameters
  • Data that could be passed explicitly
  • Configuration that doesn't vary per-request

Common Patterns

Read references/PATTERNS.md when deriving contexts (WithTimeout, WithCancel, WithDeadline), checking cancellation in loops or HTTP handlers, using context values with typed keys, or needing the quick reference table.

Deriving Contexts

Always defer cancel() immediately after creating a derived context:

ctx, cancel := context.WithTimeout(ctx, 5*time.Second)

defer cancel()

Checking Cancellation

select {

case <-ctx.Done():

    return ctx.Err()

default:

    // Do work

}

Context Immutability

Contexts are immutable — it's safe to pass the same ctx to multiple

concurrent calls that share the same deadline and cancellation signal.

Related Skills

  • Goroutine coordination: See go-concurrency when using context for goroutine cancellation, select-based timeouts, or errgroup
  • Error handling: See go-error-handling when deciding how to wrap or return ctx.Err() cancellation errors
  • Interface design: See go-interfaces when designing APIs that accept context alongside interfaces
  • Request-scoped logging: See go-logging when injecting loggers into context or adding request IDs to structured log output
BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card