🔍 Go Linter Configuration OpenClaw Skill - ClawHub
Do you want your AI agent to automate Go Linter Configuration workflows? This free skill from ClawHub helps with cli utilities tasks without building custom tools from scratch.
What this skill does
Configure and troubleshoot golangci-lint for Go projects. Handle import resolution issues, type-checking problems, and optimize configurations for both local and CI environments.
Install
npx clawhub@latest install go-linter-configurationFull SKILL.md
Open original| name | description |
|---|---|
| go-linter-configuration | Configure and troubleshoot golangci-lint for Go projects. Handle import resolution issues, type-checking problems, and optimize configurations for both local and CI environments. |
Go Linter Configuration Skill
Configure and troubleshoot golangci-lint for Go projects. This skill helps handle import resolution issues, type-checking problems, and optimize configurations for both local and CI environments.
Installation
Install golangci-lint:
go install github.com/golangci/golangci-lint/cmd/golangci-lint@latest
Or use the official installation script:
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.59.1
Basic Usage
Run linter on entire project:
golangci-lint run ./...
Run with specific configuration:
golangci-lint run --config .golangci.yml ./...
Configuration File (.golangci.yml)
Minimal Configuration (for CI environments with import issues)
run:
timeout: 5m
tests: false
build-tags: []
linters:
disable-all: true
enable:
- gofmt # Format checking only
linters-settings:
gofmt:
simplify: true
issues:
exclude-use-default: false
max-issues-per-linter: 50
max-same-issues: 3
output:
format: tab
Standard Configuration (for local development)
run:
timeout: 5m
tests: true
build-tags: []
linters:
enable:
- gofmt
- govet
- errcheck
- staticcheck
- unused
- gosimple
- ineffassign
linters-settings:
govet:
enable:
- shadow
errcheck:
check-type-assertions: true
staticcheck:
checks: ["all"]
issues:
exclude-use-default: false
max-issues-per-linter: 50
max-same-issues: 3
output:
format: tab
Troubleshooting Common Issues
"undefined: package" Errors
Problem: Linter reports undefined references to imported packages
Solution: Use minimal configuration with disable-all: true and only enable basic linters like gofmt
Import Resolution Problems
Problem: CI environment cannot resolve dependencies properly Solution:
- Ensure go.mod and go.sum are up to date
- Use
go mod downloadbefore running linter in CI - Consider using simpler linters in CI environment
Type-Checking Failures
Problem: Linter fails during type checking phase Solution:
- Temporarily disable complex linters that require type checking
- Use
--fastflag for quicker, less intensive checks - Verify all imports are properly declared
CI/CD Optimization
For GitHub Actions workflow:
name: Code Quality
on:
push:
branches: [ main, master ]
pull_request:
branches: [ main, master ]
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v4
with:
go-version: '1.21'
cache: true
- name: Download dependencies
run: go mod download
- name: Install golangci-lint
run: |
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.59.1
- name: Lint
run: golangci-lint run --config .golangci.yml ./...
Linter Selection Guidelines
- gofmt: For formatting consistency
- govet: For semantic errors
- errcheck: For unchecked errors
- staticcheck: For static analysis
- unused: For dead code detection
- gosimple: For simplification suggestions
- ineffassign: For ineffective assignments
Choose linters based on project needs and CI performance requirements.