From c60fa713ae954705fbfed2b5a30c57be4f1c221c Mon Sep 17 00:00:00 2001 From: Jonathan Matthews Date: Wed, 17 Jan 2024 17:20:22 +0000 Subject: [PATCH] docs/howto: use path.Join This adds a Commented CUE guide that demonstrates using path.Join to construct well-formed paths. One example of parent directory traversal is included. Preview-Path: /docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/ Signed-off-by: Jonathan Matthews Change-Id: I046a00af48dd5a34e15affe49a7ab8949bd0d787 --- .../en.md | 45 ++++++++++++++++++ .../gen_cache.cue | 18 ++++++++ .../page.cue | 3 ++ .../index.md | 46 +++++++++++++++++++ 4 files changed, 112 insertions(+) create mode 100644 content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/en.md create mode 100644 content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/gen_cache.cue create mode 100644 content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/page.cue create mode 100644 hugo/content/en/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/index.md diff --git a/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/en.md b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/en.md new file mode 100644 index 000000000..017e35e2e --- /dev/null +++ b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/en.md @@ -0,0 +1,45 @@ +--- +title: Using the built-in function "path.Join" to construct well-formed paths +tags: +- commented cue +authors: +- jpluscplusm +toc_hide: true +--- + +This [Commented CUE]({{< relref "docs/howto#commented-cue-guides" >}}) +demonstrates how to use the built-in function +[`path.Join`](https://pkg.go.dev/cuelang.org/go/pkg/path#Join) +to construct well-formed paths from their individual string components. + +{{{with code "en" "cc"}}} +exec cue export +cmp stdout out +-- file.cue -- +package example + +import "path" + +join: path.Join(["foo", "bar", "baz"], path.Unix) + +unix: path.Join(_components, path.Unix) +windows: path.Join(_components, path.Windows) + +_components: [ + "foo", + "bar", + "baz", + "..", + "quux", +] +-- out -- +{ + "join": "foo/bar/baz", + "unix": "foo/bar/quux", + "windows": "foo\\bar\\quux" +} +{{{end}}} + +## Related content + +- The [`path`](https://pkg.go.dev/cuelang.org/go/pkg/path) built-in package diff --git a/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/gen_cache.cue b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/gen_cache.cue new file mode 100644 index 000000000..aa7803f7f --- /dev/null +++ b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/gen_cache.cue @@ -0,0 +1,18 @@ +package site +{ + content: { + docs: { + howto: { + "use-the-built-in-function-path-join-to-construct-well-formed-paths": { + page: { + cache: { + code: { + cc: "y9OBCcAnpV6BCR0Yg7oiGAzQwvgKvFqM/g5jiSZOVzM=" + } + } + } + } + } + } + } +} diff --git a/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/page.cue b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/page.cue new file mode 100644 index 000000000..929b3cb10 --- /dev/null +++ b/content/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/page.cue @@ -0,0 +1,3 @@ +package site + +content: docs: howto: "use-the-built-in-function-path-join-to-construct-well-formed-paths": {} diff --git a/hugo/content/en/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/index.md b/hugo/content/en/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/index.md new file mode 100644 index 000000000..961c9245b --- /dev/null +++ b/hugo/content/en/docs/howto/use-the-built-in-function-path-join-to-construct-well-formed-paths/index.md @@ -0,0 +1,46 @@ +--- +title: Using the built-in function "path.Join" to construct well-formed paths +tags: +- commented cue +authors: +- jpluscplusm +toc_hide: true +--- + +This [Commented CUE]({{< relref "docs/howto#commented-cue-guides" >}}) +demonstrates how to use the built-in function +[`path.Join`](https://pkg.go.dev/cuelang.org/go/pkg/path#Join) +to construct well-formed paths from their individual string components. + +{{< code-tabs >}} +{{< code-tab name="file.cue" language="cue" area="top-left" >}} +package example + +import "path" + +join: path.Join(["foo", "bar", "baz"], path.Unix) + +unix: path.Join(_components, path.Unix) +windows: path.Join(_components, path.Windows) + +_components: [ + "foo", + "bar", + "baz", + "..", + "quux", +] +{{< /code-tab >}} +{{< code-tab name="TERMINAL" language="" type="terminal" area="top-right" >}} +$ cue export +{ + "join": "foo/bar/baz", + "unix": "foo/bar/quux", + "windows": "foo\\bar\\quux" +} +{{< /code-tab >}} +{{< /code-tabs >}} + +## Related content + +- The [`path`](https://pkg.go.dev/cuelang.org/go/pkg/path) built-in package