From f8d819573a2ee9fd819728452734a43f523785b7 Mon Sep 17 00:00:00 2001 From: Jonathan Matthews Date: Fri, 30 Aug 2024 16:55:36 +0100 Subject: [PATCH] docs/concept: new FAQ: list arithmetic ops removal This adds an FAQ guide that explains the removal of list arithmetic operators ("+" and "*") from CUE v0.11 and later. It requires the tip of cmd/cue, upgraded in an earlier commit, in order to access a version of `cue fix` that understands how to update the operators. It also updates the /e/v0.11-list-arithmetic redirector's target so that cmd/cue can succinctly link to the FAQ from error messages introduced in https://cuelang.org/cl/1200221. This guide contains several FIXMEs, which are a product of it being written before the first 0.11 pre-release is available. They must be updated and removed before publishing. Several commands are displayed on the preview's rendered page with `missing.file.cue` arguments, in order to prompt a failure where the current cmd/cue tip doesn't yet fail. They must also be updated and removed; probably when the version of cmd/cue installed earlier in this stack includes the as-yet-unmerged https://review.gerrithub.io/c/cue-lang/cue/+/1200221. DO NOT SUBMIT Closes cue-lang/docs-and-content#178 Preview-Path: /docs/concept/faq/removing-list-arithmetic-operators-v0.11/ Signed-off-by: Jonathan Matthews Change-Id: I8d50c273ccedb7cf6ca5295917032d5aa822b413 Dispatch-Trailer: {"type":"trybot","CL":1200357,"patchset":10,"ref":"refs/changes/57/1200357/10","targetBranch":"master"} --- .../en.md | 318 ++++++++++++++++++ .../gen_cache.cue | 108 ++++++ .../page.cue | 3 + .../index.md | 313 +++++++++++++++++ hugo/layouts/index.redir | 2 +- internal/ci/netlify/netlify.cue | 2 +- 6 files changed, 744 insertions(+), 2 deletions(-) create mode 100644 content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/en.md create mode 100644 content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/gen_cache.cue create mode 100644 content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/page.cue create mode 100644 hugo/content/en/docs/concept/faq/removing-list-arithmetic-operators-v0.11/index.md diff --git a/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/en.md b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/en.md new file mode 100644 index 000000000..f50d7878e --- /dev/null +++ b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/en.md @@ -0,0 +1,318 @@ +--- +title: Removing list arithmetic operators in CUE 0.11 +authors: [jpluscplusm] +toc_hide: true +--- + +{{{with _script_ "en" "HIDDEN: set up access to CUE v0.11 before release"}}} +export PATH=/cues/$CUELANG_CUE_TIP:$PATH +{{{end}}} + +In early versions, the CUE language explicitly allowed lists to be used with +the arithmetic operators "`+`" and "`*`". +This feature was removed from the language specification +[several years ago](https://review.gerrithub.io/plugins/gitiles/cue-lang/cue/+/172f0060cd405f30c5873b793e44300e1a3588cb%5E%21/), +and its removal is now being completed in CUE version 0.11. +This FAQ answers some of your questions about what's changed. + +All the `cue` commands shown here use the following pre-release version: + +{{{with script "en" "cue version"}}} +#ellipsis 1 +cue version +{{{end}}} + +## What's being removed, and from where? + +{{}} +**The list arithmetic operators `*` and `+` don't work in CUE +evaluated by the `cue` command and the Go API from version 0.11 onwards.** +{{}} + +These operators are affected **only** when used with a list value on their left +or right side - they will continue to work as expected in all other situations +(such as numeric arithmetic and string composition). + +This CUE no longer works, and must be updated as demonstrated below: +{{{with upload "en" "removed"}}} +-- list-arithmetic.cue -- +A: [1, 2, 3] * 2 // Invalid CUE! +B: [1, 2, 3] + [4, 5, 6] // Invalid CUE! +{{{end}}} + +## Is my CUE affected by this change? + +{{}} +**If your CUE evaluates successfully using version 0.11 of the `cue` command or +Go API, then it is *not* affected. Use `cue vet` to check if updates are required.** +{{}} + +The easiest way to check if your CUE needs to be updated is to use the `cue` +command at version FIXME or later: + +{{{with upload "en" "cue vet"}}} +#force +-- list-arithmetic.cue -- +A: [1, 2, 3] * 2 // Invalid CUE! +B: [1, 2, 3] + [4, 5, 6] // Invalid CUE! +{{{end}}} +{{{with script "en" "cue vet"}}} +! cue vet missing.file.cue list-arithmetic.cue +{{{end}}} + +If your CUE evaluates successfully then it's valid and doesn't require any +updates. If it fails to evaluate with error messages like the ones shown above, +then you need to +[update your CUE]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue). + +## What changes are needed in my CUE? + +{{}} +**If your CUE suddenly fails to evaluate after upgrading to version 0.11 +and displays the error messages +[demonstrated below]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#is-my-cue-affected-by-this-change) +then use the `cue fix` command to +[update it automatically]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#do-i-need-to-update-my-cue-manually); +or manually:** + +- Find each instance of `*` being used with lists, and replace it with + [`list.Repeat()`](/go/pkg/list#Repeat) +- Find each instance of `+` being used to combine lists, and replace it with + [`list.Concat()`](/go/pkg/list#Concat) +{{}} + +In all cases where they're used with lists: + +- the "`*`" list operator should be replaced with + [`list.Repeat()`](/go/pkg/list#Repeat) from the CUE standard library +- the "`+`" list operator should be replaced with + [`list.Concat()`](/go/pkg/list#Concat), or a nested `for` loop. + +Here's an example of some CUE that uses these standard library functions +instead of list arithmetic operators. Before you start making any manual +changes to your CUE **read the next section**: +["Do I need to update my CUE manually?"]({{< relref "#do-i-need-to-update-my-cue-manually" >}}). + +{{{with code "en" "replacements"}}} +exec cue eval replacements.cue +cmp stdout out +-- replacements.cue -- +import "list" + +// Rewrite "[1, 2, 3] * 2" like this: +A: list.Repeat([1, 2, 3], 2) + +// Rewrite "[1, 2, 3] + [4, 5, 6]" like this: +B: list.Concat([[1, 2, 3], [4, 5, 6]]) + +// Alternatively, rewrite "[1, 2, 3] + [4, 5, 6]" +// like this: +B: [for i in [1, 2, 3] {i}, for i in [4, 5, 6] {i}] + +// The operators can still be used, unchanged, +// to produce number, string, and bytes types. +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +E: 2*'X.' + 3*'O.' +-- out -- +A: [1, 2, 3, 1, 2, 3] +B: [1, 2, 3, 4, 5, 6] +C: 7.6 +D: "O.O.X.X.X." +E: 'X.X.O.O.O.' +{{{end}}} + +## Do I need to update my CUE manually? + +{{}} +***Usually* not. +In many cases the `cue fix` command can perform the updates for you automatically.** +{{}} + +The [`cue fix`]({{< relref "/docs/reference/command/cue-help-fix" >}}) +command checks CUE files, packages, and entire modules, +and automatically updates them to use current CUE syntax. +This means that you usually don't need to update your CUE by hand. +There are some uses of list arithmetic operators that it can't help with, and +these are demonstrated below. + +To apply automatic updates using `cue fix`, make sure you are using a `cue` +command that's at least version FIXME, because earlier versions didn't know how +to update the list arithmetic operators. + +{{{with step}}} + +We'll start with the following CUE that includes list arithmetic operators, +and therefore needs to be updated: + +{{{with upload "en" "cue fix"}}} +#force +-- list-arithmetic.cue -- +A: [1, 2, 3] * 2 +B: [1, 2, 3] + [4, 5, 6] +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +{{{end}}} +{{{end}}} + +{{{with step}}} +We can see that `cue vet` tells us that there's a problem with this CUE: + +{{{with script "en" "cue fix: cue vet"}}} +#FIXME: error after https://review.gerrithub.io/c/cue-lang/cue/+/1200221. +# The file shown above contains invalid CUE: +! cue vet missing.file.cue list-arithmetic.cue +{{{end}}} + +Running `cue vet` on the file is silent, but this doesn't mean that it manages +to discover *every* use of list arithmetic operators and updates them all - it +just means that `cue vet` is able to process the file without error. +{{{end}}} + +{{{with step}}} +We run `cue fix` on the file: +{{{with script "en" "cue fix: cue fix"}}} +cue fix list-arithmetic.cue +{{{end}}} + +`cue fix` also accepts package import path arguments. +To process and update every CUE file in the current module, invoke the command without any arguments. +{{{end}}} + +{{{with step}}} +The updated file now looks like this: + +{{{with _script_ "en" "HIDDEN: cue fix: move file aside"}}} +mv list-arithmetic.cue .list-arithmetic.cue +{{{end}}} +{{{with upload "en" "cue fix: updated file"}}} +#force +-- list-arithmetic.cue -- +import "list" + +A: list.Repeat([1, 2, 3], 2) +B: list.Concat([[1, 2, 3], [4, 5, 6]]) +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +{{{end}}} +{{{with _script_ "en" "HIDDEN: cue fix: diff uploaded file"}}} +diff list-arithmetic.cue .list-arithmetic.cue +{{{end}}} + +Notice that the operators were only updated *where they're used with lists*. +Number- and string-based uses were left intact, as they remain valid CUE and +don't need updating. +{{{end}}} + +{{{with step}}} +The updated file is now valid, and can be evaluated successfully: + +{{{with script "en" "cue fix: cue eval"}}} +cue vet list-arithmetic.cue +cue eval list-arithmetic.cue +{{{end}}} +{{{end}}} + +If `cue vet` still reports problems evaluating your CUE after it has been +updated by `cue fix`, then your CUE is probably using list arithmetic operators +in a way that `cue fix` +[can't detect]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#why-do-i-still-get-evaluation-failures-after-running-cue-fix), +and you'll need to +[update it manually]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue); + +## Why do I still get evaluation failures after running `cue fix`? + +There are some specific scenarios that `cue fix` can't help with. + +`cue fix` can only replace the `*` and `+` list arithmetic operators when +they're used with literal lists, and not references. In other words, `cue fix` +only updates these operators when they are used *directly* with list values +such as `[1, 2, 3]`. + +This means that when the following CUE causes `cue vet` to fail, it must then +be updated manually: + +{{{with upload "en" "references: broken"}}} +-- references.cue -- +x: [1, 2, 3] +y: [4, 5, 6] + +A: x * 2 // Invalid CUE! +B: x + y // Invalid CUE! +{{{end}}} + +This file needs to be +[updated manually]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue), +to the following CUE: + +{{{with upload "en" "references: fixed"}}} +#force +-- references.cue -- +import "list" + +x: [1, 2, 3] +y: [4, 5, 6] + +A: list.Repeat(x, 2) +B: list.Concat([x, y]) +{{{end}}} + +The updated CUE evaluates successfully: + +{{{with script "en" "references: cue eval"}}} +cue eval references.cue +{{{end}}} + +## Which versions of CUE don't support list arithmetic operators? + +{{}} +**Any release or pre-release of CUE that has a version string which starts with +`v0.11` or later does not support list arithmetic operators.** +{{}} + +This includes the 0.11 pre-release alphas (`v0.11.0-alpha...`), the 0.11 +release candidates (`v0.11.0-rc...`), and all 0.11 patch releases including +`v0.11.0`, `v0.11.1`, and so on. It also includes all releases that come after +0.11, whatever version number they might be given. + +## Why are list arithmetic operators being removed? + +The commit that removed them from the CUE language specification in 2021 +[explained the project's reasoning](https://review.gerrithub.io/plugins/gitiles/cue-lang/cue/+/172f0060cd405f30c5873b793e44300e1a3588cb%5E%21/): + +``` +List operators are confusing [and unnecessary]. + +For instance, is the result of [a, ...] + [b, ...] open or closed? +What about [a] + [b, ...]? +``` + +## Why were list arithmetic operators supported until now? + +The CUE project takes its compatibility responsibilities to its users +seriously. A capability that's made available in a released version of CUE (as +list arithmetic operators were) shouldn't be removed the instant that it's +deprecated, even though CUE is still pre-version-1.0 and such an immediate +removal might seem generally allowable under +[semantic versioning guidelines](https://semver.org/#spec-item-5). + +Some users might have written working, supported CUE that relied on list +arithmetic operators, so the CUE tooling supported it up to and including +version 0.10 -- which was released over 3½ years after the feature stopped +being mentioned. + +This breaking language change isn't based on `language.version` from +`cue.mod/module.cue` because a large amount of time has now passed *without* it +being mentioned in the CUE language specification or official documentation. + +## I have a question that isn't answered here + +Please join the [CUE community]({{< relref "/community" >}}) on GitHub, Slack, +or Discord -- we'll be happy to help! + +## Related content + +- {{}} +- {{}} +- Standard library: [`list.Repeat()`](/go/pkg/list#Repeat) +- Standard library: [`list.Concat()`](/go/pkg/list#Concat) diff --git a/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/gen_cache.cue b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/gen_cache.cue new file mode 100644 index 000000000..88b1d57e0 --- /dev/null +++ b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/gen_cache.cue @@ -0,0 +1,108 @@ +package site +{ + content: { + docs: { + concept: { + faq: { + "removing-list-arithmetic-operators-v0.11": { + page: { + cache: { + upload: { + removed: "hVb+hFId97isxNNFm7eJZXOVbKr/ekj9HAUd4wreYcU=" + "cue vet": "d3XMngpaPkyQfgkSC/b1R1N0VLqz2sfqrGyc1jJbOpY=" + "cue fix": "6MrKtOG1JvskQZaLjNd8SifXdhTAnsc2mG18nVq8rCg=" + "cue fix: updated file": "4MnZawoR3KzKRPwsjDcMHAXpZeKvARAbROcLeei2caE=" + "references: broken": "SmeV0nlOnS5Hj5b/VBVNf/V/XC65p/fSql290J7at1Q=" + "references: fixed": "xI/y9+GYRE4GFJgAGxLXRJX6V6Dj+NvIoq6+pR5Wvog=" + } + code: { + replacements: "qxpkTZhAcFW9bt2OXZWi7S9tKIX1010arnxYgOpCN7k=" + } + multi_step: { + hash: "UCVT2RP8QC65JMS0G280A033M2G5I4SGVBRIV3MD6P12S7AGV83G====" + scriptHash: "GRJ1FCBP5280L38Q03DG0BVL8HMBV4Q7608BVUALMMDG61PO9UQ0====" + steps: [{ + doc: "" + cmd: "export PATH=/cues/v0.11.0-0.dev.0.20240902110846-1440b9eae7fa:$PATH" + exitCode: 0 + output: "" + }, { + doc: "#ellipsis 1" + cmd: "cue version" + exitCode: 0 + output: """ + cue version v0.11.0-0.dev.0.20240902110846-1440b9eae7fa + ... + + """ + }, { + doc: "" + cmd: "cue vet missing.file.cue list-arithmetic.cue" + exitCode: 1 + output: """ + could not find file /home/runner/missing.file.cue: stat: stat /home/runner/missing.file.cue: no such file or directory + + """ + }, { + doc: """ + #FIXME: error after https://review.gerrithub.io/c/cue-lang/cue/+/1200221. + # The file shown above contains invalid CUE: + """ + cmd: "cue vet missing.file.cue list-arithmetic.cue" + exitCode: 1 + output: """ + could not find file /home/runner/missing.file.cue: stat: stat /home/runner/missing.file.cue: no such file or directory + + """ + }, { + doc: "" + cmd: "cue fix list-arithmetic.cue" + exitCode: 0 + output: "" + }, { + doc: "" + cmd: "mv list-arithmetic.cue .list-arithmetic.cue" + exitCode: 0 + output: "" + }, { + doc: "" + cmd: "diff list-arithmetic.cue .list-arithmetic.cue" + exitCode: 0 + output: "" + }, { + doc: "" + cmd: "cue vet list-arithmetic.cue" + exitCode: 0 + output: "" + }, { + doc: "" + cmd: "cue eval list-arithmetic.cue" + exitCode: 0 + output: """ + A: [1, 2, 3, 1, 2, 3] + B: [1, 2, 3, 4, 5, 6] + C: 7.6 + D: "O.O.X.X.X." + + """ + }, { + doc: "" + cmd: "cue eval references.cue" + exitCode: 0 + output: """ + x: [1, 2, 3] + y: [4, 5, 6] + A: [1, 2, 3, 1, 2, 3] + B: [1, 2, 3, 4, 5, 6] + + """ + }] + } + } + } + } + } + } + } + } +} diff --git a/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/page.cue b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/page.cue new file mode 100644 index 000000000..6f9a2ef89 --- /dev/null +++ b/content/docs/concept/faq/removing-list-arithmetic-operators-v0.11/page.cue @@ -0,0 +1,3 @@ +package site + +content: docs: concept: faq: "removing-list-arithmetic-operators-v0.11": page: _ diff --git a/hugo/content/en/docs/concept/faq/removing-list-arithmetic-operators-v0.11/index.md b/hugo/content/en/docs/concept/faq/removing-list-arithmetic-operators-v0.11/index.md new file mode 100644 index 000000000..f024d16f0 --- /dev/null +++ b/hugo/content/en/docs/concept/faq/removing-list-arithmetic-operators-v0.11/index.md @@ -0,0 +1,313 @@ +--- +title: Removing list arithmetic operators in CUE 0.11 +authors: [jpluscplusm] +toc_hide: true +--- + +In early versions, the CUE language explicitly allowed lists to be used with +the arithmetic operators "`+`" and "`*`". +This feature was removed from the language specification +[several years ago](https://review.gerrithub.io/plugins/gitiles/cue-lang/cue/+/172f0060cd405f30c5873b793e44300e1a3588cb%5E%21/), +and its removal is now being completed in CUE version 0.11. +This FAQ answers some of your questions about what's changed. + +All the `cue` commands shown here use the following pre-release version: + +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIHZlcnNpb24=" } +$ cue version +cue version v0.11.0-0.dev.0.20240902110846-1440b9eae7fa +... +``` + +## What's being removed, and from where? + +{{}} +**The list arithmetic operators `*` and `+` don't work in CUE +evaluated by the `cue` command and the Go API from version 0.11 onwards.** +{{}} + +These operators are affected **only** when used with a list value on their left +or right side - they will continue to work as expected in all other situations +(such as numeric arithmetic and string composition). + +This CUE no longer works, and must be updated as demonstrated below: +{{< code-tabs >}} +{{< code-tab name="list-arithmetic.cue" language="cue" area="top-left" >}} +A: [1, 2, 3] * 2 // Invalid CUE! +B: [1, 2, 3] + [4, 5, 6] // Invalid CUE! +{{< /code-tab >}}{{< /code-tabs >}} + +## Is my CUE affected by this change? + +{{}} +**If your CUE evaluates successfully using version 0.11 of the `cue` command or +Go API, then it is *not* affected. Use `cue vet` to check if updates are required.** +{{}} + +The easiest way to check if your CUE needs to be updated is to use the `cue` +command at version FIXME or later: + +{{< code-tabs >}} +{{< code-tab name="list-arithmetic.cue" language="cue" area="top-left" >}} +A: [1, 2, 3] * 2 // Invalid CUE! +B: [1, 2, 3] + [4, 5, 6] // Invalid CUE! +{{< /code-tab >}}{{< /code-tabs >}} +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIHZldCBtaXNzaW5nLmZpbGUuY3VlIGxpc3QtYXJpdGhtZXRpYy5jdWU=" } +$ cue vet missing.file.cue list-arithmetic.cue +could not find file /home/runner/missing.file.cue: stat: stat /home/runner/missing.file.cue: no such file or directory +``` + +If your CUE evaluates successfully then it's valid and doesn't require any +updates. If it fails to evaluate with error messages like the ones shown above, +then you need to +[update your CUE]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue). + +## What changes are needed in my CUE? + +{{}} +**If your CUE suddenly fails to evaluate after upgrading to version 0.11 +and displays the error messages +[demonstrated below]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#is-my-cue-affected-by-this-change) +then use the `cue fix` command to +[update it automatically]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#do-i-need-to-update-my-cue-manually); +or manually:** + +- Find each instance of `*` being used with lists, and replace it with + [`list.Repeat()`](/go/pkg/list#Repeat) +- Find each instance of `+` being used to combine lists, and replace it with + [`list.Concat()`](/go/pkg/list#Concat) +{{}} + +In all cases where they're used with lists: + +- the "`*`" list operator should be replaced with + [`list.Repeat()`](/go/pkg/list#Repeat) from the CUE standard library +- the "`+`" list operator should be replaced with + [`list.Concat()`](/go/pkg/list#Concat), or a nested `for` loop. + +Here's an example of some CUE that uses these standard library functions +instead of list arithmetic operators. Before you start making any manual +changes to your CUE **read the next section**: +["Do I need to update my CUE manually?"]({{< relref "#do-i-need-to-update-my-cue-manually" >}}). + +{{< code-tabs >}} +{{< code-tab name="replacements.cue" language="cue" area="top-left" >}} +import "list" + +// Rewrite "[1, 2, 3] * 2" like this: +A: list.Repeat([1, 2, 3], 2) + +// Rewrite "[1, 2, 3] + [4, 5, 6]" like this: +B: list.Concat([[1, 2, 3], [4, 5, 6]]) + +// Alternatively, rewrite "[1, 2, 3] + [4, 5, 6]" +// like this: +B: [for i in [1, 2, 3] {i}, for i in [4, 5, 6] {i}] + +// The operators can still be used, unchanged, +// to produce number, string, and bytes types. +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +E: 2*'X.' + 3*'O.' +{{< /code-tab >}} +{{< code-tab name="TERMINAL" language="" area="top-right" type="terminal" codetocopy="Y3VlIGV2YWwgcmVwbGFjZW1lbnRzLmN1ZQ==" >}} +$ cue eval replacements.cue +A: [1, 2, 3, 1, 2, 3] +B: [1, 2, 3, 4, 5, 6] +C: 7.6 +D: "O.O.X.X.X." +E: 'X.X.O.O.O.' +{{< /code-tab >}} +{{< /code-tabs >}} + +## Do I need to update my CUE manually? + +{{}} +***Usually* not. +In many cases the `cue fix` command can perform the updates for you automatically.** +{{}} + +The [`cue fix`]({{< relref "/docs/reference/command/cue-help-fix" >}}) +command checks CUE files, packages, and entire modules, +and automatically updates them to use current CUE syntax. +This means that you usually don't need to update your CUE by hand. +There are some uses of list arithmetic operators that it can't help with, and +these are demonstrated below. + +To apply automatic updates using `cue fix`, make sure you are using a `cue` +command that's at least version FIXME, because earlier versions didn't know how +to update the list arithmetic operators. + +{{< step stepNumber="1" >}} + +We'll start with the following CUE that includes list arithmetic operators, +and therefore needs to be updated: + +{{< code-tabs >}} +{{< code-tab name="list-arithmetic.cue" language="cue" area="top-left" >}} +A: [1, 2, 3] * 2 +B: [1, 2, 3] + [4, 5, 6] +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +{{< /code-tab >}}{{< /code-tabs >}} +{{< /step >}} + +{{< step stepNumber="2" >}} +We can see that `cue vet` tells us that there's a problem with this CUE: + +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIHZldCBtaXNzaW5nLmZpbGUuY3VlIGxpc3QtYXJpdGhtZXRpYy5jdWU=" } +# The file shown above contains invalid CUE: +$ cue vet missing.file.cue list-arithmetic.cue +could not find file /home/runner/missing.file.cue: stat: stat /home/runner/missing.file.cue: no such file or directory +``` + +Running `cue vet` on the file is silent, but this doesn't mean that it manages +to discover *every* use of list arithmetic operators and updates them all - it +just means that `cue vet` is able to process the file without error. +{{< /step >}} + +{{< step stepNumber="3" >}} +We run `cue fix` on the file: +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIGZpeCBsaXN0LWFyaXRobWV0aWMuY3Vl" } +$ cue fix list-arithmetic.cue +``` + +`cue fix` also accepts package import path arguments. +To process and update every CUE file in the current module, invoke the command without any arguments. +{{< /step >}} + +{{< step stepNumber="4" >}} +The updated file now looks like this: +{{< code-tabs >}} +{{< code-tab name="list-arithmetic.cue" language="cue" area="top-left" >}} +import "list" + +A: list.Repeat([1, 2, 3], 2) +B: list.Concat([[1, 2, 3], [4, 5, 6]]) +C: 1 + 2*3.3 +D: 2*"O." + 3*"X." +{{< /code-tab >}}{{< /code-tabs >}} +Notice that the operators were only updated *where they're used with lists*. +Number- and string-based uses were left intact, as they remain valid CUE and +don't need updating. +{{< /step >}} + +{{< step stepNumber="5" >}} +The updated file is now valid, and can be evaluated successfully: + +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIHZldCBsaXN0LWFyaXRobWV0aWMuY3VlCmN1ZSBldmFsIGxpc3QtYXJpdGhtZXRpYy5jdWU=" } +$ cue vet list-arithmetic.cue +$ cue eval list-arithmetic.cue +A: [1, 2, 3, 1, 2, 3] +B: [1, 2, 3, 4, 5, 6] +C: 7.6 +D: "O.O.X.X.X." +``` +{{< /step >}} + +If `cue vet` still reports problems evaluating your CUE after it has been +updated by `cue fix`, then your CUE is probably using list arithmetic operators +in a way that `cue fix` +[can't detect]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#why-do-i-still-get-evaluation-failures-after-running-cue-fix), +and you'll need to +[update it manually]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue); + +## Why do I still get evaluation failures after running `cue fix`? + +There are some specific scenarios that `cue fix` can't help with. + +`cue fix` can only replace the `*` and `+` list arithmetic operators when +they're used with literal lists, and not references. In other words, `cue fix` +only updates these operators when they are used *directly* with list values +such as `[1, 2, 3]`. + +This means that when the following CUE causes `cue vet` to fail, it must then +be updated manually: + +{{< code-tabs >}} +{{< code-tab name="references.cue" language="cue" area="top-left" >}} +x: [1, 2, 3] +y: [4, 5, 6] + +A: x * 2 // Invalid CUE! +B: x + y // Invalid CUE! +{{< /code-tab >}}{{< /code-tabs >}} + +This file needs to be +[updated manually]({{< relref "removing-list-arithmetic-operators-v0.11" >}}#what-changes-are-needed-in-my-cue), +to the following CUE: + +{{< code-tabs >}} +{{< code-tab name="references.cue" language="cue" area="top-left" >}} +import "list" + +x: [1, 2, 3] +y: [4, 5, 6] + +A: list.Repeat(x, 2) +B: list.Concat([x, y]) +{{< /code-tab >}}{{< /code-tabs >}} + +The updated CUE evaluates successfully: + +```text { title="TERMINAL" type="terminal" codeToCopy="Y3VlIGV2YWwgcmVmZXJlbmNlcy5jdWU=" } +$ cue eval references.cue +x: [1, 2, 3] +y: [4, 5, 6] +A: [1, 2, 3, 1, 2, 3] +B: [1, 2, 3, 4, 5, 6] +``` + +## Which versions of CUE don't support list arithmetic operators? + +{{}} +**Any release or pre-release of CUE that has a version string which starts with +`v0.11` or later does not support list arithmetic operators.** +{{}} + +This includes the 0.11 pre-release alphas (`v0.11.0-alpha...`), the 0.11 +release candidates (`v0.11.0-rc...`), and all 0.11 patch releases including +`v0.11.0`, `v0.11.1`, and so on. It also includes all releases that come after +0.11, whatever version number they might be given. + +## Why are list arithmetic operators being removed? + +The commit that removed them from the CUE language specification in 2021 +[explained the project's reasoning](https://review.gerrithub.io/plugins/gitiles/cue-lang/cue/+/172f0060cd405f30c5873b793e44300e1a3588cb%5E%21/): + +``` +List operators are confusing [and unnecessary]. + +For instance, is the result of [a, ...] + [b, ...] open or closed? +What about [a] + [b, ...]? +``` + +## Why were list arithmetic operators supported until now? + +The CUE project takes its compatibility responsibilities to its users +seriously. A capability that's made available in a released version of CUE (as +list arithmetic operators were) shouldn't be removed the instant that it's +deprecated, even though CUE is still pre-version-1.0 and such an immediate +removal might seem generally allowable under +[semantic versioning guidelines](https://semver.org/#spec-item-5). + +Some users might have written working, supported CUE that relied on list +arithmetic operators, so the CUE tooling supported it up to and including +version 0.10 -- which was released over 3½ years after the feature stopped +being mentioned. + +This breaking language change isn't based on `language.version` from +`cue.mod/module.cue` because a large amount of time has now passed *without* it +being mentioned in the CUE language specification or official documentation. + +## I have a question that isn't answered here + +Please join the [CUE community]({{< relref "/community" >}}) on GitHub, Slack, +or Discord -- we'll be happy to help! + +## Related content + +- {{}} +- {{}} +- Standard library: [`list.Repeat()`](/go/pkg/list#Repeat) +- Standard library: [`list.Concat()`](/go/pkg/list#Concat) diff --git a/hugo/layouts/index.redir b/hugo/layouts/index.redir index 4c6eff775..0c5f8307f 100644 --- a/hugo/layouts/index.redir +++ b/hugo/layouts/index.redir @@ -50,4 +50,4 @@ https://cue.netlify.com/* https://cuelang.org/:splat 301! /docs/tutorials/tour/packages /docs/tour/packages/ 301! /s/slack https://join.slack.com/t/cuelang/shared_invite/enQtNzQwODc3NzYzNTA0LTAxNWQwZGU2YWFiOWFiOWQ4MjVjNGQ2ZTNlMmIxODc4MDVjMDg5YmIyOTMyMjQ2MTkzMTU5ZjA1OGE0OGE1NmE 302! /s/discord https://discord.gg/CBUzN6CrRa 302! -/e/v0.11-list-arithmetic /cl/1200221 302! +/e/v0.11-list-arithmetic /docs/concept/faq/removing-list-arithmetic-operators-v0.11/ 302! diff --git a/internal/ci/netlify/netlify.cue b/internal/ci/netlify/netlify.cue index e4569d146..ed97fb778 100644 --- a/internal/ci/netlify/netlify.cue +++ b/internal/ci/netlify/netlify.cue @@ -185,7 +185,7 @@ config: #config & { to: "https://discord.gg/CBUzN6CrRa" }, { from: "/e/v0.11-list-arithmetic" - to: "/cl/1200221" + to: "/docs/concept/faq/removing-list-arithmetic-operators-v0.11/" }] }