From 5230f8f7e540f61a123cef8c4d203e0f616c5cd2 Mon Sep 17 00:00:00 2001 From: "zoo-github-actions-auth[bot]" <155849648+zoo-github-actions-auth[bot]@users.noreply.github.com> Date: Mon, 30 Sep 2024 18:07:42 -0700 Subject: [PATCH] Update KCL docs (#257) YOYO NEW KCL DOCS!! Co-authored-by: github-actions[bot] --- content/pages/docs/kcl/arrayReduce.md | 47 --- content/pages/docs/kcl/index.md | 3 +- content/pages/docs/kcl/map.md | 56 ++++ content/pages/docs/kcl/reduce.md | 47 +++ .../pages/docs/kcl/types/BinaryOperator.md | 89 ++++++ content/pages/docs/kcl/types/BinaryPart.md | 161 ++++++++++ content/pages/docs/kcl/types/BodyItem.md | 75 +++++ content/pages/docs/kcl/types/CommentStyle.md | 41 +++ content/pages/docs/kcl/types/ElseIf.md | 24 ++ content/pages/docs/kcl/types/Environment.md | 21 ++ .../pages/docs/kcl/types/EnvironmentRef.md | 16 + content/pages/docs/kcl/types/Expr.md | 297 ++++++++++++++++++ .../docs/kcl/types/FunctionExpression.md | 24 ++ content/pages/docs/kcl/types/Identifier.md | 23 ++ content/pages/docs/kcl/types/KclValue.md | 195 ++++++++++++ .../pages/docs/kcl/types/LiteralIdentifier.md | 56 ++++ content/pages/docs/kcl/types/LiteralValue.md | 57 ++++ content/pages/docs/kcl/types/MemberObject.md | 57 ++++ content/pages/docs/kcl/types/NonCodeMeta.md | 22 ++ content/pages/docs/kcl/types/NonCodeNode.md | 23 ++ content/pages/docs/kcl/types/NonCodeValue.md | 103 ++++++ .../pages/docs/kcl/types/ObjectProperty.md | 24 ++ content/pages/docs/kcl/types/Parameter.md | 23 ++ content/pages/docs/kcl/types/Program.md | 25 ++ content/pages/docs/kcl/types/ProgramMemory.md | 22 ++ content/pages/docs/kcl/types/UnaryOperator.md | 41 +++ .../docs/kcl/types/VariableDeclarator.md | 24 ++ content/pages/docs/kcl/types/VariableKind.md | 65 ++++ 28 files changed, 1613 insertions(+), 48 deletions(-) delete mode 100644 content/pages/docs/kcl/arrayReduce.md create mode 100644 content/pages/docs/kcl/map.md create mode 100644 content/pages/docs/kcl/reduce.md create mode 100644 content/pages/docs/kcl/types/BinaryOperator.md create mode 100644 content/pages/docs/kcl/types/BinaryPart.md create mode 100644 content/pages/docs/kcl/types/BodyItem.md create mode 100644 content/pages/docs/kcl/types/CommentStyle.md create mode 100644 content/pages/docs/kcl/types/ElseIf.md create mode 100644 content/pages/docs/kcl/types/Environment.md create mode 100644 content/pages/docs/kcl/types/EnvironmentRef.md create mode 100644 content/pages/docs/kcl/types/Expr.md create mode 100644 content/pages/docs/kcl/types/FunctionExpression.md create mode 100644 content/pages/docs/kcl/types/Identifier.md create mode 100644 content/pages/docs/kcl/types/KclValue.md create mode 100644 content/pages/docs/kcl/types/LiteralIdentifier.md create mode 100644 content/pages/docs/kcl/types/LiteralValue.md create mode 100644 content/pages/docs/kcl/types/MemberObject.md create mode 100644 content/pages/docs/kcl/types/NonCodeMeta.md create mode 100644 content/pages/docs/kcl/types/NonCodeNode.md create mode 100644 content/pages/docs/kcl/types/NonCodeValue.md create mode 100644 content/pages/docs/kcl/types/ObjectProperty.md create mode 100644 content/pages/docs/kcl/types/Parameter.md create mode 100644 content/pages/docs/kcl/types/Program.md create mode 100644 content/pages/docs/kcl/types/ProgramMemory.md create mode 100644 content/pages/docs/kcl/types/UnaryOperator.md create mode 100644 content/pages/docs/kcl/types/VariableDeclarator.md create mode 100644 content/pages/docs/kcl/types/VariableKind.md diff --git a/content/pages/docs/kcl/arrayReduce.md b/content/pages/docs/kcl/arrayReduce.md deleted file mode 100644 index 1c8796c..0000000 --- a/content/pages/docs/kcl/arrayReduce.md +++ /dev/null @@ -1,47 +0,0 @@ ---- -title: "arrayReduce" -excerpt: "Take a starting value. Then, for each element of an array, calculate the next value," -layout: manual ---- - -Take a starting value. Then, for each element of an array, calculate the next value, - -using the previous value and the element. - -```js -arrayReduce(array: [u64], start: Sketch, reduce_fn: FunctionParam) -> Sketch -``` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `array` | `[u64]` | | Yes | -| `start` | [`Sketch`](/docs/kcl/types/Sketch) | A sketch is a collection of paths. | Yes | -| `reduce_fn` | `FunctionParam` | | Yes | - -### Returns - -[`Sketch`](/docs/kcl/types/Sketch) - A sketch is a collection of paths. - - -### Examples - -```js -fn decagon = (radius) => { - let step = 1 / 10 * tau() - let sketch001 = startSketchAt([cos(0) * radius, sin(0) * radius]) - return arrayReduce([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], sketch001, (i, sg) => { - let x = cos(step * i) * radius - let y = sin(step * i) * radius - return lineTo([x, y], sg) -}) -} -decagon(5.0) - |> close(%) -``` - -![Rendered example of arrayReduce 0]() - - diff --git a/content/pages/docs/kcl/index.md b/content/pages/docs/kcl/index.md index 7049d8b..da22436 100644 --- a/content/pages/docs/kcl/index.md +++ b/content/pages/docs/kcl/index.md @@ -19,7 +19,6 @@ layout: manual * [`angledLineToX`](kcl/angledLineToX) * [`angledLineToY`](kcl/angledLineToY) * [`arc`](kcl/arc) -* [`arrayReduce`](kcl/arrayReduce) * [`asin`](kcl/asin) * [`assert`](kcl/assert) * [`assertEqual`](kcl/assertEqual) @@ -62,6 +61,7 @@ layout: manual * [`log10`](kcl/log10) * [`log2`](kcl/log2) * [`m`](kcl/m) +* [`map`](kcl/map) * [`max`](kcl/max) * [`min`](kcl/min) * [`mirror2d`](kcl/mirror2d) @@ -78,6 +78,7 @@ layout: manual * [`profileStart`](kcl/profileStart) * [`profileStartX`](kcl/profileStartX) * [`profileStartY`](kcl/profileStartY) +* [`reduce`](kcl/reduce) * [`rem`](kcl/rem) * [`revolve`](kcl/revolve) * [`segAng`](kcl/segAng) diff --git a/content/pages/docs/kcl/map.md b/content/pages/docs/kcl/map.md new file mode 100644 index 0000000..019aa04 --- /dev/null +++ b/content/pages/docs/kcl/map.md @@ -0,0 +1,56 @@ +--- +title: "map" +excerpt: "Apply a function to every element of a list." +layout: manual +--- + +Apply a function to every element of a list. + +Given a list like `[a, b, c]`, and a function like `f`, returns `[f(a), f(b), f(c)]` + +```js +map(array: [KclValue], map_fn: FunctionParam) -> [KclValue] +``` + + +### Arguments + +| Name | Type | Description | Required | +|----------|------|-------------|----------| +| `array` | [`[KclValue]`](/docs/kcl/types/KclValue) | | Yes | +| `map_fn` | `FunctionParam` | | Yes | + +### Returns + +[`[KclValue]`](/docs/kcl/types/KclValue) + + +### Examples + +```js +const r = 10 // radius +fn drawCircle = (id) => { + return startSketchOn("XY") + |> circle({ center: [id * 2 * r, 0], radius: r }, %) +} + +// Call `drawCircle`, passing in each element of the array. +// The outputs from each `drawCircle` form a new array, +// which is the return value from `map`. +const circles = map([1, 2, 3], drawCircle) +``` + +![Rendered example of map 0]() + +```js +const r = 10 // radius +// Call `map`, using an anonymous function instead of a named one. +const circles = map([1, 2, 3], (id) => { + return startSketchOn("XY") + |> circle({ center: [id * 2 * r, 0], radius: r }, %) +}) +``` + +![Rendered example of map 1]() + + diff --git a/content/pages/docs/kcl/reduce.md b/content/pages/docs/kcl/reduce.md new file mode 100644 index 0000000..15302e0 --- /dev/null +++ b/content/pages/docs/kcl/reduce.md @@ -0,0 +1,47 @@ +--- +title: "reduce" +excerpt: "Take a starting value. Then, for each element of an array, calculate the next value," +layout: manual +--- + +Take a starting value. Then, for each element of an array, calculate the next value, + +using the previous value and the element. + +```js +reduce(array: [u64], start: Sketch, reduce_fn: FunctionParam) -> Sketch +``` + + +### Arguments + +| Name | Type | Description | Required | +|----------|------|-------------|----------| +| `array` | `[u64]` | | Yes | +| `start` | [`Sketch`](/docs/kcl/types/Sketch) | A sketch is a collection of paths. | Yes | +| `reduce_fn` | `FunctionParam` | | Yes | + +### Returns + +[`Sketch`](/docs/kcl/types/Sketch) - A sketch is a collection of paths. + + +### Examples + +```js +fn decagon = (radius) => { + let step = 1 / 10 * tau() + let sketch001 = startSketchAt([cos(0) * radius, sin(0) * radius]) + return reduce([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], sketch001, (i, sg) => { + let x = cos(step * i) * radius + let y = sin(step * i) * radius + return lineTo([x, y], sg) +}) +} +decagon(5.0) + |> close(%) +``` + +![Rendered example of reduce 0]() + + diff --git a/content/pages/docs/kcl/types/BinaryOperator.md b/content/pages/docs/kcl/types/BinaryOperator.md new file mode 100644 index 0000000..4ef890e --- /dev/null +++ b/content/pages/docs/kcl/types/BinaryOperator.md @@ -0,0 +1,89 @@ +--- +title: "BinaryOperator" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + +Add two numbers. + +**enum:** `+` + + + + + + + + +---- +Subtract two numbers. + +**enum:** `-` + + + + + + + + +---- +Multiply two numbers. + +**enum:** `*` + + + + + + + + +---- +Divide two numbers. + +**enum:** `/` + + + + + + + + +---- +Modulo two numbers. + +**enum:** `%` + + + + + + + + +---- +Raise a number to a power. + +**enum:** `^` + + + + + + + + +---- + + + + diff --git a/content/pages/docs/kcl/types/BinaryPart.md b/content/pages/docs/kcl/types/BinaryPart.md new file mode 100644 index 0000000..87b0b77 --- /dev/null +++ b/content/pages/docs/kcl/types/BinaryPart.md @@ -0,0 +1,161 @@ +--- +title: "BinaryPart" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Literal`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |[`LiteralValue`](/docs/kcl/types/LiteralValue)| | No | +| `raw` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `name` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `BinaryExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `operator` |[`BinaryOperator`](/docs/kcl/types/BinaryOperator)| | No | +| `left` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| | No | +| `right` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `CallExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `callee` |[`Identifier`](/docs/kcl/types/Identifier)| | No | +| `arguments` |`[` [`Expr`](/docs/kcl/types/Expr) `]`| | No | +| `optional` |`boolean`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `UnaryExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `operator` |[`UnaryOperator`](/docs/kcl/types/UnaryOperator)| | No | +| `argument` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `MemberExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `object` |[`MemberObject`](/docs/kcl/types/MemberObject)| | No | +| `property` |[`LiteralIdentifier`](/docs/kcl/types/LiteralIdentifier)| | No | +| `computed` |`boolean`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `IfExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `cond` |[`Expr`](/docs/kcl/types/Expr)| | No | +| `then_val` |[`Program`](/docs/kcl/types/Program)| | No | +| `else_ifs` |`[` [`ElseIf`](/docs/kcl/types/ElseIf) `]`| | No | +| `final_else` |[`Program`](/docs/kcl/types/Program)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/BodyItem.md b/content/pages/docs/kcl/types/BodyItem.md new file mode 100644 index 0000000..5fab055 --- /dev/null +++ b/content/pages/docs/kcl/types/BodyItem.md @@ -0,0 +1,75 @@ +--- +title: "BodyItem" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `ExpressionStatement`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `expression` |[`Expr`](/docs/kcl/types/Expr)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `VariableDeclaration`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `declarations` |`[` [`VariableDeclarator`](/docs/kcl/types/VariableDeclarator) `]`| | No | +| `kind` |[`VariableKind`](/docs/kcl/types/VariableKind)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `ReturnStatement`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `argument` |[`Expr`](/docs/kcl/types/Expr)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/CommentStyle.md b/content/pages/docs/kcl/types/CommentStyle.md new file mode 100644 index 0000000..368811a --- /dev/null +++ b/content/pages/docs/kcl/types/CommentStyle.md @@ -0,0 +1,41 @@ +--- +title: "CommentStyle" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + +Like // foo + +**enum:** `line` + + + + + + + + +---- +Like /* foo */ + +**enum:** `block` + + + + + + + + +---- + + + + diff --git a/content/pages/docs/kcl/types/ElseIf.md b/content/pages/docs/kcl/types/ElseIf.md new file mode 100644 index 0000000..20f3f6b --- /dev/null +++ b/content/pages/docs/kcl/types/ElseIf.md @@ -0,0 +1,24 @@ +--- +title: "ElseIf" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `cond` |[`Expr`](/docs/kcl/types/Expr)| | No | +| `then_val` |[`Program`](/docs/kcl/types/Program)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/Environment.md b/content/pages/docs/kcl/types/Environment.md new file mode 100644 index 0000000..d2ed592 --- /dev/null +++ b/content/pages/docs/kcl/types/Environment.md @@ -0,0 +1,21 @@ +--- +title: "Environment" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `bindings` |`object`| | No | +| `parent` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | + + diff --git a/content/pages/docs/kcl/types/EnvironmentRef.md b/content/pages/docs/kcl/types/EnvironmentRef.md new file mode 100644 index 0000000..2293065 --- /dev/null +++ b/content/pages/docs/kcl/types/EnvironmentRef.md @@ -0,0 +1,16 @@ +--- +title: "EnvironmentRef" +excerpt: "An index pointing to an environment." +layout: manual +--- + +An index pointing to an environment. + +**Type:** `integer` (`uint`) + + + + + + + diff --git a/content/pages/docs/kcl/types/Expr.md b/content/pages/docs/kcl/types/Expr.md new file mode 100644 index 0000000..b3e70b6 --- /dev/null +++ b/content/pages/docs/kcl/types/Expr.md @@ -0,0 +1,297 @@ +--- +title: "Expr" +excerpt: "An expression can be evaluated to yield a single KCL value." +layout: manual +--- + +An expression can be evaluated to yield a single KCL value. + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Literal`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |[`LiteralValue`](/docs/kcl/types/LiteralValue)| An expression can be evaluated to yield a single KCL value. | No | +| `raw` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `name` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`TagDeclarator`](/docs/kcl/types#tag-declaration)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `BinaryExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `operator` |[`BinaryOperator`](/docs/kcl/types/BinaryOperator)| An expression can be evaluated to yield a single KCL value. | No | +| `left` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | +| `right` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`FunctionExpression`](/docs/kcl/types/FunctionExpression)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `params` |`[` [`Parameter`](/docs/kcl/types/Parameter) `]`| | No | +| `body` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `CallExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `callee` |[`Identifier`](/docs/kcl/types/Identifier)| An expression can be evaluated to yield a single KCL value. | No | +| `arguments` |`[` [`Expr`](/docs/kcl/types/Expr) `]`| | No | +| `optional` |`boolean`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `PipeExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `body` |`[` [`Expr`](/docs/kcl/types/Expr) `]`| | No | +| `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `PipeSubstitution`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `ArrayExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `elements` |`[` [`Expr`](/docs/kcl/types/Expr) `]`| | No | +| `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `ObjectExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `properties` |`[` [`ObjectProperty`](/docs/kcl/types/ObjectProperty) `]`| | No | +| `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `MemberExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `object` |[`MemberObject`](/docs/kcl/types/MemberObject)| An expression can be evaluated to yield a single KCL value. | No | +| `property` |[`LiteralIdentifier`](/docs/kcl/types/LiteralIdentifier)| An expression can be evaluated to yield a single KCL value. | No | +| `computed` |`boolean`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `UnaryExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `operator` |[`UnaryOperator`](/docs/kcl/types/UnaryOperator)| An expression can be evaluated to yield a single KCL value. | No | +| `argument` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `IfExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `cond` |[`Expr`](/docs/kcl/types/Expr)| An expression can be evaluated to yield a single KCL value. | No | +| `then_val` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | +| `else_ifs` |`[` [`ElseIf`](/docs/kcl/types/ElseIf) `]`| | No | +| `final_else` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- +KCL value for an optional parameter which was not given an argument. (remember, parameters are in the function declaration, arguments are in the function call/application). + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `None`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/FunctionExpression.md b/content/pages/docs/kcl/types/FunctionExpression.md new file mode 100644 index 0000000..5ad84fc --- /dev/null +++ b/content/pages/docs/kcl/types/FunctionExpression.md @@ -0,0 +1,24 @@ +--- +title: "FunctionExpression" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `params` |`[` [`Parameter`](/docs/kcl/types/Parameter) `]`| | No | +| `body` |[`Program`](/docs/kcl/types/Program)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/Identifier.md b/content/pages/docs/kcl/types/Identifier.md new file mode 100644 index 0000000..a07e5a9 --- /dev/null +++ b/content/pages/docs/kcl/types/Identifier.md @@ -0,0 +1,23 @@ +--- +title: "Identifier" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `name` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/KclValue.md b/content/pages/docs/kcl/types/KclValue.md new file mode 100644 index 0000000..6c0bf16 --- /dev/null +++ b/content/pages/docs/kcl/types/KclValue.md @@ -0,0 +1,195 @@ +--- +title: "KclValue" +excerpt: "A memory item." +layout: manual +--- + +A memory item. + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `UserVal`| | No | +| `value` |``| | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`TagIdentifier`](/docs/kcl/types#tag-identifier)| | No | +| `value` |`string`| | No | +| `info` |[`TagEngineInfo`](/docs/kcl/types/TagEngineInfo)| | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`TagDeclarator`](/docs/kcl/types#tag-declaration)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- +A plane. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Plane`| | No | +| `id` |`string`| The id of the plane. | No | +| `value` |[`PlaneType`](/docs/kcl/types/PlaneType)| A memory item. | No | +| `origin` |[`Point3d`](/docs/kcl/types/Point3d)| Origin of the plane. | No | +| `xAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane’s X axis be? | No | +| `yAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane’s Y axis be? | No | +| `zAxis` |[`Point3d`](/docs/kcl/types/Point3d)| The z-axis (normal). | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- +A face. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Face`| | No | +| `id` |`string`| The id of the face. | No | +| `value` |`string`| The tag of the face. | No | +| `xAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the face’s X axis be? | No | +| `yAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the face’s Y axis be? | No | +| `zAxis` |[`Point3d`](/docs/kcl/types/Point3d)| The z-axis (normal). | No | +| `solid` |[`Solid`](/docs/kcl/types/Solid)| The solid the face is on. | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- +An solid is a collection of extrude surfaces. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`Solid`](/docs/kcl/types/Solid)| | No | +| `id` |`string`| The id of the solid. | No | +| `value` |`[` [`ExtrudeSurface`](/docs/kcl/types/ExtrudeSurface) `]`| The extrude surfaces. | No | +| `sketch` |[`Sketch`](/docs/kcl/types/Sketch)| The sketch. | No | +| `height` |`number`| The height of the solid. | No | +| `startCapId` |`string`| The id of the extrusion start cap | No | +| `endCapId` |`string`| The id of the extrusion end cap | No | +| `edgeCuts` |`[` [`EdgeCut`](/docs/kcl/types/EdgeCut) `]`| Chamfers or fillets on this solid. | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| Metadata. | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Solids`| | No | +| `value` |`[` [`Solid`](/docs/kcl/types/Solid) `]`| | No | + + +---- +Data for an imported geometry. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`ImportedGeometry`](/docs/kcl/types/ImportedGeometry)| | No | +| `id` |`string`| The ID of the imported geometry. | No | +| `value` |`[` `string` `]`| The original file paths. | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Function`| | No | +| `expression` |[`FunctionExpression`](/docs/kcl/types/FunctionExpression)| A memory item. | No | +| `memory` |[`ProgramMemory`](/docs/kcl/types/ProgramMemory)| A memory item. | No | +| `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/LiteralIdentifier.md b/content/pages/docs/kcl/types/LiteralIdentifier.md new file mode 100644 index 0000000..654d7e5 --- /dev/null +++ b/content/pages/docs/kcl/types/LiteralIdentifier.md @@ -0,0 +1,56 @@ +--- +title: "LiteralIdentifier" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `name` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `Literal`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |[`LiteralValue`](/docs/kcl/types/LiteralValue)| | No | +| `raw` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/LiteralValue.md b/content/pages/docs/kcl/types/LiteralValue.md new file mode 100644 index 0000000..1535d50 --- /dev/null +++ b/content/pages/docs/kcl/types/LiteralValue.md @@ -0,0 +1,57 @@ +--- +title: "LiteralValue" +excerpt: "" +layout: manual +--- + + + + + +**This schema accepts any of the following:** + + +**Type:** `integer` (`int64`) + + + + + + + +---- + +**Type:** `number` (`double`) + + + + + + + +---- + +**Type:** `string` + + + + + + + +---- + +**Type:** `boolean` + + + + + + + +---- + + + + + diff --git a/content/pages/docs/kcl/types/MemberObject.md b/content/pages/docs/kcl/types/MemberObject.md new file mode 100644 index 0000000..568ab0b --- /dev/null +++ b/content/pages/docs/kcl/types/MemberObject.md @@ -0,0 +1,57 @@ +--- +title: "MemberObject" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `MemberExpression`| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `object` |[`MemberObject`](/docs/kcl/types/MemberObject)| | No | +| `property` |[`LiteralIdentifier`](/docs/kcl/types/LiteralIdentifier)| | No | +| `computed` |`boolean`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)| | No | +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `name` |`string`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/NonCodeMeta.md b/content/pages/docs/kcl/types/NonCodeMeta.md new file mode 100644 index 0000000..14b14d4 --- /dev/null +++ b/content/pages/docs/kcl/types/NonCodeMeta.md @@ -0,0 +1,22 @@ +--- +title: "NonCodeMeta" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `nonCodeNodes` |`object`| | No | +| `start` |`[` [`NonCodeNode`](/docs/kcl/types/NonCodeNode) `]`| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/NonCodeNode.md b/content/pages/docs/kcl/types/NonCodeNode.md new file mode 100644 index 0000000..2209de9 --- /dev/null +++ b/content/pages/docs/kcl/types/NonCodeNode.md @@ -0,0 +1,23 @@ +--- +title: "NonCodeNode" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `value` |[`NonCodeValue`](/docs/kcl/types/NonCodeValue)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/NonCodeValue.md b/content/pages/docs/kcl/types/NonCodeValue.md new file mode 100644 index 0000000..87a7c56 --- /dev/null +++ b/content/pages/docs/kcl/types/NonCodeValue.md @@ -0,0 +1,103 @@ +--- +title: "NonCodeValue" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + +A shebang. This is a special type of comment that is at the top of the file. It looks like this: ```python,no_run #!/usr/bin/env python ``` + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `shebang`| | No | +| `value` |`string`| | No | + + +---- +An inline comment. Here are examples: `1 + 1 // This is an inline comment`. `1 + 1 /* Here's another */`. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `inlineComment`| | No | +| `value` |`string`| | No | +| `style` |[`CommentStyle`](/docs/kcl/types/CommentStyle)| | No | + + +---- +A block comment. An example of this is the following: ```python,no_run /* This is a block comment */ 1 + 1 ``` Now this is important. The block comment is attached to the next line. This is always the case. Also the block comment doesn't have a new line above it. If it did it would be a `NewLineBlockComment`. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `blockComment`| | No | +| `value` |`string`| | No | +| `style` |[`CommentStyle`](/docs/kcl/types/CommentStyle)| | No | + + +---- +A block comment that has a new line above it. The user explicitly added a new line above the block comment. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `newLineBlockComment`| | No | +| `value` |`string`| | No | +| `style` |[`CommentStyle`](/docs/kcl/types/CommentStyle)| | No | + + +---- + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `type` |enum: `newLine`| | No | + + +---- + + + + diff --git a/content/pages/docs/kcl/types/ObjectProperty.md b/content/pages/docs/kcl/types/ObjectProperty.md new file mode 100644 index 0000000..57b1ea3 --- /dev/null +++ b/content/pages/docs/kcl/types/ObjectProperty.md @@ -0,0 +1,24 @@ +--- +title: "ObjectProperty" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `key` |[`Identifier`](/docs/kcl/types/Identifier)| | No | +| `value` |[`Expr`](/docs/kcl/types/Expr)| | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/Parameter.md b/content/pages/docs/kcl/types/Parameter.md new file mode 100644 index 0000000..7700601 --- /dev/null +++ b/content/pages/docs/kcl/types/Parameter.md @@ -0,0 +1,23 @@ +--- +title: "Parameter" +excerpt: "Parameter of a KCL function." +layout: manual +--- + +Parameter of a KCL function. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `identifier` |[`Identifier`](/docs/kcl/types/Identifier)| The parameter's label or name. | No | +| `optional` |`boolean`| Is the parameter optional? | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/Program.md b/content/pages/docs/kcl/types/Program.md new file mode 100644 index 0000000..b33b63e --- /dev/null +++ b/content/pages/docs/kcl/types/Program.md @@ -0,0 +1,25 @@ +--- +title: "Program" +excerpt: "A KCL program top level, or function body." +layout: manual +--- + +A KCL program top level, or function body. + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `body` |`[` [`BodyItem`](/docs/kcl/types/BodyItem) `]`| | No | +| `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| A KCL program top level, or function body. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/ProgramMemory.md b/content/pages/docs/kcl/types/ProgramMemory.md new file mode 100644 index 0000000..b6bd5c0 --- /dev/null +++ b/content/pages/docs/kcl/types/ProgramMemory.md @@ -0,0 +1,22 @@ +--- +title: "ProgramMemory" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `environments` |`[` [`Environment`](/docs/kcl/types/Environment) `]`| | No | +| `currentEnv` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `return` |[`KclValue`](/docs/kcl/types/KclValue)| | No | + + diff --git a/content/pages/docs/kcl/types/UnaryOperator.md b/content/pages/docs/kcl/types/UnaryOperator.md new file mode 100644 index 0000000..6a2e8fb --- /dev/null +++ b/content/pages/docs/kcl/types/UnaryOperator.md @@ -0,0 +1,41 @@ +--- +title: "UnaryOperator" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + +Negate a number. + +**enum:** `-` + + + + + + + + +---- +Negate a boolean. + +**enum:** `!` + + + + + + + + +---- + + + + diff --git a/content/pages/docs/kcl/types/VariableDeclarator.md b/content/pages/docs/kcl/types/VariableDeclarator.md new file mode 100644 index 0000000..5af68d9 --- /dev/null +++ b/content/pages/docs/kcl/types/VariableDeclarator.md @@ -0,0 +1,24 @@ +--- +title: "VariableDeclarator" +excerpt: "" +layout: manual +--- + + +**Type:** `object` + + + + + +## Properties + +| Property | Type | Description | Required | +|----------|------|-------------|----------| +| `start` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `end` |[`EnvironmentRef`](/docs/kcl/types/EnvironmentRef)| | No | +| `id` |[`Identifier`](/docs/kcl/types/Identifier)| The identifier of the variable. | No | +| `init` |[`Expr`](/docs/kcl/types/Expr)| The value of the variable. | No | +| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | + + diff --git a/content/pages/docs/kcl/types/VariableKind.md b/content/pages/docs/kcl/types/VariableKind.md new file mode 100644 index 0000000..5ae17e3 --- /dev/null +++ b/content/pages/docs/kcl/types/VariableKind.md @@ -0,0 +1,65 @@ +--- +title: "VariableKind" +excerpt: "" +layout: manual +--- + + + + + + +**This schema accepts exactly one of the following:** + +Declare a variable. + +**enum:** `let` + + + + + + + + +---- +Declare a variable that is read-only. + +**enum:** `const` + + + + + + + + +---- +Declare a function. + +**enum:** `fn` + + + + + + + + +---- +Declare a variable. + +**enum:** `var` + + + + + + + + +---- + + + +