# Bazel support To get [Bazel](https://bazel.build/) working with {fmt} you can copy the files `BUILD.bazel`, `MODULE.bazel`, `WORKSPACE.bazel`, and `.bazelversion` from this folder (`support/bazel`) to the root folder of this project. This way {fmt} gets bazelized and can be used with Bazel (e.g. doing a `bazel build //...` on {fmt}). ## Using {fmt} as a dependency ### Using Bzlmod The [Bazel Central Registry](https://github.com/bazelbuild/bazel-central-registry/tree/main/modules/fmt) provides support for {fmt}. For instance, to use {fmt} add to your `MODULE.bazel` file: ``` bazel_dep(name = "fmt", version = "10.2.1") ``` For a live-at-head approach, you can copy the contents of this repository and move the Bazel-related build files to the root folder of this project as described above and make use of `local_path_override`, e.g.: ``` local_path_override( module_name = "fmt", path = "../third_party/fmt", ) ``` ### WORKSPACE system The following minimal example shows how to use {fmt} as a dependency within a Bazel project, that uses the traditional, repository-focused WORKSPACE system. Note that in the long term Bazel will only support Bzlmod. The following file structure is assumed: ``` example ├── BUILD.bazel ├── main.cpp └── WORKSPACE.bazel ``` *main.cpp*: ```c++ #include "fmt/core.h" int main() { fmt::print("The answer is {}\n", 42); } ``` The expected output of this example is `The answer is 42`. *WORKSPACE.bazel*: ```python load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository") git_repository( name = "fmt", branch = "master", remote = "https://github.com/fmtlib/fmt", patch_cmds = [ "mv support/bazel/.bazelversion .bazelversion", "mv support/bazel/BUILD.bazel BUILD.bazel", "mv support/bazel/WORKSPACE.bazel WORKSPACE.bazel", ], # Windows-related patch commands are only needed in the case MSYS2 is not installed. # More details about the installation process of MSYS2 on Windows systems can be found here: # https://docs.bazel.build/versions/main/install-windows.html#installing-compilers-and-language-runtimes # Even if MSYS2 is installed the Windows related patch commands can still be used. patch_cmds_win = [ "Move-Item -Path support/bazel/.bazelversion -Destination .bazelversion", "Move-Item -Path support/bazel/BUILD.bazel -Destination BUILD.bazel", "Move-Item -Path support/bazel/WORKSPACE.bazel -Destination WORKSPACE.bazel", ], ) ``` In the *WORKSPACE* file, the {fmt} GitHub repository is fetched. Using the attribute `patch_cmds` the files `BUILD.bazel`, `WORKSPACE.bazel`, and `.bazelversion` are moved to the root of the {fmt} repository. This way the {fmt} repository is recognized as a bazelized workspace. *BUILD.bazel*: ```python cc_binary( name = "Demo", srcs = ["main.cpp"], deps = ["@fmt"], ) ``` The *BUILD* file defines a binary named `Demo` that has a dependency to {fmt}. To execute the binary you can run `bazel run //:Demo`.