ビルド制約とベンダリング
ビルド制約とベンダリングモードは、ビルドプロセスを微調整するために使用できるツールです。 ビルド制約では、パッケージに含めるファイルを決定するルールを定義します。 ベンダリングモードを有効にすると、プロジェクト内に保存されている依存関係パッケージのみを使用してアプリケーションがビルドされるようになります。 このアプローチにより、パッケージに特定のファイルセットを含め、ローカルで変更またはパッチを適用した依存関係を使用できます。
ビルド制約
ビルド制約 (ビルドタグとも呼ばれる) は、パッケージにファイルが含まれる条件を概説する行コメントです。 これらのタグは、オペレーティングシステム、アーキテクチャ、Go バージョン、コンパイラー、cgo サポート、その他のターゲットシステムのニーズなどの要件を指定できます。 以下の例では、このファイルが次の基準を満たすターゲットシステム用であることを宣言しています。
//+build darwin,cgo linuxはビルドタグの古い構文で、Go ではまだ認識されています。 次の 2 つの条件セットを指定します。darwin,cgo:darwinプラットフォーム (macOS) 用にコンパイルするとき、およびcgoが有効なときにビルドに含めます。cgoを使用すると、Go プログラムに C コードを組み込むことができます。linux: Linux プラットフォーム用にコンパイルするときに含めます。
スペースは OR 演算子として機能します。つまり、ファイルは cgo が有効になっている macOS または Linux に含まれる必要があります。
//go:build (darwin && cgo) || linuxは、Go 1.17 で導入されたビルドタグの新しい構文で、より明示的なブール式形式を使用します。(darwin && cgo) || linux: このファイルは、cgo が有効になっている macOS のビルド、または上記の条件と同じ Linux のビルドに含める必要があります。

GoLand は、これらの制約を使用して、検証、解決、シンボル候補の際に無視すべきファイルを判断できます。 ファイルがターゲットシステムの要件を満たさない場合、GoLand が通知を表示します。 例: スクリーンショット上の次の条件は、 「プロジェクトのビルド制約を構成する」手順の設定と競合します。

プロジェクトのビルド制約を構成する
Go の go ビルド コマンドは、 -タグ 引数を通じてカスタムタグの使用を サポートしており、ビルド制約に基づいてファイルを条件付きでコンパイルできます。 これらのタグを使用すると、ビルドプロセスに含めるファイルの条件を指定できます。
Go ソースファイルでは、ファイルの先頭に // +build または //go:build ディレクティブとそれに続くカスタムタグを含むコメントを配置することで、ビルド制約を定義できます。
設定を開き(Ctrl+Alt+S)、 に移動します。
ドロップダウンリストから、ターゲットシステムの期待値を選択します。 カスタムタグがある場合は、 カスタムタグ フィールドで指定します(タグとしてスペースを区切りとして使用します)。
OK をクリックしてください。

Go 実験の使用
Ctrl+Alt+S を押して設定を開き、 に移動します。
いずれかのフィールドに Go Experiments のタグを入力してください:
カスタムタグ :次のフォーマットでタグを入力してください:
goexperiment.rangefunc goexperiment.loopvar。 タグ同士をスペースで区切ってください。実験 :次のフォーマットでタグを入力してください:
rangefunc, loopvar。 タグ同士はコンマで区切ってください。
タグ名は対応するパッケージ内にあります。 たとえば、
iterパッケージにアクセスすると、go:buildタグの直後にタグ名が表示されます。 特にiterパッケージの場合、タグはgoexperiment.rangefuncです。 カスタムタグ フィールドには完全なタグを入力し、 実験 フィールドにはgoexperiment.に続くセグメントのみを入力します。
ビルドタグフィールドの説明
ビルドタグまたは制約の詳細については、 pkg.go.dev でのビルド制約(英語)を参照してください。
フィールド | ビルドタグ | 説明 |
|---|---|---|
オペレーティングシステム |
|
|
アーキテクチャー |
|
|
Go バージョン |
| インストールされている Go のバージョンを示します。 これは、 |
コンパイラー | ランタイムで使用可能なものに基づいて、 | |
CGO サポート |
| cgo が有効 (1) か無効 (0) かを示し、C コードを含めることができるかどうかに影響します。 |
カスタムタグ |
例: 次のスクリーンショットでは、 ![]() | |
実験 |
| オンまたはオフにできる Go ツールチェーン実験のリスト。 主に Go 自体に取り組んでいる開発者向けです。 |
ビルド制約に複数の条件を使用する
ビルド制約の新しい構文が導入されたため、複数の条件を使用する場合の構文の違いを示す次の表を考慮してください。
|
|
|---|---|
//+build darwin,cgo linux
コンマ(論理積として)と空白(論理和として) | //go:build (darwin && cgo) || linux
|
ベンダリング
ベンダリングモードを有効にして、プロジェクト内の vendor ディレクトリに格納されている依存関係パッケージのみを使用してアプリケーションを構築します。 このモードでは、Go コマンドは go.mod の依存関係の説明を無視し、 vendor ディレクトリに依存関係の正しいコピーがあると見なします。 デフォルトでは、Go モジュールを使用すると、 vendor ディレクトリはビルド中に無視されます。
Go 1.14 RC では、自動ベンダリングモードが Go の組み込み機能になりました。 Go 1.14 RC 以降、GoLand でもデフォルトで自動ベンダリングモードが有効化されます。 たとえば、別の言語で使用されている vendor フォルダーを含むモノリポジトリがある場合、プロジェクトごとにベンダリングを無効にすることができます。
ベンダリングサポートを自動的に有効にする チェックボックスを使用して自動ベンダリングを制御できます。 チェックボックスを選択すると、自動ベンダリングが有効になります。 vendor ディレクトリをモジュールに追加すると、IDE はそれを使用します。 ディレクトリを削除すると、GoLand はグローバル Go モジュールキャッシングを使用します。
ベンダリングモードを切り替える
Ctrl+Alt+S を押して設定を開き、 を選択します。
ベンダリングサポートを自動的に有効にする チェックボックスをオフまたは選択して、 OK をクリックします。
