From 9cf6299c010a089a70f710e2fc60a5e1fe939f7a Mon Sep 17 00:00:00 2001 From: Jonathan Matthews Date: Mon, 15 Jan 2024 16:17:38 +0000 Subject: [PATCH] docs/howto: use list.UniqueItems This adds a Commented CUE guide that demonstrates both how to use list.UniqueItems to return a boolean, and how to use the function as a field validator. Field validation is shown operating on source data and on comprehension-generated data which only contains a subset of the source data. The source data was selected to include a field name that evokes Kubernetes configuration ("kind"), as list.UniqueItems has previously been asked about within a Kubernetes context on Slack. *Actual* Kubernetes configuration data would be inappropriate to display, here, even as an example, as doing so would run the risk of the howto guide being seen in some way as authoritative *for Kubernetes+CUE* - which is not currently the intent for any page on cuelang.org. Signed-off-by: Jonathan Matthews Preview-Path: /docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/ Change-Id: Ia956f9cd735d525394c3ee06d65831af4b243652 Dispatch-Trailer: {"type":"trybot","CL":1174648,"patchset":1,"ref":"refs/changes/48/1174648/1","targetBranch":"alpha"} --- .../en.md | 94 +++++++++++++++++++ .../gen_cache.cue | 18 ++++ .../page.cue | 3 + .../index.md | 93 ++++++++++++++++++ 4 files changed, 208 insertions(+) create mode 100644 content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/en.md create mode 100644 content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/gen_cache.cue create mode 100644 content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/page.cue create mode 100644 hugo/content/en/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/index.md diff --git a/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/en.md b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/en.md new file mode 100644 index 000000000..cf5d3ad25 --- /dev/null +++ b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/en.md @@ -0,0 +1,94 @@ +--- +title: Using the builtin function "list.UniqueItems" to enforce complete or partial list item completeness +tags: +- commented cue +authors: +- jpluscplusm +toc_hide: true +--- + +This [Commented CUE]({{< relref "docs/howto#commented-cue-guides" >}}) +demonstrates how to use the builtin function `list.UniqueItems` to enforce that +a list's items are either completely unique (taking all of each item's fields +into account), or that they're partially unique (taking only *some* of each +item's fields into account). + +{{{with code "en" "cc"}}} +#location top bottom + +! exec cue vet +cmp stderr out +-- file.cue -- +package example + +import "list" + +// inline uses list.UniqueItems in its non-validator mode, returning a boolean +// value. Its value will be "true". +inline: list.UniqueItems([1, 2, "3", 4, "five"]) + +// iceCreams is a list of structs representing multiple brands' specific kinds +// (or flavours) of ice cream, along with optional names and prices. +// It is *not* mandatory to declare a list's schema in order to use the list +// with list.UniqueItems. We do so, here, for clarity. +iceCreams: [...{ + brand!: string + kind!: string + name?: string + price?: number +}] + +// Assert that iceCreams contains no duplicate items. +iceCreams: list.UniqueItems + +// Assert that a synthetic list, constructed using a subset of the fields inside +// iceCreams' items, contains no duplicate items. +_flavoursByBrand: list.UniqueItems & [ + for item in iceCreams {{ + brand: item.brand + kind: item.kind + }}, +] + +// Assert that a synthetic list, constructed using a different subset of the +// fields inside iceCreams' items, contains no duplicate items. +_names: list.UniqueItems & [ + for item in iceCreams + if item.name != _|_ {{ + name: item.name + }}, +] + +iceCreams: [{ + brand: "Charlie's Chocs" + kind: "vanilla" + name: "Vanilla Deluxe" + price: 5 +}, { + brand: "Lola's Lollies" + kind: "strawberry" +}, { + brand: "Charlie's Chocs" + kind: "strawberry" + name: "Strawberry Delight" + price: 7.99 +}, { + brand: "Charlie's Chocs" + kind: "vanilla" + name: "Vanilla Treat" + price: 5 +}, { + brand: "Lola's Lollies" + kind: "vanilla" + name: "Vanilla Deluxe" +}] +-- out -- +_flavoursByBrand: invalid value [{brand:"Charlie's Chocs",kind:"vanilla"},{brand:"Lola's Lollies",kind:"strawberry"},{brand:"Charlie's Chocs",kind:"strawberry"},{brand:"Charlie's Chocs",kind:"vanilla"},{brand:"Lola's Lollies",kind:"vanilla"}] (does not satisfy list.UniqueItems): + ./file.cue:25:19 +_names: invalid value [{name:"Vanilla Deluxe"},{name:"Strawberry Delight"},{name:"Vanilla Treat"},{name:"Vanilla Deluxe"}] (does not satisfy list.UniqueItems): + ./file.cue:34:9 +{{{end}}} + +## Related content + +- The [`list`](https://pkg.go.dev/cuelang.org/go/pkg/list) builtin package diff --git a/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/gen_cache.cue b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/gen_cache.cue new file mode 100644 index 000000000..52d313bfc --- /dev/null +++ b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/gen_cache.cue @@ -0,0 +1,18 @@ +package site +{ + content: { + docs: { + howto: { + "use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness": { + page: { + cache: { + code: { + cc: "AmV/cSOME5Y8H5cRt98/Ep9rlidekNbIo+0/1jipAzM=" + } + } + } + } + } + } + } +} diff --git a/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/page.cue b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/page.cue new file mode 100644 index 000000000..bca5c046c --- /dev/null +++ b/content/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/page.cue @@ -0,0 +1,3 @@ +package site + +content: docs: howto: "use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness": {} diff --git a/hugo/content/en/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/index.md b/hugo/content/en/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/index.md new file mode 100644 index 000000000..fe0a5c189 --- /dev/null +++ b/hugo/content/en/docs/howto/use-the-builtin-function-list-uniqueitems-to-enforce-complete-or-partial-list-item-uniqueness/index.md @@ -0,0 +1,93 @@ +--- +title: Using the builtin function "list.UniqueItems" to enforce complete or partial list item completeness +tags: +- commented cue +authors: +- jpluscplusm +toc_hide: true +--- + +This [Commented CUE]({{< relref "docs/howto#commented-cue-guides" >}}) +demonstrates how to use the builtin function `list.UniqueItems` to enforce that +a list's items are either completely unique (taking all of each item's fields +into account), or that they're partially unique (taking only *some* of each +item's fields into account). + +{{< code-tabs >}} +{{< code-tab name="file.cue" language="cue" area="top" >}} +package example + +import "list" + +// inline uses list.UniqueItems in its non-validator mode, returning a boolean +// value. Its value will be "true". +inline: list.UniqueItems([1, 2, "3", 4, "five"]) + +// iceCreams is a list of structs representing multiple brands' specific kinds +// (or flavours) of ice cream, along with optional names and prices. +// It is *not* mandatory to declare a list's schema in order to use the list +// with list.UniqueItems. We do so, here, for clarity. +iceCreams: [...{ + brand!: string + kind!: string + name?: string + price?: number +}] + +// Assert that iceCreams contains no duplicate items. +iceCreams: list.UniqueItems + +// Assert that a synthetic list, constructed using a subset of the fields inside +// iceCreams' items, contains no duplicate items. +_flavoursByBrand: list.UniqueItems & [ + for item in iceCreams {{ + brand: item.brand + kind: item.kind + }}, +] + +// Assert that a synthetic list, constructed using a different subset of the +// fields inside iceCreams' items, contains no duplicate items. +_names: list.UniqueItems & [ + for item in iceCreams + if item.name != _|_ {{ + name: item.name + }}, +] + +iceCreams: [{ + brand: "Charlie's Chocs" + kind: "vanilla" + name: "Vanilla Deluxe" + price: 5 +}, { + brand: "Lola's Lollies" + kind: "strawberry" +}, { + brand: "Charlie's Chocs" + kind: "strawberry" + name: "Strawberry Delight" + price: 7.99 +}, { + brand: "Charlie's Chocs" + kind: "vanilla" + name: "Vanilla Treat" + price: 5 +}, { + brand: "Lola's Lollies" + kind: "vanilla" + name: "Vanilla Deluxe" +}] +{{< /code-tab >}} +{{< code-tab name="TERMINAL" language="" type="terminal" area="bottom" >}} +$ cue vet +_flavoursByBrand: invalid value [{brand:"Charlie's Chocs",kind:"vanilla"},{brand:"Lola's Lollies",kind:"strawberry"},{brand:"Charlie's Chocs",kind:"strawberry"},{brand:"Charlie's Chocs",kind:"vanilla"},{brand:"Lola's Lollies",kind:"vanilla"}] (does not satisfy list.UniqueItems): + ./file.cue:25:19 +_names: invalid value [{name:"Vanilla Deluxe"},{name:"Strawberry Delight"},{name:"Vanilla Treat"},{name:"Vanilla Deluxe"}] (does not satisfy list.UniqueItems): + ./file.cue:34:9 +{{< /code-tab >}} +{{< /code-tabs >}} + +## Related content + +- The [`list`](https://pkg.go.dev/cuelang.org/go/pkg/list) builtin package