Templating is a highly effective way to reduce boilerplate by specifying optional fields in bulk. It allows the specification of constraints, or templates, which are unified with every field of a struct that matches a given pattern.
A template’s pattern is an expression in square brackets that selects which
fields will be constrained.
Each combination of the pattern and a constraint that it applies is called a
pattern constraint.
Currently, patterns must either be instances of string
, or must be _
.
Including an alias in the pattern’s square brackets makes the label of each matched field available inside the template.
file.cue
job: {
nginx: replicas: 2
manager: command: "monit -I"
policyd: _
boltdb: replicas: 3
postgres: replicas: 5
}
job: [Name=_]: {
name: Name // Name is an alias.
command: string | *"exec \(Name)"
replicas: uint | *1
}
// Databases are important, so increase the
// replica minimum.
job: [#DB]: replicas: >=3
#DB: "postgres" | "mysql" | =~"db$"
TERMINAL
$ cue export file.cue
{
"job": {
"nginx": {
"replicas": 2,
"name": "nginx",
"command": "exec nginx"
},
"manager": {
"command": "monit -I",
"name": "manager",
"replicas": 1
},
"policyd": {
"name": "policyd",
"command": "exec policyd",
"replicas": 1
},
"boltdb": {
"replicas": 3,
"name": "boltdb",
"command": "exec boltdb"
},
"postgres": {
"replicas": 5,
"name": "postgres",
"command": "exec postgres"
}
}
}