3.1 KiB
layout | page_title |
---|---|
language | Operators - Configuration Language |
Arithmetic and Logical Operators
An operator is a type of expression that transforms or combines one or more other expressions. Operators either combine two values in some way to produce a third result value, or transform a single given value to produce a single result.
Operators that work on two values place an operator symbol between the two
values, similar to mathematical notation: 1 + 2
. Operators that work on
only one value place an operator symbol before that value, like
!true
.
The Terraform language has a set of operators for both arithmetic and logic, which are similar to operators in programming languages such as JavaScript or Ruby.
When multiple operators are used together in an expression, they are evaluated in the following order of operations:
!
,-
(multiplication by-1
)*
,/
,%
+
,-
(subtraction)>
,>=
,<
,<=
==
,!=
&&
||
Parentheses can be used to override the default order of operations. Without
parentheses, higher levels are evaluated first, so 1 + 2 * 3
is interpreted
as 1 + (2 * 3)
and not as (1 + 2) * 3
.
The different operators can be gathered into a few different groups with similar behavior, as described below. Each group of operators expects its given values to be of a particular type. Terraform will attempt to convert values to the required type automatically, or will produce an error message if this automatic conversion is not possible.
Arithmetic Operators
The arithmetic operators all expect number values and produce number values as results:
a + b
returns the result of addinga
andb
together.a - b
returns the result of subtractingb
froma
.a * b
returns the result of multiplyinga
andb
.a / b
returns the result of dividinga
byb
.a % b
returns the remainder of dividinga
byb
. This operator is generally useful only when used with whole numbers.-a
returns the result of multiplyinga
by-1
.
Equality Operators
The equality operators both take two values of any type and produce boolean values as results.
a == b
returnstrue
ifa
andb
both have the same type and the same value, orfalse
otherwise.a != b
is the opposite ofa == b
.
Comparison Operators
The comparison operators all expect number values and produce boolean values as results.
a < b
returnstrue
ifa
is less thanb
, orfalse
otherwise.a <= b
returnstrue
ifa
is less than or equal tob
, orfalse
otherwise.a > b
returnstrue
ifa
is greater thanb
, orfalse
otherwise.a >= b
returnstrue
ifa
is greater than or equal tob
, orfalse
otherwise.
Logical Operators
The logical operators all expect bool values and produce bool values as results.
a || b
returnstrue
if eithera
orb
istrue
, orfalse
if both arefalse
.a && b
returnstrue
if botha
andb
aretrue
, orfalse
if either one isfalse
.!a
returnstrue
ifa
isfalse
, andfalse
ifa
istrue
.