fix(lz4): v1.10.0.bcr.1 - restore targets for compatibility (#5922) 1.10.0 included an overly aggressive refactoring of the `BUILD.bazel` file into a single unified `:lz4` target, which was an unintentional breaking change for the following modules: - c-blosc-2 - flann - folly - libarchive - librdkafka - mcap - squashfs-tools when they were dependencies in a build and 1.10.0 was also included (as seen in issue #5899), overriding their specified dependence on earlier versions of LZ4 that including different targets. 1.10.0.bcr.1 reverts the root `BUILD.bazel` file to the exact structure used in 1.9.4.bcr.2. This resolves the visibility errors encountered when building modules that depended on the `@lz4//:lz4`, `@lz4//:lz4_hc` and `@lz4//:lz4_frame` targets. The new multithreading feature in the `programs/` directory is preserved. Apologies for originally overlooking this. Signed-off-by: James Wilson <206078155+daemoninstitute@users.noreply.github.com>
The Bazel Central Registry (BCR) is the default registry for Bazel's external dependency system (“Bzlmod”). This is the GitHub repository backing the contents of the BCR, hosted at https://bcr.bazel.build/. For the website that allows you to search modules and see their versions conveniently, visit https://registry.bazel.build/.
Besides hosting metadata about Bazel-specific libraries (commonly known as “rulesets”), the BCR is also a central host for projects that don't have upstream support for Bazel (most commonly, C/C++ projects).
The BCR is just like a regular Bazel registry, with some extra metadata fields and policy restrictions. You can contribute to the BCR by sending pull requests; see BCR policies and contribution guidelines for more information.
The core infrastructure of the Bazel Central Registry depends on GitHub and Google Cloud. Bazel users who enable Bzlmod (the default since Bazel 8) depend on the BCR by default. While we try to keep the BCR infrastructure simple and reliable, we assume no liability for any damages caused by build failures due to potential BCR infrastructure failures.
If you consider it necessary, you can do the following to avoid depending on the BCR infrastructure while still making use of the information checked into the BCR.
--registry is a flag that can be specified multiple times.--registry flag is specified, the BCR is the only registry Bazel consults.--registry flag is specified, Bazel will consult the specified registries in order, but will not consult the BCR unless the BCR is explicitly specified as a registry. In other words, to use your own registry layered on top of the BCR, use --registry=https://my.own.registry.com/ --registry=https://bcr.bazel.build/../bazel_registry.json. You can run bazel run //tools:print_all_src_urls to get the list of source URLs to mirror for all Bazel modules checked into the BCR. For example, https://foo.com/bar.zip should be mirrored to https://<your mirror>/foo.com/bar.zip.