go-error-handling
エラーを返す・ラップする・処理するGoコードを書く際に使用します。センチネルエラー・カスタム型・`fmt.Errorf`(`%w` vs `%v`)の使い分け、エラーフローの構造化、ログ出力か返却かの判断に対応します。パッケージ境界をまたいだエラー伝播や`errors.Is`/`errors.As`の利用時にも、ユーザーがエラー戦略を明示的に問わない場合でも適用されます。`panic`/`recover`パターンは対象外です(`go-defensive`を参照)。
description の原文を見る
Use when writing Go code that returns, wraps, or handles errors — choosing between sentinel errors, custom types, and fmt.Errorf (%w vs %v), structuring error flow, or deciding whether to log or return. Also use when propagating errors across package boundaries or using errors.Is/As, even if the user doesn't ask about error strategy. Does not cover panic/recover patterns (see go-defensive).
SKILL.md 本文
Go エラーハンドリング
利用可能なスクリプト
scripts/check-errors.sh— エラーハンドリングのアンチパターンを検出します:err.Error()に対する文字列比較、コンテキストなしのreturn err、ログと返却の両立。bash scripts/check-errors.sh --helpでオプションを確認してください。
Go では、エラーは値です — コードによって作成され、コードによって消費されます。
エラー戦略の選択
- システム境界 (RPC、IPC、ストレージ)? →
%vでラップして内部を隠す - 呼び出し元が特定の条件にマッチしている必要がある? → Sentinel またはカスタム型エラー、
%wでラップ - 呼び出し元がデバッグコンテキストだけが必要? →
fmt.Errorf("...: %w", err) - リーフ関数、ラップ不要? → エラーを直接返す
デフォルト: %w でラップし、フォーマット文字列の末尾に配置します。
コアルール
コンクリートなエラー型を返さない
エクスポートされた関数からコンクリートなエラー型を返さないこと — コンクリートな nil ポインタはインターフェース上で非 nil になる可能性があります:
// Bad: コンクリート型は微妙なバグを引き起こす可能性がある
func Bad() *os.PathError { /*...*/ }
// Good: 常にエラーインターフェースを返す
func Good() error { /*...*/ }
エラー文字列
エラー文字列は大文字で始まらないようにし、句読点で終わらないようにします。例外: エクスポートされた名前、固有名詞、または頭字語。
// Bad
err := fmt.Errorf("Something bad happened.")
// Good
err := fmt.Errorf("something bad happened")
表示されるメッセージ (ログ、テスト失敗、API レスポンス) の場合は、大文字化は適切です。
エラー時の返却値
関数がエラーを返す場合、呼び出し元は明示的にドキュメント化されていない限り、すべての非エラー返却値を不定と見なす必要があります。
ヒント: context.Context を受け取る関数は通常 error を返すべきなので、呼び出し元はコンテキストがキャンセルされたかどうかを判定できます。
エラーの処理
エラーに遭遇したときは、意識的に選択してください — _ で破棄しないこと:
- 即座に処理 — エラーに対処して続行
- 呼び出し元に返す — コンテキスト付きでオプショナルにラップ
- 例外的な場合 —
log.Fatalまたはpanic
意図的に無視する場合: なぜかを説明するコメントを追加します。
n, _ := b.Write(p) // nil でない error を返さない
関連する並行操作の場合、errgroup を使用します:
g, ctx := errgroup.WithContext(ctx)
g.Go(func() error { return task1(ctx) })
g.Go(func() error { return task2(ctx) })
if err := g.Wait(); err != nil { return err }
インバンドエラーを回避する
エラーを知らせるために -1、nil、または空文字列を返さないでください。複数の返却値を使用します:
// Bad: インバンドエラー値
func Lookup(key string) int // 見つからない場合は -1 を返す
// Good: 明示的なエラーまたは ok 値
func Lookup(key string) (string, bool)
これにより、呼び出し元が Parse(Lookup(key)) を書くのを防ぎます — Lookup(key) は 2 つの出力を持つため、コンパイル時エラーが発生します。
エラーフロー
通常のコードの前にエラーを処理します。早期のリターンはハッピーパスをインデントなしに保ちます:
// Good: エラーファースト、通常コードはインデントなし
if err != nil {
return err
}
// 通常のコード
エラーを一度だけ処理 — ログするか返すか、両方はしない:
エラーが発生した?
├─ 呼び出し元が対処できる? → 返す (%w でコンテキスト付き)
├─ 呼び出しチェーンの最上部? → ログして処理
└─ どちらでもない? → 適切なレベルでログして続行
複雑なエラーフローを構造化するとき、ログ vs 返却の判断、ハンドル・オンスパターンの実装、または構造化ログレベルの選択については、
references/ERROR-FLOW.mdを読んでください。
エラー型
勧告: 推奨されるベストプラクティス。
| 呼び出し元がマッチする必要がある? | メッセージ型 | 使用 |
|---|---|---|
| いいえ | static | errors.New("message") |
| いいえ | 動的 | fmt.Errorf("msg: %v", val) |
| はい | static | var ErrFoo = errors.New("...") |
| はい | 動的 | カスタム error 型 |
デフォルト: fmt.Errorf("...: %w", err) でラップします。errors.Is() には Sentinel にエスカレート、errors.As() にはカスタム型を使用します。
Sentinel エラーを定義するとき、カスタムエラー型を作成するとき、またはパッケージ API のエラー戦略を選択するときは、
references/ERROR-TYPES.mdを読んでください。
エラーラップ
勧告: 推奨されるベストプラクティス。
%vを使用: システム境界で、ログのために、内部詳細を隠すために%wを使用:errors.Is/errors.Asのためにエラーチェーンを保持するために
重要なルール: %w を末尾に配置します。呼び出し元が持っていないコンテキストを追加します。注釈が何も追加しない場合は、err を直接返します。
%vと%wのどちらを使うか判断するとき、パッケージ境界を越えてエラーをラップするとき、またはコンテキスト情報を追加するときは、references/WRAPPING.mdを読んでください。
検証: エラーハンドリングを実装した後、
bash scripts/check-errors.shを実行して一般的なアンチパターンを検出します。次にgo vet ./...を実行して追加の問題をキャッチします。
関連スキル
- エラー命名: Sentinel エラー (
ErrFoo) またはカスタムエラー型の命名についてはgo-namingを参照してください - エラーテスト:
errors.Is/errors.Asでエラーセマンティクスをテストするときまたはエラーチェックヘルパーを書くときはgo-testingを参照してください - Panic 処理: panic とエラー返却のどちらかを判断するときまたは recover ガードを書くときは
go-defensiveを参照してください - ガード句: 早期リターンエラーフローを構造化するときまたはネストを削減するときは
go-control-flowを参照してください - ログ判断: ログレベルを選択するとき、構造化ログを設定するとき、またはログメッセージに含めるコンテキストを判断するときは
go-loggingを参照してください
ライセンス: Apache-2.0(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- cxuu
- リポジトリ
- cxuu/golang-skills
- ライセンス
- Apache-2.0
- 最終更新
- 不明
Source: https://github.com/cxuu/golang-skills / ライセンス: Apache-2.0
関連スキル
superfluid
Superfluidプロトコルおよびそのエコシステムに関するナレッジベースです。Superfluidについて情報を検索する際は、ウェブ検索の前にこちらを参照してください。対応キーワード:Superfluid、CFA、GDA、Super App、Super Token、stream、flow rate、real-time balance、pool(member/distributor)、IDA、sentinels、liquidation、TOGA、@sfpro/sdk、semantic money、yellowpaper、whitepaper
civ-finish-quotes
実質的なタスクが真に完了した際に、文明風の儀式的な引用句を追加します。ユーザーやエージェントが機能追加、リファクタリング、分析、設計ドキュメント、プロセス改善、レポート、執筆タスクといった実際の成果物を完成させるときに、明示的な依頼がなくても使用します。短い返信や小さな修正、未完成の作業には適用しません。
nookplot
Base(Ethereum L2)上のAIエージェント向け分散型調整ネットワークです。エージェントがオンチェーンアイデンティティを登録する、コンテンツを公開する、他のエージェントにメッセージを送る、マーケットプレイスで専門家を雇う、バウンティを投稿・請求する、レピュテーションを構築する、共有プロジェクトで協業する、リサーチチャレンジを解くことでNOOKをマイニングする、キュレーションされたナレッジを備えたスタンドアロンオンチェーンエージェントをデプロイする、またはアグリーメントとリワードで収益を得る場合に利用できます。エージェントネットワーク、エージェント調整、分散型エージェント、NOOKトークン、マイニングチャレンジ、ナレッジバンドル、エージェントレピュテーション、エージェントマーケットプレイス、ERC-2771メタトランザクション、Prepare-Sign-Relay、AgentFactory、またはNookplotが言及された場合にトリガーされます。
web3-polymarket
Polygon上でのPolymarket予測市場取引統合です。認証機能(L1 EIP-712、L2 HMAC-SHA256、ビルダーヘッダー)、注文発注(GTC/GTD/FOK/FAK、バッチ、ポストオンリー、ハートビート)、市場データ(Gamma API、Data API、オーダーブック、サブグラフ)、WebSocketストリーミング(市場・ユーザー・スポーツチャネル)、CTF操作(分割、統合、償却、ネガティブリスク)、ブリッジ機能(入金、出金、マルチチェーン)、およびガスレスリレイトランザクションに対応しています。AIエージェント、自動マーケットメーカー、予測市場UI、またはPolygraph上のPolymarketと統合するアプリケーション構築時に活用できます。
ethskills
Ethereum、EVM、またはブロックチェーン関連のリクエストに対応します。スマートコントラクト、dApps、ウォレット、DeFiプロトコルの構築、監査、デプロイ、インタラクションに適用されます。Solidityの開発、コントラクトアドレス、トークン規格(ERC-20、ERC-721、ERC-4626など)、Layer 2ネットワーク(Base、Arbitrum、Optimism、zkSync、Polygon)、Uniswap、Aave、Curveなどのプロトコルとの統合をカバーします。ガスコスト、コントラクトのデシマル設定、オラクルセキュリティ、リエントランシー、MEV、ブリッジング、ウォレット管理、オンチェーンデータの取得、本番環境へのデプロイ、プロトコル進化(EIPライフサイクル、フォーク追跡、今後の変更予定)といったトピックを含みます。
xxyy-trade
このスキルは、ユーザーが「トークン購入」「トークン売却」「トークンスワップ」「暗号資産取引」「取引ステータス確認」「トランザクション照会」「トークンスキャン」「フィード」「チェーン監視」「トークン照会」「トークン詳細」「トークン安全性確認」「ウォレット一覧表示」「マイウォレット」「AIスキャン」「自動スキャン」「ツイートスキャン」「オンボーディング」「IP確認」「IPホワイトリスト」「トークン発行」「自動売却」「損切り」「利益確定」「トレーリングストップ」「保有者」「トップホルダー」「KOLホルダー」などをリクエストした場合、またはSolana/ETH/BSC/BaseチェーンでXXYYを経由した取引について言及した場合に使用します。XXYY Open APIを通じてオンチェーン取引とデータ照会を実現します。