lang/functions: set functions from cty
The sethaselement, setintersection, and setunion functions are defined in the cty stdlib. Making them available in Terraform will make it easier to work with sets, and complement the currently-Terraform-specific setproduct function. In the long run setproduct should probably move into the cty stdlib too, but since it was submitted as a Terraform function originally we'll leave it here now for simplicity's sake and reorganize later.
This commit is contained in:
parent
edb5f82de1
commit
da51e72cbb
|
@ -81,7 +81,10 @@ func (s *Scope) Functions() map[string]function.Function {
|
||||||
"pow": funcs.PowFunc,
|
"pow": funcs.PowFunc,
|
||||||
"replace": funcs.ReplaceFunc,
|
"replace": funcs.ReplaceFunc,
|
||||||
"rsadecrypt": funcs.RsaDecryptFunc,
|
"rsadecrypt": funcs.RsaDecryptFunc,
|
||||||
|
"sethaselement": stdlib.SetHasElementFunc,
|
||||||
|
"setintersection": stdlib.SetIntersectionFunc,
|
||||||
"setproduct": funcs.SetProductFunc,
|
"setproduct": funcs.SetProductFunc,
|
||||||
|
"setunion": stdlib.SetUnionFunc,
|
||||||
"sha1": funcs.Sha1Func,
|
"sha1": funcs.Sha1Func,
|
||||||
"sha256": funcs.Sha256Func,
|
"sha256": funcs.Sha256Func,
|
||||||
"sha512": funcs.Sha512Func,
|
"sha512": funcs.Sha512Func,
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
---
|
||||||
|
layout: "functions"
|
||||||
|
page_title: "sethaselement - Functions - Configuration Language"
|
||||||
|
sidebar_current: "docs-funcs-collection-sethaselement"
|
||||||
|
description: |-
|
||||||
|
The sethaselement function tests whether a given value is in a given set.
|
||||||
|
---
|
||||||
|
|
||||||
|
# `sethaselement` Function
|
||||||
|
|
||||||
|
The `sethaselement` function tests whether a given value is in a given set.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
sethaselement(set, value)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
|
||||||
|
```
|
||||||
|
> sethaselement(["a", "b"], "b")
|
||||||
|
true
|
||||||
|
> sethaselement(["a", "b"], "c")
|
||||||
|
false
|
||||||
|
```
|
||||||
|
|
||||||
|
## Related Functions
|
||||||
|
|
||||||
|
* [`setintersection`](./setintersection.html) computes the _intersection_ of
|
||||||
|
multiple sets.
|
||||||
|
* [`setproduct`](./setproduct.html) computes the _cartesian product_ of multiple
|
||||||
|
sets.
|
||||||
|
* [`setunion`](./setunion.html) computes the _union_ of
|
||||||
|
multiple sets.
|
|
@ -0,0 +1,40 @@
|
||||||
|
---
|
||||||
|
layout: "functions"
|
||||||
|
page_title: "setintersection - Functions - Configuration Language"
|
||||||
|
sidebar_current: "docs-funcs-collection-setintersection"
|
||||||
|
description: |-
|
||||||
|
The setintersection function takes multiple sets and produces a single set
|
||||||
|
containing only the elements that all of the given sets have in common.
|
||||||
|
---
|
||||||
|
|
||||||
|
# `setintersection` Function
|
||||||
|
|
||||||
|
The `setintersection` function takes multiple sets and produces a single set
|
||||||
|
containing only the elements that all of the given sets have in common.
|
||||||
|
In other words, it computes the
|
||||||
|
[intersection](https://en.wikipedia.org/wiki/Intersection_(set_theory)) of the sets.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
setintersection(sets...)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
|
||||||
|
```
|
||||||
|
> setintersection(["a", "b"], ["b", "c"], ["b", "d"])
|
||||||
|
[
|
||||||
|
"b",
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
The given arguments are converted to sets, so the result is also a set and
|
||||||
|
the ordering of the given elements is not preserved.
|
||||||
|
|
||||||
|
## Related Functions
|
||||||
|
|
||||||
|
* [`sethaselement`](./sethaselement.html) tests whether a given set contains
|
||||||
|
a given element value.
|
||||||
|
* [`setproduct`](./setproduct.html) computes the _cartesian product_ of multiple
|
||||||
|
sets.
|
||||||
|
* [`setunion`](./setunion.html) computes the _union_ of
|
||||||
|
multiple sets.
|
|
@ -113,3 +113,12 @@ elements all have a consistent type:
|
||||||
],
|
],
|
||||||
]
|
]
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Related Functions
|
||||||
|
|
||||||
|
* [`sethaselement`](./sethaselement.html) tests whether a given set contains
|
||||||
|
a given element value.
|
||||||
|
* [`setintersection`](./setintersection.html) computes the _intersection_ of
|
||||||
|
multiple sets.
|
||||||
|
* [`setunion`](./setunion.html) computes the _union_ of multiple
|
||||||
|
sets.
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
---
|
||||||
|
layout: "functions"
|
||||||
|
page_title: "setunion - Functions - Configuration Language"
|
||||||
|
sidebar_current: "docs-funcs-collection-setunion"
|
||||||
|
description: |-
|
||||||
|
The setunion function takes multiple sets and produces a single set
|
||||||
|
containing the elements from all of the given sets.
|
||||||
|
---
|
||||||
|
|
||||||
|
# `setunion` Function
|
||||||
|
|
||||||
|
The `setunion` function takes multiple sets and produces a single set
|
||||||
|
containing the elements from all of the given sets. In other words, it
|
||||||
|
computes the [union](https://en.wikipedia.org/wiki/Union_(set_theory)) of
|
||||||
|
the sets.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
setunion(sets...)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
|
||||||
|
```
|
||||||
|
> setunion(["a", "b"], ["b", "c"], ["d"])
|
||||||
|
[
|
||||||
|
"d",
|
||||||
|
"b",
|
||||||
|
"c",
|
||||||
|
"a",
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
The given arguments are converted to sets, so the result is also a set and
|
||||||
|
the ordering of the given elements is not preserved.
|
||||||
|
|
||||||
|
## Related Functions
|
||||||
|
|
||||||
|
* [`sethaselement`](./sethaselement.html) tests whether a given set contains
|
||||||
|
a given element value.
|
||||||
|
* [`setintersection`](./setintersection.html) computes the _intersection_ of
|
||||||
|
multiple sets.
|
||||||
|
* [`setproduct`](./setproduct.html) computes the _cartesian product_ of multiple
|
||||||
|
sets.
|
|
@ -171,10 +171,22 @@
|
||||||
<a href="/docs/configuration/functions/merge.html">merge</a>
|
<a href="/docs/configuration/functions/merge.html">merge</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li<%= sidebar_current("docs-funcs-collection-sethaselement") %>>
|
||||||
|
<a href="/docs/configuration/functions/sethaselement.html">sethaselement</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
<li<%= sidebar_current("docs-funcs-collection-setintersection") %>>
|
||||||
|
<a href="/docs/configuration/functions/setintersection.html">setintersection</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
<li<%= sidebar_current("docs-funcs-collection-setproduct") %>>
|
<li<%= sidebar_current("docs-funcs-collection-setproduct") %>>
|
||||||
<a href="/docs/configuration/functions/setproduct.html">setproduct</a>
|
<a href="/docs/configuration/functions/setproduct.html">setproduct</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li<%= sidebar_current("docs-funcs-collection-setunion") %>>
|
||||||
|
<a href="/docs/configuration/functions/setunion.html">setunion</a>
|
||||||
|
</li>
|
||||||
|
|
||||||
<li<%= sidebar_current("docs-funcs-collection-slice") %>>
|
<li<%= sidebar_current("docs-funcs-collection-slice") %>>
|
||||||
<a href="/docs/configuration/functions/slice.html">slice</a>
|
<a href="/docs/configuration/functions/slice.html">slice</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
Loading…
Reference in New Issue