| # Copyright 2018 The Bazel Authors. All rights reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http:#www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| """Defines a repository rule that generates an archive consisting of the specified files to fetch""" |
| |
| load("//:distdir_deps.bzl", "DEPS_BY_NAME") |
| load("//tools/build_defs/repo:http.bzl", "http_archive", "http_file") |
| |
| _BUILD = """ |
| load("@rules_pkg//:pkg.bzl", "pkg_tar") |
| |
| pkg_tar( |
| name="archives", |
| srcs = {srcs}, |
| package_dir = "{dirname}", |
| visibility = ["//visibility:public"], |
| ) |
| |
| """ |
| |
| def _distdir_tar_impl(ctx): |
| for name in ctx.attr.archives: |
| ctx.download(ctx.attr.urls[name], name, ctx.attr.sha256[name], False) |
| ctx.file("WORKSPACE", "") |
| ctx.file( |
| "BUILD", |
| _BUILD.format(srcs = ctx.attr.archives, dirname = ctx.attr.dirname), |
| ) |
| |
| _distdir_tar_attrs = { |
| "archives": attr.string_list(), |
| "sha256": attr.string_dict(), |
| "urls": attr.string_list_dict(), |
| "dirname": attr.string(default = "distdir"), |
| } |
| |
| _distdir_tar = repository_rule( |
| implementation = _distdir_tar_impl, |
| attrs = _distdir_tar_attrs, |
| ) |
| |
| def distdir_tar(name, archives, sha256, urls, dirname, dist_deps = None): |
| """Creates a repository whose content is a set of tar files. |
| |
| Args: |
| name: repo name. |
| archives: list of tar file names. |
| sha256: map of tar file names to SHAs. |
| urls: map of tar file names to URL lists. |
| dirname: output directory in repo. |
| dist_deps: map of repo names to dict of archive, sha256, and urls. |
| """ |
| if dist_deps: |
| for dep, info in dist_deps.items(): |
| archive_file = info["archive"] |
| archives.append(archive_file) |
| sha256[archive_file] = info["sha256"] |
| urls[archive_file] = info["urls"] |
| _distdir_tar( |
| name = name, |
| archives = archives, |
| sha256 = sha256, |
| urls = urls, |
| dirname = dirname, |
| ) |
| |
| def dist_http_archive(name, **kwargs): |
| """Wraps http_archive, providing attributes like sha and urls from the central list. |
| |
| dist_http_archive wraps an http_archive invocation, but looks up relevant attributes |
| from distdir_deps.bzl so the user does not have to specify them. |
| |
| Args: |
| name: repo name |
| **kwargs: see http_archive for allowed args. |
| """ |
| info = DEPS_BY_NAME[name] |
| if "patch_args" not in kwargs: |
| kwargs["patch_args"] = info.get("patch_args") |
| if "patches" not in kwargs: |
| kwargs["patches"] = info.get("patches") |
| if "strip_prefix" not in kwargs: |
| kwargs["strip_prefix"] = info.get("strip_prefix") |
| http_archive( |
| name = name, |
| sha256 = info["sha256"], |
| urls = info["urls"], |
| **kwargs |
| ) |
| |
| def dist_http_file(name, **kwargs): |
| """Wraps http_file, providing attributes like sha and urls from the central list. |
| |
| dist_http_file wraps an http_file invocation, but looks up relevant attributes |
| from distdir_deps.bzl so the user does not have to specify them. |
| |
| Args: |
| name: repo name |
| **kwargs: see http_file for allowed args. |
| """ |
| info = DEPS_BY_NAME[name] |
| http_file( |
| name = name, |
| sha256 = info["sha256"], |
| urls = info["urls"], |
| **kwargs |
| ) |