Expression evaluation in Bake
Bake files in the HCL format support expression evaluation, which lets you perform arithmetic operations, conditionally set values, and more.
Arithmetic operations
You can perform arithmetic operations in expressions. The following example shows how to multiply two numbers.
sum = 7*6
target "default" {
args = {
answer = sum
}
}Printing the Bake file with the --print flag shows the evaluated value for
the answer build argument.
$ docker buildx bake --print
{
"target": {
"default": {
"context": ".",
"dockerfile": "Dockerfile",
"args": {
"answer": "42"
}
}
}
}Ternary operators
You can use ternary operators to conditionally register a value.
The following example adds a tag only when a variable is not empty, using the
built-in notequal function.
variable "TAG" {}
target "default" {
context="."
dockerfile="Dockerfile"
tags = [
"my-image:latest",
notequal("",TAG) ? "my-image:${TAG}": ""
]
}In this case, TAG is an empty string, so the resulting build configuration
only contains the hard-coded my-image:latest tag.
$ docker buildx bake --print
{
"target": {
"default": {
"context": ".",
"dockerfile": "Dockerfile",
"tags": ["my-image:latest"]
}
}
}Expressions with variables
You can use expressions with variables to conditionally set values, or to perform arithmetic operations.
The following example uses expressions to set values based on the value of
variables. The v1 build argument is set to "higher" if the variable FOO is
greater than 5, otherwise it is set to "lower". The v2 build argument is set
to "yes" if the IS_FOO variable is true, otherwise it is set to "no".
variable "FOO" {
default = 3
}
variable "IS_FOO" {
default = true
}
target "app" {
args = {
v1 = FOO > 5 ? "higher" : "lower"
v2 = IS_FOO ? "yes" : "no"
}
}Printing the Bake file with the --print flag shows the evaluated values for
the v1 and v2 build arguments.
$ docker buildx bake --print app
{
"group": {
"default": {
"targets": ["app"]
}
},
"target": {
"app": {
"context": ".",
"dockerfile": "Dockerfile",
"args": {
"v1": "lower",
"v2": "yes"
}
}
}
}