["Make variable"]: https://docs.bazel.build/versions/master/be/make-variables.html [Bourne shell tokenization]: https://docs.bazel.build/versions/master/be/common-definitions.html#sh-tokenization [Gazelle]: https://github.com/bazelbuild/bazel-gazelle [GoArchive]: /go/providers.rst#GoArchive [GoLibrary]: /go/providers.rst#GoLibrary [GoPath]: /go/providers.rst#GoPath [GoSource]: /go/providers.rst#GoSource [build constraints]: https://golang.org/pkg/go/build/#hdr-Build_Constraints [cc_library deps]: https://docs.bazel.build/versions/master/be/c-cpp.html#cc_library.deps [cgo]: http://golang.org/cmd/cgo/ [config_setting]: https://docs.bazel.build/versions/master/be/general.html#config_setting [data dependencies]: https://docs.bazel.build/versions/master/build-ref.html#data [goarch]: /go/modes.rst#goarch [goos]: /go/modes.rst#goos [mode attributes]: /go/modes.rst#mode-attributes [nogo]: /go/nogo.rst#nogo [pure]: /go/modes.rst#pure [race]: /go/modes.rst#race [msan]: /go/modes.rst#msan [select]: https://docs.bazel.build/versions/master/be/functions.html#select [shard_count]: https://docs.bazel.build/versions/master/be/common-definitions.html#test.shard_count [static]: /go/modes.rst#static [test_arg]: https://docs.bazel.build/versions/master/user-manual.html#flag--test_arg [test_filter]: https://docs.bazel.build/versions/master/user-manual.html#flag--test_filter [test_env]: https://docs.bazel.build/versions/master/user-manual.html#flag--test_env [test_runner_fail_fast]: https://docs.bazel.build/versions/master/command-line-reference.html#flag--test_runner_fail_fast [write a CROSSTOOL file]: https://github.com/bazelbuild/bazel/wiki/Yet-Another-CROSSTOOL-Writing-Tutorial [bazel]: https://pkg.go.dev/github.com/bazelbuild/rules_go/go/tools/bazel?tab=doc [go_library]: #go_library [go_binary]: #go_binary [go_test]: #go_test [go_path]: #go_path [go_source]: #go_source [go_test]: #go_test [Examples]: examples.md#examples [Defines and stamping]: defines_and_stamping.md#defines-and-stamping [Stamping with the workspace status script]: defines_and_stamping.md#stamping-with-the-workspace-status-script [Embedding]: embedding.md#embedding [Cross compilation]: cross_compilation.md#cross-compilation [Platform-specific dependencies]: platform-specific_dependencies.md#platform-specific-dependencies # Core Go rules These are the core go rules, required for basic operation. The intent is that these rules are sufficient to match the capabilities of the normal go tools. ## Additional resources - ["Make variable"] - [Bourne shell tokenization] - [Gazelle] - [GoArchive] - [GoLibrary] - [GoPath] - [GoSource] - [build constraints]: - [cc_library deps] - [cgo] - [config_setting] - [data dependencies] - [goarch] - [goos] - [mode attributes] - [nogo] - [pure] - [race] - [msan] - [select]: - [shard_count] - [static] - [test_arg] - [test_filter] - [test_env] - [test_runner_fail_fast] - [write a CROSSTOOL file] - [bazel] ------------------------------------------------------------------------ Introduction ------------ Three core rules may be used to build most projects: [go_library], [go_binary], and [go_test]. These rules reimplement the low level plumping commands of a normal 'go build' invocation: compiling package's source files to archives, then linking archives into go binary. [go_library] builds a single package. It has a list of source files (specified with `srcs`) and may depend on other packages (with `deps`). Each [go_library] has an `importpath`, which is the name used to import it in Go source files. [go_binary] also builds a single `main` package and links it into an executable. It may embed the content of a [go_library] using the `embed` attribute. Embedded sources are compiled together in the same package. Binaries can be built for alternative platforms and configurations by setting `goos`, `goarch`, and other attributes. [go_test] builds a test executable. Like tests produced by `go test`, this consists of three packages: an internal test package compiled together with the library being tested (specified with `embed`), an external test package compiled separately, and a generated test main package. Here is an example of a Bazel build graph for a project using these core rules:  By instrumenting the lower level go tooling, we can cache smaller, finer artifacts with Bazel and thus, speed up incremental builds. Rules ----- ## go_binary
go_binary(name, basename, cdeps, cgo, clinkopts, copts, cppopts, cxxopts, data, deps, embed,
          embedsrcs, env, gc_goopts, gc_linkopts, goarch, goos, gotags, importpath, linkmode, msan,
          out, pure, race, srcs, static, x_defs)
This builds an executable from a set of source files,
    which must all be in the `main` package. You can run the binary with
    `bazel run`, or you can build it with `bazel build` and run it directly.cgo = True.   | List of labels | optional | [] |
| cgo |  If True, the package may contain [cgo] code, and srcs may contain             C, C++, Objective-C, and Objective-C++ files and non-Go assembly files.             When cgo is enabled, these files will be compiled with the C/C++ toolchain             and included in the package. Note that this attribute does not force cgo             to be enabled. Cgo is enabled for non-cross-compiling builds when a C/C++             toolchain is configured.   | Boolean | optional | False |
| clinkopts |  List of flags to add to the C link command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| copts |  List of flags to add to the C compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| cppopts |  List of flags to add to the C/C++ preprocessor command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| cxxopts |  List of flags to add to the C++ compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| data |  List of files needed by this rule at run-time. This may include data files             needed or other programs that may be executed. The [bazel] package may be             used to locate run files; they may appear in different places depending on the             operating system and environment. See [data dependencies] for more             information on data files.   | List of labels | optional | [] |
| deps |  List of Go libraries this package imports directly.             These may be go_library rules or compatible rules with the [GoLibrary] provider.   | List of labels | optional | [] |
| embed |  List of Go libraries whose sources should be compiled together with this             binary's sources. Labels listed here must name go_library,             go_proto_library, or other compatible targets with the [GoLibrary] and             [GoSource] providers. Embedded libraries must all have the same importpath,             which must match the importpath for this go_binary if one is             specified. At most one embedded library may have cgo = True, and the             embedding binary may not also have cgo = True. See [Embedding] for             more information.   | List of labels | optional | [] |
| embedsrcs |  The list of files that may be embedded into the compiled package using             //go:embed directives. All files must be in the same logical directory             or a subdirectory as source files. All source files containing //go:embed             directives must be in the same logical directory. It's okay to mix static and             generated source files and static and generated embeddable files.   | List of labels | optional | [] |
| env |  Environment variables to set when the binary is executed with bazel run.             The values (but not keys) are subject to             [location expansion](https://docs.bazel.build/versions/main/skylark/macros.html) but not full             [make variable expansion](https://docs.bazel.build/versions/main/be/make-variables.html).   | Dictionary: String -> String | optional | {} |
| gc_goopts |  List of flags to add to the Go compilation command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| gc_linkopts |  List of flags to add to the Go link command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| goarch |  Forces a binary to be cross-compiled for a specific architecture. It's usually             better to control this on the command line with --platforms.pure = off.--platforms.pure = off.on, off, or auto. Not available when cgo is             disabled. In most cases, it's better to control this on the command line with             --@io_bazel_rules_go//go/config:msan. See [mode attributes], specifically             [msan].   | String | optional | "auto" |
| out |  Sets the output filename for the generated executable. When set, go_binary             will write this file without mode-specific directory prefixes, without             linkmode-specific prefixes like "lib", and without platform-specific suffixes             like ".exe". Note that without a mode-specific directory prefix, the             output file (but not its dependencies) will be invalidated in Bazel's cache             when changing configurations.   | String | optional | "" |
| pure |  Controls whether cgo source code and dependencies are compiled and linked,             similar to setting CGO_ENABLED. May be one of on, off,             or auto. If auto, pure mode is enabled when no C/C++             toolchain is configured or when cross-compiling. It's usually better to             control this on the command line with             --@io_bazel_rules_go//go/config:pure. See [mode attributes], specifically             [pure].   | String | optional | "auto" |
| race |  Controls whether code is instrumented for race detection. May be one of             on, off, or auto. Not available when cgo is             disabled. In most cases, it's better to control this on the command line with             --@io_bazel_rules_go//go/config:race. See [mode attributes], specifically             [race].   | String | optional | "auto" |
| srcs |  The list of Go source files that are compiled to create the package.             Only .go and .s files are permitted, unless the cgo             attribute is set, in which case,             .c .cc .cpp .cxx .h .hh .hpp .hxx .inc .m .mm             files are also permitted. Files may be filtered at build time             using Go [build constraints].   | List of labels | optional | [] |
| static |  Controls whether a binary is statically linked. May be one of on,             off, or auto. Not available on all platforms or in all             modes. It's usually better to control this on the command line with             --@io_bazel_rules_go//go/config:static. See [mode attributes],             specifically [static].   | String | optional | "auto" |
| x_defs |  Map of defines to add to the go link command.             See [Defines and stamping] for examples of how to use these.   | Dictionary: String -> String | optional | {} |
## go_cross_binary
go_cross_binary(name, platform, sdk_version, target)This wraps an executable built by `go_binary` to cross compile it for a different platform, and/or compile it using a different version of the golang SDK.
target for.             If unspecified, the target will be compiled with the             same platform as it would've with the original go_binary rule.   | Label | optional | None |
| sdk_version |  The golang SDK version to use for compiling the target.             Supports specifying major, minor, and/or patch versions, eg. "1",             "1.17", or "1.17.1". The first Go SDK provider installed in the             repo's workspace (via go_download_sdk, go_wrap_sdk, etc) that             matches the specified version will be used for compiling the given             target. If unspecified, the target will be compiled with the same             SDK as it would've with the original go_binary rule.             Transitions target by changing the --@io_bazel_rules_go//go/toolchain:sdk_version             build flag to the value provided for sdk_version here.   | String | optional | "" |
| target |  Go binary target to transition to the given platform and/or sdk_version.   | Label | required |  |
## go_library
go_library(name, cdeps, cgo, clinkopts, copts, cppopts, cxxopts, data, deps, embed, embedsrcs,
           gc_goopts, importmap, importpath, importpath_aliases, srcs, x_defs)
This builds a Go library from a set of source files that are all part of
    the same package.cgo = True.   | List of labels | optional | [] |
| cgo |  If True, the package may contain [cgo] code, and srcs may contain C, C++, Objective-C, and Objective-C++ files             and non-Go assembly files. When cgo is enabled, these files will be compiled with the C/C++ toolchain and             included in the package. Note that this attribute does not force cgo to be enabled. Cgo is enabled for             non-cross-compiling builds when a C/C++ toolchain is configured.   | Boolean | optional | False |
| clinkopts |  List of flags to add to the C link command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization]. Only valid if cgo = True.   | List of strings | optional | [] |
| copts |  List of flags to add to the C compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization]. Only valid if cgo = True.   | List of strings | optional | [] |
| cppopts |  List of flags to add to the C/C++ preprocessor command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| cxxopts |  List of flags to add to the C++ compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization]. Only valid if cgo = True.   | List of strings | optional | [] |
| data |  List of files needed by this rule at run-time.             This may include data files needed or other programs that may be executed.             The [bazel] package may be used to locate run files; they may appear in different places             depending on the operating system and environment. See [data dependencies] for more information on data files.   | List of labels | optional | [] |
| deps |  List of Go libraries this package imports directly.             These may be go_library rules or compatible rules with the [GoLibrary] provider.   | List of labels | optional | [] |
| embed |  List of Go libraries whose sources should be compiled together with this package's sources.             Labels listed here must name go_library, go_proto_library, or other compatible targets with             the [GoLibrary] and [GoSource] providers. Embedded libraries must have the same importpath as the embedding library.             At most one embedded library may have cgo = True, and the embedding library may not also have cgo = True.             See [Embedding] for more information.   | List of labels | optional | [] |
| embedsrcs |  The list of files that may be embedded into the compiled package using //go:embed             directives. All files must be in the same logical directory or a subdirectory as source files.             All source files containing //go:embed directives must be in the same logical directory.             It's okay to mix static and generated source files and static and generated embeddable files.   | List of labels | optional | [] |
| gc_goopts |  List of flags to add to the Go compilation command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| importmap |  The actual import path of this library. By default, this is importpath. This is mostly only visible to the compiler and linker,             but it may also be seen in stack traces. This must be unique among packages passed to the linker.             It may be set to something different than importpath to prevent conflicts between multiple packages             with the same path (for example, from different vendor directories).   | String | optional | "" |
| importpath |  The source import path of this library. Other libraries can import this library using this path.             This must either be specified in go_library or inherited from one of the libraries in embed.   | String | optional | "" |
| importpath_aliases |  -   | List of strings | optional | [] |
| srcs |  The list of Go source files that are compiled to create the package.             Only .go and .s files are permitted, unless the cgo attribute is set,             in which case, .c .cc .cpp .cxx .h .hh .hpp .hxx .inc .m .mm files are also permitted.             Files may be filtered at build time using Go [build constraints].   | List of labels | optional | [] |
| x_defs |  Map of defines to add to the go link command. See [Defines and stamping] for examples of how to use these.   | Dictionary: String -> String | optional | {} |
## go_path
go_path(name, data, deps, include_data, include_pkg, include_transitive, mode)`go_path` builds a directory structure that can be used with tools that understand the GOPATH directory layout. This directory structure can be built by zipping, copying, or linking files. `go_path` can depend on one or more Go targets (i.e., [go_library], [go_binary], or [go_test]). It will include packages from those targets, as well as their transitive dependencies. Packages will be in subdirectories named after their `importpath` or `importmap` attributes under a `src/` directory. ### **Attributes** | Name | Description | Type | Mandatory | Default | | :------------- | :------------- | :------------- | :------------- | :------------- | | name | A unique name for this target. | Name | required | | | data | A list of targets producing data files that will be stored next to the
src/ directory. Useful for including things like licenses and readmes.   | List of labels | optional | [] |
| deps |  A list of targets that build Go packages. A directory will be generated from             files in these targets and their transitive dependencies. All targets must             provide [GoArchive] ([go_library], [go_binary], [go_test], and similar             rules have this).importpath attributes will be included in the             generated directory. Synthetic packages (like the main package produced by             [go_test]) and packages with inferred import paths will not be             included. The values of importmap attributes may influence the placement             of packages within the generated directory (for example, in vendor             directories).srcs attributes like .pb.go files. The generated directory will also             contain runfiles found in data attributes.   | List of labels | optional | [] |
| include_data |  When true, data files referenced by libraries, binaries, and tests will be             included in the output directory. Files listed in the data attribute             for this rule will be included regardless of this attribute.   | Boolean | optional | True |
| include_pkg |  When true, a pkg subdirectory containing the compiled libraries will be created in the             generated GOPATH containing compiled libraries.   | Boolean | optional | False |
| include_transitive |  When true, the transitive dependency graph will be included in the generated GOPATH. This is             the default behaviour. When false, only the direct dependencies will be included in the             generated GOPATH.   | Boolean | optional | True |
| mode |  Determines how the generated directory is provided. May be one of:             "archive": The generated directory is packaged as a single .zip file."copy": The generated directory is a single tree artifact. Source files                 are copied into the tree."link": Unmaintained due to correctness issues. Source files                 are symlinked into the tree. All of the symlink files are provided as separate output                 files."copy" mode, when a GoPath is consumed as a set of input             files or run files, Bazel may provide symbolic links instead of regular files.             Any program that consumes these files should dereference links, e.g., if you             run tar, use the --dereference flag.   | String | optional | "copy" |
## go_source
go_source(name, data, deps, embed, gc_goopts, srcs)This declares a set of source files and related dependencies that can be embedded into one of the other rules. This is used as a way of easily declaring a common set of sources re-used in multiple rules.
go_library,             go_proto_library, or other compatible targets with the [GoLibrary] and             [GoSource] providers. Embedded libraries must have the same importpath as             the embedding library. At most one embedded library may have cgo = True,             and the embedding library may not also have cgo = True. See [Embedding]             for more information.   | List of labels | optional | [] |
| gc_goopts |  List of flags to add to the Go compilation command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| srcs |  The list of Go source files that are compiled to create the package.             The following file types are permitted: .go, .c, .s, .S .h.             The files may contain Go-style [build constraints].   | List of labels | optional | [] |
## go_test
go_test(name, cdeps, cgo, clinkopts, copts, cppopts, cxxopts, data, deps, embed, embedsrcs, env,
        env_inherit, gc_goopts, gc_linkopts, goarch, goos, gotags, importpath, linkmode, msan, pure,
        race, rundir, srcs, static, x_defs)
This builds a set of tests that can be run with `bazel test`.cgo = True.   | List of labels | optional | [] |
| cgo |  If True, the package may contain [cgo] code, and srcs may contain             C, C++, Objective-C, and Objective-C++ files and non-Go assembly files.             When cgo is enabled, these files will be compiled with the C/C++ toolchain             and included in the package. Note that this attribute does not force cgo             to be enabled. Cgo is enabled for non-cross-compiling builds when a C/C++             toolchain is configured.   | Boolean | optional | False |
| clinkopts |  List of flags to add to the C link command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| copts |  List of flags to add to the C compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| cppopts |  List of flags to add to the C/C++ preprocessor command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| cxxopts |  List of flags to add to the C++ compilation command.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].             Only valid if cgo = True.   | List of strings | optional | [] |
| data |  List of files needed by this rule at run-time. This may include data files             needed or other programs that may be executed. The [bazel] package may be             used to locate run files; they may appear in different places depending on the             operating system and environment. See [data dependencies] for more             information on data files.   | List of labels | optional | [] |
| deps |  List of Go libraries this test imports directly.             These may be go_library rules or compatible rules with the [GoLibrary] provider.   | List of labels | optional | [] |
| embed |  List of Go libraries whose sources should be compiled together with this             package's sources. Labels listed here must name go_library,             go_proto_library, or other compatible targets with the [GoLibrary] and             [GoSource] providers. Embedded libraries must have the same importpath as             the embedding library. At most one embedded library may have cgo = True,             and the embedding library may not also have cgo = True. See [Embedding]             for more information.   | List of labels | optional | [] |
| embedsrcs |  The list of files that may be embedded into the compiled package using             //go:embed directives. All files must be in the same logical directory             or a subdirectory as source files. All source files containing //go:embed             directives must be in the same logical directory. It's okay to mix static and             generated source files and static and generated embeddable files.   | List of labels | optional | [] |
| env |  Environment variables to set for the test execution.             The values (but not keys) are subject to             [location expansion](https://docs.bazel.build/versions/main/skylark/macros.html) but not full             [make variable expansion](https://docs.bazel.build/versions/main/be/make-variables.html).   | Dictionary: String -> String | optional | {} |
| env_inherit |  Environment variables to inherit from the external environment.   | List of strings | optional | [] |
| gc_goopts |  List of flags to add to the Go compilation command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| gc_linkopts |  List of flags to add to the Go link command when using the gc compiler.             Subject to ["Make variable"] substitution and [Bourne shell tokenization].   | List of strings | optional | [] |
| goarch |  Forces a binary to be cross-compiled for a specific architecture. It's usually             better to control this on the command line with --platforms.pure = off.--platforms.pure = off.on, off, or auto. Not available when cgo is             disabled. In most cases, it's better to control this on the command line with             --@io_bazel_rules_go//go/config:msan. See [mode attributes], specifically             [msan].   | String | optional | "auto" |
| pure |  Controls whether cgo source code and dependencies are compiled and linked,             similar to setting CGO_ENABLED. May be one of on, off,             or auto. If auto, pure mode is enabled when no C/C++             toolchain is configured or when cross-compiling. It's usually better to             control this on the command line with             --@io_bazel_rules_go//go/config:pure. See [mode attributes], specifically             [pure].   | String | optional | "auto" |
| race |  Controls whether code is instrumented for race detection. May be one of             on, off, or auto. Not available when cgo is             disabled. In most cases, it's better to control this on the command line with             --@io_bazel_rules_go//go/config:race. See [mode attributes], specifically             [race].   | String | optional | "auto" |
| rundir |  A directory to cd to before the test is run.             This should be a path relative to the root directory of the             repository in which the test is defined, which can be the main or an             external repository.go test so it is easy to write compatible tests.. makes the test behave the normal way for a bazel             test, except that the working directory is always that of the test's             repository, which is not necessarily the main repository..go and .s files are permitted, unless the cgo             attribute is set, in which case,             .c .cc .cpp .cxx .h .hh .hpp .hxx .inc .m .mm             files are also permitted. Files may be filtered at build time             using Go [build constraints].   | List of labels | optional | [] |
| static |  Controls whether a binary is statically linked. May be one of on,             off, or auto. Not available on all platforms or in all             modes. It's usually better to control this on the command line with             --@io_bazel_rules_go//go/config:static. See [mode attributes],             specifically [static].   | String | optional | "auto" |
| x_defs |  Map of defines to add to the go link command.             See [Defines and stamping] for examples of how to use these.   | Dictionary: String -> String | optional | {} |