This repository has been archived by the owner on Sep 30, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy pathstamp_tags.bzl
39 lines (32 loc) · 1.65 KB
/
stamp_tags.bzl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
"Helper for stamping version control info into the tag"
load("@aspect_bazel_lib//lib:jq.bzl", "jq")
load("@bazel_skylib//lib:types.bzl", "types")
def stamp_tags(name, remote_tags, **kwargs):
"""Wrapper macro around the [jq](https://docs.aspect.build/rules/aspect_bazel_lib/docs/jq) rule.
Produces a text file that can be used with the `remote_tags` attribute of [`oci_push`](#oci_push).
Each entry in `remote_tags` is typically either a constant like `my-repo:latest`, or can contain a stamp expression.
The latter can use any key from `bazel-out/stable-status.txt` or `bazel-out/volatile-status.txt`.
See https://docs.aspect.build/rules/aspect_bazel_lib/docs/stamping/ for details.
The jq `//` default operator is useful for returning an alternative value for unstamped builds.
For example, if you use the expression `($stamp.BUILD_EMBED_LABEL // "0.0.0")`, this resolves to
"0.0.0" if stamping is not enabled. When built with `--stamp --embed_label=1.2.3` it will
resolve to `1.2.3`.
Args:
name: name of the resulting jq target.
remote_tags: list of jq expressions which result in a string value, see docs above
**kwargs: additional named parameters to the jq rule.
"""
if not types.is_list(remote_tags):
fail("remote_tags should be a list")
_maybe_quote = lambda x: x if "\"" in x else "\"{}\"".format(x)
jq(
name = name,
srcs = [],
out = "_{}.tags.txt".format(name),
args = ["--raw-output"],
filter = "|".join([
"$ARGS.named.STAMP as $stamp",
",".join([_maybe_quote(t) for t in remote_tags]),
]),
**kwargs
)