diff --git a/.github/workflows/e2e-tests.yml b/.github/workflows/e2e-tests.yml index 9ba5a9c79..ea9fadcfc 100644 --- a/.github/workflows/e2e-tests.yml +++ b/.github/workflows/e2e-tests.yml @@ -229,10 +229,6 @@ jobs: timeout_minutes: 30 max_attempts: 3 env: - CI: true - NODE_ENV: development - VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} - VITE_KC_SKIP_AUTH: true token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} snapshottoken: ${{ secrets.KITTYCAD_API_TOKEN }} @@ -377,11 +373,7 @@ jobs: timeout_minutes: 45 max_attempts: 15 env: - CI: true FAIL_ON_CONSOLE_ERRORS: true - NODE_ENV: development - VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} - VITE_KC_SKIP_AUTH: true token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} - uses: actions/upload-artifact@v4 diff --git a/docs/kcl/consts.md b/docs/kcl/consts.md index c204f1d77..385c7bf46 100644 --- a/docs/kcl/consts.md +++ b/docs/kcl/consts.md @@ -9,13 +9,9 @@ layout: manual ### `std` -- [`HALF_TURN`](/docs/kcl/consts/std-HALF_TURN) -- [`QUARTER_TURN`](/docs/kcl/consts/std-QUARTER_TURN) -- [`THREE_QUARTER_TURN`](/docs/kcl/consts/std-THREE_QUARTER_TURN) - [`XY`](/docs/kcl/consts/std-XY) - [`XZ`](/docs/kcl/consts/std-XZ) - [`YZ`](/docs/kcl/consts/std-YZ) -- [`ZERO`](/docs/kcl/consts/std-ZERO) ### `std::math` @@ -23,3 +19,10 @@ layout: manual - [`PI`](/docs/kcl/consts/std-math-PI) - [`TAU`](/docs/kcl/consts/std-math-TAU) +### `std::turns` + +- [`HALF_TURN`](/docs/kcl/consts/std-turns-HALF_TURN) +- [`QUARTER_TURN`](/docs/kcl/consts/std-turns-QUARTER_TURN) +- [`THREE_QUARTER_TURN`](/docs/kcl/consts/std-turns-THREE_QUARTER_TURN) +- [`ZERO`](/docs/kcl/consts/std-turns-ZERO) + diff --git a/docs/kcl/consts/std-HALF_TURN.md b/docs/kcl/consts/std-HALF_TURN.md deleted file mode 100644 index 65a69a56e..000000000 --- a/docs/kcl/consts/std-HALF_TURN.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -title: "std::HALF_TURN" -excerpt: "" -layout: manual ---- - - - - - -```js -std::HALF_TURN: number(deg) = 180deg -``` - - diff --git a/docs/kcl/consts/std-QUARTER_TURN.md b/docs/kcl/consts/std-QUARTER_TURN.md deleted file mode 100644 index 7fb657840..000000000 --- a/docs/kcl/consts/std-QUARTER_TURN.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -title: "std::QUARTER_TURN" -excerpt: "" -layout: manual ---- - - - - - -```js -std::QUARTER_TURN: number(deg) = 90deg -``` - - diff --git a/docs/kcl/consts/std-THREE_QUARTER_TURN.md b/docs/kcl/consts/std-THREE_QUARTER_TURN.md deleted file mode 100644 index 4d66e4d2f..000000000 --- a/docs/kcl/consts/std-THREE_QUARTER_TURN.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -title: "std::THREE_QUARTER_TURN" -excerpt: "" -layout: manual ---- - - - - - -```js -std::THREE_QUARTER_TURN: number(deg) = 270deg -``` - - diff --git a/docs/kcl/consts/std-ZERO.md b/docs/kcl/consts/std-ZERO.md deleted file mode 100644 index 0002979af..000000000 --- a/docs/kcl/consts/std-ZERO.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -title: "std::ZERO" -excerpt: "" -layout: manual ---- - - - - - -```js -std::ZERO: number = 0 -``` - - diff --git a/docs/kcl/consts/std-turns-HALF_TURN.md b/docs/kcl/consts/std-turns-HALF_TURN.md new file mode 100644 index 000000000..b019c2a5d --- /dev/null +++ b/docs/kcl/consts/std-turns-HALF_TURN.md @@ -0,0 +1,15 @@ +--- +title: "std::turns::HALF_TURN" +excerpt: "" +layout: manual +--- + + + + + +```js +std::turns::HALF_TURN: number(deg) = 180deg +``` + + diff --git a/docs/kcl/consts/std-turns-QUARTER_TURN.md b/docs/kcl/consts/std-turns-QUARTER_TURN.md new file mode 100644 index 000000000..baf369a91 --- /dev/null +++ b/docs/kcl/consts/std-turns-QUARTER_TURN.md @@ -0,0 +1,15 @@ +--- +title: "std::turns::QUARTER_TURN" +excerpt: "" +layout: manual +--- + + + + + +```js +std::turns::QUARTER_TURN: number(deg) = 90deg +``` + + diff --git a/docs/kcl/consts/std-turns-THREE_QUARTER_TURN.md b/docs/kcl/consts/std-turns-THREE_QUARTER_TURN.md new file mode 100644 index 000000000..11ce8e342 --- /dev/null +++ b/docs/kcl/consts/std-turns-THREE_QUARTER_TURN.md @@ -0,0 +1,15 @@ +--- +title: "std::turns::THREE_QUARTER_TURN" +excerpt: "" +layout: manual +--- + + + + + +```js +std::turns::THREE_QUARTER_TURN: number(deg) = 270deg +``` + + diff --git a/docs/kcl/consts/std-turns-ZERO.md b/docs/kcl/consts/std-turns-ZERO.md new file mode 100644 index 000000000..b32ff42de --- /dev/null +++ b/docs/kcl/consts/std-turns-ZERO.md @@ -0,0 +1,15 @@ +--- +title: "std::turns::ZERO" +excerpt: "" +layout: manual +--- + + + + + +```js +std::turns::ZERO: number = 0 +``` + + diff --git a/docs/kcl/index.md b/docs/kcl/index.md index 5b73d3ec1..97bf13f51 100644 --- a/docs/kcl/index.md +++ b/docs/kcl/index.md @@ -23,19 +23,15 @@ layout: manual * [`tag`](kcl/types/tag) * **std** * [`Face`](kcl/types/Face) - * [`HALF_TURN`](kcl/consts/std-HALF_TURN) * [`Helix`](kcl/types/Helix) * [`Plane`](kcl/types/Plane) * [`Point2d`](kcl/types/Point2d) * [`Point3d`](kcl/types/Point3d) - * [`QUARTER_TURN`](kcl/consts/std-QUARTER_TURN) * [`Sketch`](kcl/types/Sketch) * [`Solid`](kcl/types/Solid) - * [`THREE_QUARTER_TURN`](kcl/consts/std-THREE_QUARTER_TURN) * [`XY`](kcl/consts/std-XY) * [`XZ`](kcl/consts/std-XZ) * [`YZ`](kcl/consts/std-YZ) - * [`ZERO`](kcl/consts/std-ZERO) * [`abs`](kcl/abs) * [`acos`](kcl/acos) * [`angleToMatchLengthX`](kcl/angleToMatchLengthX) @@ -146,3 +142,8 @@ layout: manual * [`tan`](kcl/std-math-tan) * **std::sketch** * [`circle`](kcl/std-sketch-circle) +* **std::turns** + * [`turns::HALF_TURN`](kcl/consts/std-turns-HALF_TURN) + * [`turns::QUARTER_TURN`](kcl/consts/std-turns-QUARTER_TURN) + * [`turns::THREE_QUARTER_TURN`](kcl/consts/std-turns-THREE_QUARTER_TURN) + * [`turns::ZERO`](kcl/consts/std-turns-ZERO) diff --git a/docs/kcl/rotate.md b/docs/kcl/rotate.md index bd74dea02..0f1276a65 100644 --- a/docs/kcl/rotate.md +++ b/docs/kcl/rotate.md @@ -6,6 +6,10 @@ layout: manual Rotate a solid or a sketch. +This is really useful for assembling parts together. You can create a part and then rotate it to the correct orientation. + +For sketches, you can use this to rotate a sketch and then loft it with another sketch. + ### Using Roll, Pitch, and Yaw When rotating a part in 3D space, "roll," "pitch," and "yaw" refer to the three rotational axes used to describe its orientation: roll is rotation around the longitudinal axis (front-to-back), pitch is rotation around the lateral axis (wing-to-wing), and yaw is rotation around the vertical axis (up-down); essentially, it's like tilting the part on its side (roll), tipping the nose up or down (pitch), and turning it left or right (yaw). @@ -166,7 +170,7 @@ fn square() { profile001 = square() profile002 = square() - |> translate(translate = [0, 0, 20]) + |> translate(x = 0, y = 0, z = 20) |> rotate(axis = [0, 0, 1.0], angle = 45) loft([profile001, profile002]) diff --git a/docs/kcl/scale.md b/docs/kcl/scale.md index ea13d8d8b..c3d477fac 100644 --- a/docs/kcl/scale.md +++ b/docs/kcl/scale.md @@ -6,6 +6,10 @@ layout: manual Scale a solid or a sketch. +This is really useful for resizing parts. You can create a part and then scale it to the correct size. + +For sketches, you can use this to scale a sketch and then loft it with another sketch. + By default the transform is applied in local sketch axis, therefore the origin will not move. If you want to apply the transform in global space, set `global` to `true`. The origin of the model will move. If the model is not centered on origin and you scale globally it will look like the model moves and gets bigger at the same time. Say you have a square `(1,1) - (1,2) - (2,2) - (2,1)` and you scale by 2 globally it will become `(2,2) - (2,4)`...etc so the origin has moved from `(1.5, 1.5)` to `(2,2)`. @@ -13,7 +17,9 @@ If you want to apply the transform in global space, set `global` to `true`. The ```js scale( objects: SolidOrSketchOrImportedGeometry, - scale: [number], + x: number, + y: number, + z: number, global?: bool, ): SolidOrSketchOrImportedGeometry ``` @@ -24,7 +30,9 @@ scale( | Name | Type | Description | Required | |----------|------|-------------|----------| | `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to scale. | Yes | -| `scale` | [`[number]`](/docs/kcl/types/number) | The scale factor for the x, y, and z axes. | Yes | +| `x` | [`number`](/docs/kcl/types/number) | The scale factor for the x axis. | Yes | +| `y` | [`number`](/docs/kcl/types/number) | The scale factor for the y axis. | Yes | +| `z` | [`number`](/docs/kcl/types/number) | The scale factor for the z axis. | Yes | | `global` | [`bool`](/docs/kcl/types/bool) | If true, the transform is applied in global space. The origin of the model will move. By default, the transform is applied in local sketch axis, therefore the origin will not move. | No | ### Returns @@ -54,7 +62,7 @@ sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) - |> scale(scale = [1.0, 1.0, 2.5]) + |> scale(x = 1.0, y = 1.0, z = 2.5) ``` ![Rendered example of scale 0]() @@ -66,7 +74,7 @@ sweepSketch = startSketchOn(XY) import "tests/inputs/cube.sldprt" as cube cube - |> scale(scale = [1.0, 1.0, 2.5]) + |> scale(x = 1.0, y = 1.0, z = 2.5) ``` ![Rendered example of scale 1]() @@ -100,7 +108,12 @@ sweepPath = startProfileAt([0, 0], sketch002) parts = sweep([rectangleSketch, circleSketch], path = sweepPath) // Scale the sweep. -scale(parts, scale = [1.0, 1.0, 0.5]) +scale( + parts, + x = 1.0, + y = 1.0, + z = 0.5, +) ``` ![Rendered example of scale 2]() diff --git a/docs/kcl/std.json b/docs/kcl/std.json index 678b4dfb2..660d10f58 100644 --- a/docs/kcl/std.json +++ b/docs/kcl/std.json @@ -253490,7 +253490,7 @@ { "name": "rotate", "summary": "Rotate a solid or a sketch.", - "description": "### Using Roll, Pitch, and Yaw\n\nWhen rotating a part in 3D space, \"roll,\" \"pitch,\" and \"yaw\" refer to the three rotational axes used to describe its orientation: roll is rotation around the longitudinal axis (front-to-back), pitch is rotation around the lateral axis (wing-to-wing), and yaw is rotation around the vertical axis (up-down); essentially, it's like tilting the part on its side (roll), tipping the nose up or down (pitch), and turning it left or right (yaw).\n\nSo, in the context of a 3D model:\n\n- **Roll**: Imagine spinning a pencil on its tip - that's a roll movement.\n\n- **Pitch**: Think of a seesaw motion, where the object tilts up or down along its side axis.\n\n- **Yaw**: Like turning your head left or right, this is a rotation around the vertical axis\n\n### Using an Axis and Angle\n\nWhen rotating a part around an axis, you specify the axis of rotation and the angle of rotation.", + "description": "This is really useful for assembling parts together. You can create a part and then rotate it to the correct orientation.\n\nFor sketches, you can use this to rotate a sketch and then loft it with another sketch.\n\n### Using Roll, Pitch, and Yaw\n\nWhen rotating a part in 3D space, \"roll,\" \"pitch,\" and \"yaw\" refer to the three rotational axes used to describe its orientation: roll is rotation around the longitudinal axis (front-to-back), pitch is rotation around the lateral axis (wing-to-wing), and yaw is rotation around the vertical axis (up-down); essentially, it's like tilting the part on its side (roll), tipping the nose up or down (pitch), and turning it left or right (yaw).\n\nSo, in the context of a 3D model:\n\n- **Roll**: Imagine spinning a pencil on its tip - that's a roll movement.\n\n- **Pitch**: Think of a seesaw motion, where the object tilts up or down along its side axis.\n\n- **Yaw**: Like turning your head left or right, this is a rotation around the vertical axis\n\n### Using an Axis and Angle\n\nWhen rotating a part around an axis, you specify the axis of rotation and the angle of rotation.", "tags": [], "keywordArguments": true, "args": [ @@ -266424,7 +266424,7 @@ "// Rotate a pipe about an axis with an angle.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> rotate(axis = [0, 0, 1.0], angle = 90)", "// Rotate an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> rotate(axis = [0, 0, 1.0], angle = 90)", "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Rotate the sweeps.\nrotate(parts, axis = [0, 0, 1.0], angle = 90)", - "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(x = 0, y = 0, z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" ] }, { @@ -266472,7 +266472,7 @@ { "name": "scale", "summary": "Scale a solid or a sketch.", - "description": "By default the transform is applied in local sketch axis, therefore the origin will not move.\n\nIf you want to apply the transform in global space, set `global` to `true`. The origin of the model will move. If the model is not centered on origin and you scale globally it will look like the model moves and gets bigger at the same time. Say you have a square `(1,1) - (1,2) - (2,2) - (2,1)` and you scale by 2 globally it will become `(2,2) - (2,4)`...etc so the origin has moved from `(1.5, 1.5)` to `(2,2)`.", + "description": "This is really useful for resizing parts. You can create a part and then scale it to the correct size.\n\nFor sketches, you can use this to scale a sketch and then loft it with another sketch.\n\nBy default the transform is applied in local sketch axis, therefore the origin will not move.\n\nIf you want to apply the transform in global space, set `global` to `true`. The origin of the model will move. If the model is not centered on origin and you scale globally it will look like the model moves and gets bigger at the same time. Say you have a square `(1,1) - (1,2) - (2,2) - (2,1)` and you scale by 2 globally it will become `(2,2) - (2,4)`...etc so the origin has moved from `(1.5, 1.5)` to `(2,2)`.", "tags": [], "keywordArguments": true, "args": [ @@ -268144,18 +268144,13 @@ "labelRequired": false }, { - "name": "scale", - "type": "[number]", + "name": "x", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Array_size_3_of_double", - "type": "array", - "items": { - "type": "number", - "format": "double" - }, - "maxItems": 3, - "minItems": 3, + "title": "double", + "type": "number", + "format": "double", "definitions": { "Solid": { "type": "object", @@ -269742,7 +269737,3201 @@ }, "required": true, "includeInSnippet": true, - "description": "The scale factor for the x, y, and z axes.", + "description": "The scale factor for the x axis.", + "labelRequired": true + }, + { + "name": "y", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "double", + "type": "number", + "format": "double", + "definitions": { + "Solid": { + "type": "object", + "required": [ + "artifactId", + "height", + "id", + "sketch", + "units", + "value" + ], + "properties": { + "id": { + "description": "The id of the solid.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID of the solid. Unlike `id`, this doesn't change.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The extrude surfaces.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ExtrudeSurface" + } + }, + "sketch": { + "description": "The sketch.", + "allOf": [ + { + "$ref": "#/components/schemas/Sketch" + } + ] + }, + "height": { + "description": "The height of the solid.", + "type": "number", + "format": "double" + }, + "startCapId": { + "description": "The id of the extrusion start cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "endCapId": { + "description": "The id of the extrusion end cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "edgeCuts": { + "description": "Chamfers or fillets on this solid.", + "type": "array", + "items": { + "$ref": "#/components/schemas/EdgeCut" + } + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "ArtifactId": { + "type": "string", + "format": "uuid" + }, + "ExtrudeSurface": { + "description": "An extrude surface.", + "oneOf": [ + { + "description": "An extrude plane.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudePlane" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "An extruded arc.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudeArc" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "faceId": { + "description": "The id for the chamfer surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "faceId": { + "description": "The id for the fillet surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + } + ] + }, + "TagDeclarator": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + }, + "digest": { + "type": "array", + "items": { + "type": "integer", + "format": "uint8", + "minimum": 0.0 + }, + "maxItems": 32, + "minItems": 32, + "nullable": true + }, + "start": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "end": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + } + } + }, + "SourceRange": { + "description": "The first two items are the start and end points (byte offsets from the start of the file). The third item is whether the source range belongs to the 'main' file, i.e., the file currently being rendered/displayed in the editor.", + "type": "array", + "items": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "maxItems": 3, + "minItems": 3 + }, + "Sketch": { + "type": "object", + "required": [ + "artifactId", + "id", + "on", + "originalId", + "paths", + "start", + "units" + ], + "properties": { + "id": { + "description": "The id of the sketch (this will change when the engine's reference to it changes).", + "type": "string", + "format": "uuid" + }, + "paths": { + "description": "The paths in the sketch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Path" + } + }, + "on": { + "description": "What the sketch is on (can be a plane or a face).", + "allOf": [ + { + "$ref": "#/components/schemas/SketchSurface" + } + ] + }, + "start": { + "description": "The starting path.", + "allOf": [ + { + "$ref": "#/components/schemas/BasePath" + } + ] + }, + "tags": { + "description": "Tag identifiers that have been declared in this sketch.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/TagIdentifier" + } + }, + "artifactId": { + "description": "The original id of the sketch. This stays the same even if the sketch is is sketched on face etc.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "originalId": { + "type": "string", + "format": "uuid" + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "Path": { + "description": "A path.", + "oneOf": [ + { + "description": "A path that goes to a point.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ToPoint" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment that goes to a point", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArcTo" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArc" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "a complete arc", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Circle" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "the arc's radius", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "arc's direction This is used to compute the tangential angle.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "CircleThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ArcThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the arc (base on the end of previous segment)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the arc (interior kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the arc (end kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A path that is horizontal.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units", + "x" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Horizontal" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "An angled line to.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "AngledLineTo" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "y": { + "description": "The y coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Base" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A circular arc, not necessarily tangential to the current point.", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Arc" + ] + }, + "center": { + "description": "Center of the circle that this arc is drawn on.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "Radius of the circle that this arc is drawn on.", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "True if the arc is counterclockwise.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + } + ] + }, + "UnitLen": { + "description": "A unit of length.", + "oneOf": [ + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Mm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Cm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "M" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Inches" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Feet" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Yards" + ] + } + } + } + ] + }, + "GeoMeta": { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "id", + "sourceRange" + ], + "properties": { + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + "SketchSurface": { + "description": "A sketch type.", + "oneOf": [ + { + "type": "object", + "required": [ + "artifactId", + "id", + "origin", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "plane" + ] + }, + "id": { + "description": "The id of the plane.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "$ref": "#/components/schemas/PlaneType" + }, + "origin": { + "description": "Origin of the plane.", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "xAxis": { + "description": "What should the plane's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the plane's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + { + "description": "A face.", + "type": "object", + "required": [ + "artifactId", + "id", + "solid", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "face" + ] + }, + "id": { + "description": "The id of the face.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The tag of the face.", + "type": "string" + }, + "xAxis": { + "description": "What should the face's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the face's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "solid": { + "description": "The solid the face is on.", + "allOf": [ + { + "$ref": "#/components/schemas/Solid" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + } + ] + }, + "PlaneType": { + "description": "Type for a plane.", + "oneOf": [ + { + "type": "string", + "enum": [ + "XY", + "XZ", + "YZ" + ] + }, + { + "description": "A custom plane.", + "type": "string", + "enum": [ + "Custom" + ] + }, + { + "description": "A custom plane which has not been sent to the engine. It must be sent before it is used.", + "type": "string", + "enum": [ + "Uninit" + ] + } + ] + }, + "Point3d": { + "type": "object", + "required": [ + "x", + "y", + "z" + ], + "properties": { + "x": { + "type": "number", + "format": "double" + }, + "y": { + "type": "number", + "format": "double" + }, + "z": { + "type": "number", + "format": "double" + } + } + }, + "BasePath": { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "units" + ], + "properties": { + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + "TagIdentifier": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + } + } + }, + "EdgeCut": { + "description": "A fillet or a chamfer.", + "oneOf": [ + { + "description": "A fillet.", + "type": "object", + "required": [ + "edgeId", + "id", + "radius", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "id": { + "description": "The id of the engine command that called this fillet.", + "type": "string", + "format": "uuid" + }, + "radius": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to fillet.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + }, + { + "description": "A chamfer.", + "type": "object", + "required": [ + "edgeId", + "id", + "length", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "id": { + "description": "The id of the engine command that called this chamfer.", + "type": "string", + "format": "uuid" + }, + "length": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to chamfer.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + } + ] + } + } + }, + "required": true, + "includeInSnippet": true, + "description": "The scale factor for the y axis.", + "labelRequired": true + }, + { + "name": "z", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "double", + "type": "number", + "format": "double", + "definitions": { + "Solid": { + "type": "object", + "required": [ + "artifactId", + "height", + "id", + "sketch", + "units", + "value" + ], + "properties": { + "id": { + "description": "The id of the solid.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID of the solid. Unlike `id`, this doesn't change.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The extrude surfaces.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ExtrudeSurface" + } + }, + "sketch": { + "description": "The sketch.", + "allOf": [ + { + "$ref": "#/components/schemas/Sketch" + } + ] + }, + "height": { + "description": "The height of the solid.", + "type": "number", + "format": "double" + }, + "startCapId": { + "description": "The id of the extrusion start cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "endCapId": { + "description": "The id of the extrusion end cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "edgeCuts": { + "description": "Chamfers or fillets on this solid.", + "type": "array", + "items": { + "$ref": "#/components/schemas/EdgeCut" + } + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "ArtifactId": { + "type": "string", + "format": "uuid" + }, + "ExtrudeSurface": { + "description": "An extrude surface.", + "oneOf": [ + { + "description": "An extrude plane.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudePlane" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "An extruded arc.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudeArc" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "faceId": { + "description": "The id for the chamfer surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "faceId": { + "description": "The id for the fillet surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + } + ] + }, + "TagDeclarator": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + }, + "digest": { + "type": "array", + "items": { + "type": "integer", + "format": "uint8", + "minimum": 0.0 + }, + "maxItems": 32, + "minItems": 32, + "nullable": true + }, + "start": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "end": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + } + } + }, + "SourceRange": { + "description": "The first two items are the start and end points (byte offsets from the start of the file). The third item is whether the source range belongs to the 'main' file, i.e., the file currently being rendered/displayed in the editor.", + "type": "array", + "items": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "maxItems": 3, + "minItems": 3 + }, + "Sketch": { + "type": "object", + "required": [ + "artifactId", + "id", + "on", + "originalId", + "paths", + "start", + "units" + ], + "properties": { + "id": { + "description": "The id of the sketch (this will change when the engine's reference to it changes).", + "type": "string", + "format": "uuid" + }, + "paths": { + "description": "The paths in the sketch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Path" + } + }, + "on": { + "description": "What the sketch is on (can be a plane or a face).", + "allOf": [ + { + "$ref": "#/components/schemas/SketchSurface" + } + ] + }, + "start": { + "description": "The starting path.", + "allOf": [ + { + "$ref": "#/components/schemas/BasePath" + } + ] + }, + "tags": { + "description": "Tag identifiers that have been declared in this sketch.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/TagIdentifier" + } + }, + "artifactId": { + "description": "The original id of the sketch. This stays the same even if the sketch is is sketched on face etc.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "originalId": { + "type": "string", + "format": "uuid" + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "Path": { + "description": "A path.", + "oneOf": [ + { + "description": "A path that goes to a point.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ToPoint" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment that goes to a point", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArcTo" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArc" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "a complete arc", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Circle" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "the arc's radius", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "arc's direction This is used to compute the tangential angle.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "CircleThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ArcThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the arc (base on the end of previous segment)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the arc (interior kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the arc (end kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A path that is horizontal.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units", + "x" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Horizontal" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "An angled line to.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "AngledLineTo" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "y": { + "description": "The y coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Base" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A circular arc, not necessarily tangential to the current point.", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Arc" + ] + }, + "center": { + "description": "Center of the circle that this arc is drawn on.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "Radius of the circle that this arc is drawn on.", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "True if the arc is counterclockwise.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + } + ] + }, + "UnitLen": { + "description": "A unit of length.", + "oneOf": [ + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Mm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Cm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "M" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Inches" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Feet" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Yards" + ] + } + } + } + ] + }, + "GeoMeta": { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "id", + "sourceRange" + ], + "properties": { + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + "SketchSurface": { + "description": "A sketch type.", + "oneOf": [ + { + "type": "object", + "required": [ + "artifactId", + "id", + "origin", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "plane" + ] + }, + "id": { + "description": "The id of the plane.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "$ref": "#/components/schemas/PlaneType" + }, + "origin": { + "description": "Origin of the plane.", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "xAxis": { + "description": "What should the plane's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the plane's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + { + "description": "A face.", + "type": "object", + "required": [ + "artifactId", + "id", + "solid", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "face" + ] + }, + "id": { + "description": "The id of the face.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The tag of the face.", + "type": "string" + }, + "xAxis": { + "description": "What should the face's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the face's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "solid": { + "description": "The solid the face is on.", + "allOf": [ + { + "$ref": "#/components/schemas/Solid" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + } + ] + }, + "PlaneType": { + "description": "Type for a plane.", + "oneOf": [ + { + "type": "string", + "enum": [ + "XY", + "XZ", + "YZ" + ] + }, + { + "description": "A custom plane.", + "type": "string", + "enum": [ + "Custom" + ] + }, + { + "description": "A custom plane which has not been sent to the engine. It must be sent before it is used.", + "type": "string", + "enum": [ + "Uninit" + ] + } + ] + }, + "Point3d": { + "type": "object", + "required": [ + "x", + "y", + "z" + ], + "properties": { + "x": { + "type": "number", + "format": "double" + }, + "y": { + "type": "number", + "format": "double" + }, + "z": { + "type": "number", + "format": "double" + } + } + }, + "BasePath": { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "units" + ], + "properties": { + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + "TagIdentifier": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + } + } + }, + "EdgeCut": { + "description": "A fillet or a chamfer.", + "oneOf": [ + { + "description": "A fillet.", + "type": "object", + "required": [ + "edgeId", + "id", + "radius", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "id": { + "description": "The id of the engine command that called this fillet.", + "type": "string", + "format": "uuid" + }, + "radius": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to fillet.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + }, + { + "description": "A chamfer.", + "type": "object", + "required": [ + "edgeId", + "id", + "length", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "id": { + "description": "The id of the engine command that called this chamfer.", + "type": "string", + "format": "uuid" + }, + "length": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to chamfer.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + } + ] + } + } + }, + "required": true, + "includeInSnippet": true, + "description": "The scale factor for the z axis.", "labelRequired": true }, { @@ -273011,9 +276200,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Scale a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> scale(scale = [1.0, 1.0, 2.5])", - "// Scale an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> scale(scale = [1.0, 1.0, 2.5])", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(parts, scale = [1.0, 1.0, 0.5])" + "// Scale a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> scale(x = 1.0, y = 1.0, z = 2.5)", + "// Scale an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> scale(x = 1.0, y = 1.0, z = 2.5)", + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(\n parts,\n x = 1.0,\n y = 1.0,\n z = 0.5,\n)" ] }, { @@ -321550,7 +324739,7 @@ { "name": "translate", "summary": "Move a solid or a sketch.", - "description": "", + "description": "This is really useful for assembling parts together. You can create a part and then move it to the correct location.\n\nTranslate is really useful for sketches if you want to move a sketch and then rotate it using the `rotate` function to create a loft.", "tags": [], "keywordArguments": true, "args": [ @@ -323222,18 +326411,13 @@ "labelRequired": false }, { - "name": "translate", - "type": "[number]", + "name": "x", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Array_size_3_of_double", - "type": "array", - "items": { - "type": "number", - "format": "double" - }, - "maxItems": 3, - "minItems": 3, + "title": "double", + "type": "number", + "format": "double", "definitions": { "Solid": { "type": "object", @@ -324820,7 +328004,3201 @@ }, "required": true, "includeInSnippet": true, - "description": "The amount to move the solid or sketch in all three axes.", + "description": "The amount to move the solid or sketch along the x axis.", + "labelRequired": true + }, + { + "name": "y", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "double", + "type": "number", + "format": "double", + "definitions": { + "Solid": { + "type": "object", + "required": [ + "artifactId", + "height", + "id", + "sketch", + "units", + "value" + ], + "properties": { + "id": { + "description": "The id of the solid.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID of the solid. Unlike `id`, this doesn't change.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The extrude surfaces.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ExtrudeSurface" + } + }, + "sketch": { + "description": "The sketch.", + "allOf": [ + { + "$ref": "#/components/schemas/Sketch" + } + ] + }, + "height": { + "description": "The height of the solid.", + "type": "number", + "format": "double" + }, + "startCapId": { + "description": "The id of the extrusion start cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "endCapId": { + "description": "The id of the extrusion end cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "edgeCuts": { + "description": "Chamfers or fillets on this solid.", + "type": "array", + "items": { + "$ref": "#/components/schemas/EdgeCut" + } + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "ArtifactId": { + "type": "string", + "format": "uuid" + }, + "ExtrudeSurface": { + "description": "An extrude surface.", + "oneOf": [ + { + "description": "An extrude plane.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudePlane" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "An extruded arc.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudeArc" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "faceId": { + "description": "The id for the chamfer surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "faceId": { + "description": "The id for the fillet surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + } + ] + }, + "TagDeclarator": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + }, + "digest": { + "type": "array", + "items": { + "type": "integer", + "format": "uint8", + "minimum": 0.0 + }, + "maxItems": 32, + "minItems": 32, + "nullable": true + }, + "start": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "end": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + } + } + }, + "SourceRange": { + "description": "The first two items are the start and end points (byte offsets from the start of the file). The third item is whether the source range belongs to the 'main' file, i.e., the file currently being rendered/displayed in the editor.", + "type": "array", + "items": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "maxItems": 3, + "minItems": 3 + }, + "Sketch": { + "type": "object", + "required": [ + "artifactId", + "id", + "on", + "originalId", + "paths", + "start", + "units" + ], + "properties": { + "id": { + "description": "The id of the sketch (this will change when the engine's reference to it changes).", + "type": "string", + "format": "uuid" + }, + "paths": { + "description": "The paths in the sketch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Path" + } + }, + "on": { + "description": "What the sketch is on (can be a plane or a face).", + "allOf": [ + { + "$ref": "#/components/schemas/SketchSurface" + } + ] + }, + "start": { + "description": "The starting path.", + "allOf": [ + { + "$ref": "#/components/schemas/BasePath" + } + ] + }, + "tags": { + "description": "Tag identifiers that have been declared in this sketch.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/TagIdentifier" + } + }, + "artifactId": { + "description": "The original id of the sketch. This stays the same even if the sketch is is sketched on face etc.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "originalId": { + "type": "string", + "format": "uuid" + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "Path": { + "description": "A path.", + "oneOf": [ + { + "description": "A path that goes to a point.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ToPoint" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment that goes to a point", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArcTo" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArc" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "a complete arc", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Circle" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "the arc's radius", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "arc's direction This is used to compute the tangential angle.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "CircleThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ArcThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the arc (base on the end of previous segment)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the arc (interior kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the arc (end kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A path that is horizontal.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units", + "x" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Horizontal" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "An angled line to.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "AngledLineTo" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "y": { + "description": "The y coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Base" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A circular arc, not necessarily tangential to the current point.", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Arc" + ] + }, + "center": { + "description": "Center of the circle that this arc is drawn on.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "Radius of the circle that this arc is drawn on.", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "True if the arc is counterclockwise.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + } + ] + }, + "UnitLen": { + "description": "A unit of length.", + "oneOf": [ + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Mm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Cm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "M" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Inches" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Feet" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Yards" + ] + } + } + } + ] + }, + "GeoMeta": { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "id", + "sourceRange" + ], + "properties": { + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + "SketchSurface": { + "description": "A sketch type.", + "oneOf": [ + { + "type": "object", + "required": [ + "artifactId", + "id", + "origin", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "plane" + ] + }, + "id": { + "description": "The id of the plane.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "$ref": "#/components/schemas/PlaneType" + }, + "origin": { + "description": "Origin of the plane.", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "xAxis": { + "description": "What should the plane's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the plane's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + { + "description": "A face.", + "type": "object", + "required": [ + "artifactId", + "id", + "solid", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "face" + ] + }, + "id": { + "description": "The id of the face.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The tag of the face.", + "type": "string" + }, + "xAxis": { + "description": "What should the face's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the face's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "solid": { + "description": "The solid the face is on.", + "allOf": [ + { + "$ref": "#/components/schemas/Solid" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + } + ] + }, + "PlaneType": { + "description": "Type for a plane.", + "oneOf": [ + { + "type": "string", + "enum": [ + "XY", + "XZ", + "YZ" + ] + }, + { + "description": "A custom plane.", + "type": "string", + "enum": [ + "Custom" + ] + }, + { + "description": "A custom plane which has not been sent to the engine. It must be sent before it is used.", + "type": "string", + "enum": [ + "Uninit" + ] + } + ] + }, + "Point3d": { + "type": "object", + "required": [ + "x", + "y", + "z" + ], + "properties": { + "x": { + "type": "number", + "format": "double" + }, + "y": { + "type": "number", + "format": "double" + }, + "z": { + "type": "number", + "format": "double" + } + } + }, + "BasePath": { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "units" + ], + "properties": { + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + "TagIdentifier": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + } + } + }, + "EdgeCut": { + "description": "A fillet or a chamfer.", + "oneOf": [ + { + "description": "A fillet.", + "type": "object", + "required": [ + "edgeId", + "id", + "radius", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "id": { + "description": "The id of the engine command that called this fillet.", + "type": "string", + "format": "uuid" + }, + "radius": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to fillet.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + }, + { + "description": "A chamfer.", + "type": "object", + "required": [ + "edgeId", + "id", + "length", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "id": { + "description": "The id of the engine command that called this chamfer.", + "type": "string", + "format": "uuid" + }, + "length": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to chamfer.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + } + ] + } + } + }, + "required": true, + "includeInSnippet": true, + "description": "The amount to move the solid or sketch along the y axis.", + "labelRequired": true + }, + { + "name": "z", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "double", + "type": "number", + "format": "double", + "definitions": { + "Solid": { + "type": "object", + "required": [ + "artifactId", + "height", + "id", + "sketch", + "units", + "value" + ], + "properties": { + "id": { + "description": "The id of the solid.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID of the solid. Unlike `id`, this doesn't change.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The extrude surfaces.", + "type": "array", + "items": { + "$ref": "#/components/schemas/ExtrudeSurface" + } + }, + "sketch": { + "description": "The sketch.", + "allOf": [ + { + "$ref": "#/components/schemas/Sketch" + } + ] + }, + "height": { + "description": "The height of the solid.", + "type": "number", + "format": "double" + }, + "startCapId": { + "description": "The id of the extrusion start cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "endCapId": { + "description": "The id of the extrusion end cap", + "type": "string", + "format": "uuid", + "nullable": true + }, + "edgeCuts": { + "description": "Chamfers or fillets on this solid.", + "type": "array", + "items": { + "$ref": "#/components/schemas/EdgeCut" + } + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "ArtifactId": { + "type": "string", + "format": "uuid" + }, + "ExtrudeSurface": { + "description": "An extrude surface.", + "oneOf": [ + { + "description": "An extrude plane.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudePlane" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "An extruded arc.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "extrudeArc" + ] + }, + "faceId": { + "description": "The face id for the extrude plane.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "faceId": { + "description": "The id for the chamfer surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "faceId", + "id", + "sourceRange", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "faceId": { + "description": "The id for the fillet surface.", + "type": "string", + "format": "uuid" + }, + "tag": { + "description": "The tag.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + } + ] + }, + "TagDeclarator": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + }, + "digest": { + "type": "array", + "items": { + "type": "integer", + "format": "uint8", + "minimum": 0.0 + }, + "maxItems": 32, + "minItems": 32, + "nullable": true + }, + "start": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "end": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + } + } + }, + "SourceRange": { + "description": "The first two items are the start and end points (byte offsets from the start of the file). The third item is whether the source range belongs to the 'main' file, i.e., the file currently being rendered/displayed in the editor.", + "type": "array", + "items": { + "type": "integer", + "format": "uint", + "minimum": 0.0 + }, + "maxItems": 3, + "minItems": 3 + }, + "Sketch": { + "type": "object", + "required": [ + "artifactId", + "id", + "on", + "originalId", + "paths", + "start", + "units" + ], + "properties": { + "id": { + "description": "The id of the sketch (this will change when the engine's reference to it changes).", + "type": "string", + "format": "uuid" + }, + "paths": { + "description": "The paths in the sketch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Path" + } + }, + "on": { + "description": "What the sketch is on (can be a plane or a face).", + "allOf": [ + { + "$ref": "#/components/schemas/SketchSurface" + } + ] + }, + "start": { + "description": "The starting path.", + "allOf": [ + { + "$ref": "#/components/schemas/BasePath" + } + ] + }, + "tags": { + "description": "Tag identifiers that have been declared in this sketch.", + "type": "object", + "additionalProperties": { + "$ref": "#/components/schemas/TagIdentifier" + } + }, + "artifactId": { + "description": "The original id of the sketch. This stays the same even if the sketch is is sketched on face etc.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "originalId": { + "type": "string", + "format": "uuid" + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "Path": { + "description": "A path.", + "oneOf": [ + { + "description": "A path that goes to a point.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ToPoint" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment that goes to a point", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArcTo" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A arc that is tangential to the last path segment", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "TangentialArc" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "ccw": { + "description": "arc's direction", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "a complete arc", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Circle" + ] + }, + "center": { + "description": "the arc's center", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "the arc's radius", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "arc's direction This is used to compute the tangential angle.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "CircleThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the circle", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "p1", + "p2", + "p3", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "ArcThreePoint" + ] + }, + "p1": { + "description": "Point 1 of the arc (base on the end of previous segment)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p2": { + "description": "Point 2 of the arc (interior kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the arc (end kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A path that is horizontal.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units", + "x" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Horizontal" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "An angled line to.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "AngledLineTo" + ] + }, + "x": { + "description": "The x coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "y": { + "description": "The y coordinate.", + "type": "number", + "format": "double", + "nullable": true + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Base" + ] + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + { + "description": "A circular arc, not necessarily tangential to the current point.", + "type": "object", + "required": [ + "__geoMeta", + "ccw", + "center", + "from", + "radius", + "to", + "type", + "units" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Arc" + ] + }, + "center": { + "description": "Center of the circle that this arc is drawn on.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "radius": { + "description": "Radius of the circle that this arc is drawn on.", + "type": "number", + "format": "double" + }, + "ccw": { + "description": "True if the arc is counterclockwise.", + "type": "boolean" + }, + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + } + ] + }, + "UnitLen": { + "description": "A unit of length.", + "oneOf": [ + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Mm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Cm" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "M" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Inches" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Feet" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Yards" + ] + } + } + } + ] + }, + "GeoMeta": { + "description": "Geometry metadata.", + "type": "object", + "required": [ + "id", + "sourceRange" + ], + "properties": { + "id": { + "description": "The id of the geometry.", + "type": "string", + "format": "uuid" + }, + "sourceRange": { + "description": "The source range.", + "allOf": [ + { + "$ref": "#/components/schemas/SourceRange" + } + ] + } + } + }, + "SketchSurface": { + "description": "A sketch type.", + "oneOf": [ + { + "type": "object", + "required": [ + "artifactId", + "id", + "origin", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "plane" + ] + }, + "id": { + "description": "The id of the plane.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "$ref": "#/components/schemas/PlaneType" + }, + "origin": { + "description": "Origin of the plane.", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "xAxis": { + "description": "What should the plane's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the plane's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + { + "description": "A face.", + "type": "object", + "required": [ + "artifactId", + "id", + "solid", + "type", + "units", + "value", + "xAxis", + "yAxis", + "zAxis" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "face" + ] + }, + "id": { + "description": "The id of the face.", + "type": "string", + "format": "uuid" + }, + "artifactId": { + "description": "The artifact ID.", + "allOf": [ + { + "$ref": "#/components/schemas/ArtifactId" + } + ] + }, + "value": { + "description": "The tag of the face.", + "type": "string" + }, + "xAxis": { + "description": "What should the face's X axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "yAxis": { + "description": "What should the face's Y axis be?", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "zAxis": { + "description": "The z-axis (normal).", + "allOf": [ + { + "$ref": "#/components/schemas/Point3d" + } + ] + }, + "solid": { + "description": "The solid the face is on.", + "allOf": [ + { + "$ref": "#/components/schemas/Solid" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + } + ] + }, + "PlaneType": { + "description": "Type for a plane.", + "oneOf": [ + { + "type": "string", + "enum": [ + "XY", + "XZ", + "YZ" + ] + }, + { + "description": "A custom plane.", + "type": "string", + "enum": [ + "Custom" + ] + }, + { + "description": "A custom plane which has not been sent to the engine. It must be sent before it is used.", + "type": "string", + "enum": [ + "Uninit" + ] + } + ] + }, + "Point3d": { + "type": "object", + "required": [ + "x", + "y", + "z" + ], + "properties": { + "x": { + "type": "number", + "format": "double" + }, + "y": { + "type": "number", + "format": "double" + }, + "z": { + "type": "number", + "format": "double" + } + } + }, + "BasePath": { + "description": "A base path.", + "type": "object", + "required": [ + "__geoMeta", + "from", + "to", + "units" + ], + "properties": { + "from": { + "description": "The from point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "to": { + "description": "The to point.", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + }, + "tag": { + "description": "The tag of the path.", + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + }, + "__geoMeta": { + "description": "Metadata.", + "allOf": [ + { + "$ref": "#/components/schemas/GeoMeta" + } + ] + } + } + }, + "TagIdentifier": { + "type": "object", + "required": [ + "value" + ], + "properties": { + "value": { + "type": "string" + } + } + }, + "EdgeCut": { + "description": "A fillet or a chamfer.", + "oneOf": [ + { + "description": "A fillet.", + "type": "object", + "required": [ + "edgeId", + "id", + "radius", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "fillet" + ] + }, + "id": { + "description": "The id of the engine command that called this fillet.", + "type": "string", + "format": "uuid" + }, + "radius": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to fillet.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + }, + { + "description": "A chamfer.", + "type": "object", + "required": [ + "edgeId", + "id", + "length", + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "chamfer" + ] + }, + "id": { + "description": "The id of the engine command that called this chamfer.", + "type": "string", + "format": "uuid" + }, + "length": { + "type": "number", + "format": "double" + }, + "edgeId": { + "description": "The engine id of the edge to chamfer.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + } + ] + } + } + }, + "required": true, + "includeInSnippet": true, + "description": "The amount to move the solid or sketch along the z axis.", "labelRequired": true }, { @@ -328089,11 +334467,11 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Move a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> translate(translate = [1.0, 1.0, 2.5])", - "// Move an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> translate(translate = [1.0, 1.0, 2.5])", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Move the sweeps.\ntranslate(parts, translate = [1.0, 1.0, 2.5])", - "// Move a sketch.\n\n\nfn square(length) {\n l = length / 2\n p0 = [-l, -l]\n p1 = [-l, l]\n p2 = [l, l]\n p3 = [l, -l]\n\n return startSketchOn(XY)\n |> startProfileAt(p0, %)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> close()\n}\n\nsquare(10)\n |> translate(translate = [5, 5, 0])\n |> extrude(length = 10)", - "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Move a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> translate(x = 1.0, y = 1.0, z = 2.5)", + "// Move an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> translate(x = 1.0, y = 1.0, z = 2.5)", + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Move the sweeps.\ntranslate(\n parts,\n x = 1.0,\n y = 1.0,\n z = 2.5,\n)", + "// Move a sketch.\n\n\nfn square(length) {\n l = length / 2\n p0 = [-l, -l]\n p1 = [-l, l]\n p2 = [l, l]\n p3 = [l, -l]\n\n return startSketchOn(XY)\n |> startProfileAt(p0, %)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> close()\n}\n\nsquare(10)\n |> translate(x = 5, y = 5, z = 0)\n |> extrude(length = 10)", + "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(x = 0, y = 0, z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" ] }, { diff --git a/docs/kcl/translate.md b/docs/kcl/translate.md index 7fbb197a8..bcba20fc5 100644 --- a/docs/kcl/translate.md +++ b/docs/kcl/translate.md @@ -6,12 +6,16 @@ layout: manual Move a solid or a sketch. +This is really useful for assembling parts together. You can create a part and then move it to the correct location. +Translate is really useful for sketches if you want to move a sketch and then rotate it using the `rotate` function to create a loft. ```js translate( objects: SolidOrSketchOrImportedGeometry, - translate: [number], + x: number, + y: number, + z: number, global?: bool, ): SolidOrSketchOrImportedGeometry ``` @@ -22,7 +26,9 @@ translate( | Name | Type | Description | Required | |----------|------|-------------|----------| | `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to move. | Yes | -| `translate` | [`[number]`](/docs/kcl/types/number) | The amount to move the solid or sketch in all three axes. | Yes | +| `x` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the x axis. | Yes | +| `y` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the y axis. | Yes | +| `z` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the z axis. | Yes | | `global` | [`bool`](/docs/kcl/types/bool) | If true, the transform is applied in global space. The origin of the model will move. By default, the transform is applied in local sketch axis, therefore the origin will not move. | No | ### Returns @@ -52,7 +58,7 @@ sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) - |> translate(translate = [1.0, 1.0, 2.5]) + |> translate(x = 1.0, y = 1.0, z = 2.5) ``` ![Rendered example of translate 0]() @@ -64,7 +70,7 @@ sweepSketch = startSketchOn(XY) import "tests/inputs/cube.sldprt" as cube cube - |> translate(translate = [1.0, 1.0, 2.5]) + |> translate(x = 1.0, y = 1.0, z = 2.5) ``` ![Rendered example of translate 1]() @@ -98,7 +104,12 @@ sweepPath = startProfileAt([0, 0], sketch002) parts = sweep([rectangleSketch, circleSketch], path = sweepPath) // Move the sweeps. -translate(parts, translate = [1.0, 1.0, 2.5]) +translate( + parts, + x = 1.0, + y = 1.0, + z = 2.5, +) ``` ![Rendered example of translate 2]() @@ -123,7 +134,7 @@ fn square(length) { } square(10) - |> translate(translate = [5, 5, 0]) + |> translate(x = 5, y = 5, z = 0) |> extrude(length = 10) ``` @@ -145,7 +156,7 @@ fn square() { profile001 = square() profile002 = square() - |> translate(translate = [0, 0, 20]) + |> translate(x = 0, y = 0, z = 20) |> rotate(axis = [0, 0, 1.0], angle = 45) loft([profile001, profile002]) diff --git a/e2e/playwright/basic-sketch.spec.ts b/e2e/playwright/basic-sketch.spec.ts index 192b8a41b..3cb1e78fb 100644 --- a/e2e/playwright/basic-sketch.spec.ts +++ b/e2e/playwright/basic-sketch.spec.ts @@ -85,7 +85,7 @@ async function doBasicSketch( await page.mouse.click(startXPx, 500 - PUR * 20) if (openPanes.includes('code')) { await expect(u.codeLocator) - .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + .toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -119,10 +119,7 @@ async function doBasicSketch( await page.waitForTimeout(100) if (openPanes.includes('code')) { - await expect( - await u.getGreatestPixDiff(line1, TEST_COLORS.BLUE) - ).toBeLessThan(3) - await expect(await u.getGreatestPixDiff(line1, [0, 0, 255])).toBeLessThan(3) + expect(await u.getGreatestPixDiff(line1, TEST_COLORS.BLUE)).toBeLessThan(3) } // hold down shift @@ -145,7 +142,7 @@ async function doBasicSketch( // Open the code pane. await u.openKclCodePanel() await expect(u.codeLocator) - .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + .toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}, tag = $seg01) diff --git a/e2e/playwright/can-create-sketches-on-all-planes-and-their-back-sides.spec.ts b/e2e/playwright/can-create-sketches-on-all-planes-and-their-back-sides.spec.ts index bb87b7a31..b8e1b9ff0 100644 --- a/e2e/playwright/can-create-sketches-on-all-planes-and-their-back-sides.spec.ts +++ b/e2e/playwright/can-create-sketches-on-all-planes-and-their-back-sides.spec.ts @@ -46,7 +46,7 @@ test.describe( }, } - const code = `sketch001 = startSketchOn(${plane})profile001 = startProfileAt([0.91, -1.22], sketch001)` + const code = `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(${plane})profile001 = startProfileAt([0.91, -1.22], sketch001)` await u.openDebugPanel() diff --git a/e2e/playwright/code-pane-and-errors.spec.ts b/e2e/playwright/code-pane-and-errors.spec.ts index daa21d20d..1908ab38d 100644 --- a/e2e/playwright/code-pane-and-errors.spec.ts +++ b/e2e/playwright/code-pane-and-errors.spec.ts @@ -251,11 +251,11 @@ test( ]) await Promise.all([ fsp.copyFile( - executorInputPath('router-template-slate.kcl'), + executorInputPath('cylinder-inches.kcl'), join(routerTemplateDir, 'main.kcl') ), fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('e2e-can-sketch-on-chamfer.kcl'), join(bracketDir, 'main.kcl') ), ]) diff --git a/e2e/playwright/desktop-export.spec.ts b/e2e/playwright/desktop-export.spec.ts index 91e340907..c4d32ccd1 100644 --- a/e2e/playwright/desktop-export.spec.ts +++ b/e2e/playwright/desktop-export.spec.ts @@ -20,11 +20,11 @@ test( await Promise.all([fsp.mkdir(bracketDir, { recursive: true })]) await Promise.all([ fsp.copyFile( - executorInputPath('router-template-slate.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'other.kcl') ), fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('e2e-can-sketch-on-chamfer.kcl'), path.join(bracketDir, 'main.kcl') ), ]) @@ -107,7 +107,7 @@ test( }, { timeout: 15_000 } ) - .toBeGreaterThan(300_000) + .toBeGreaterThan(30_000) }) }) @@ -187,7 +187,7 @@ test( }, { timeout: 15_000 } ) - .toBeGreaterThan(70_000) + .toBeGreaterThan(50_000) }) }) } diff --git a/e2e/playwright/editor-tests.spec.ts b/e2e/playwright/editor-tests.spec.ts index 6b8f0c50a..739236857 100644 --- a/e2e/playwright/editor-tests.spec.ts +++ b/e2e/playwright/editor-tests.spec.ts @@ -32,26 +32,30 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { await page.keyboard.press('/') await page.keyboard.up('ControlOrMeta') - await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XY) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) - // |> close()`) + // |> close()`.replaceAll('\n', '') + ) // uncomment the code await page.keyboard.down('ControlOrMeta') await page.keyboard.press('/') await page.keyboard.up('ControlOrMeta') - await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XY) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) - |> close()`) + |> close()`.replaceAll('\n', '') + ) }) test('ensure we use the cache, and do not re-execute', async ({ @@ -178,13 +182,15 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { await page.locator('#code-pane button:first-child').click() await page.locator('button:has-text("Format code")').click() - await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XY) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) - |> close()`) + |> close()`.replaceAll('\n', '') + ) }) test('if you click the format button it formats your code and executes so lints are still there', async ({ @@ -227,13 +233,15 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { await u.expectCmdLog('[data-message-type="execution-done"]') await u.closeDebugPanel() - await expect(page.locator('.cm-content')) - .toHaveText(`sketch_001 = startSketchOn(XY) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch_001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) - |> close()`) + |> close()`.replaceAll('\n', '') + ) // error in guter await expect(page.locator('.cm-lint-marker-info').first()).toBeVisible() @@ -471,6 +479,7 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { test('if you write kcl with lint errors you get lints', async ({ page, homePage, + scene, }) => { const u = await getUtils(page) await page.setBodyDimensions({ width: 1000, height: 500 }) @@ -490,10 +499,7 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { await page.keyboard.press('ArrowLeft') await page.keyboard.press('ArrowRight') - // FIXME: lsp errors do not propagate to the frontend until engine is connected and code is executed - // This timeout is to wait for engine connection. LSP and code execution errors should be handled differently - // LSP can emit errors as fast as it waits and show them in the editor - await page.waitForTimeout(10000) + await scene.waitForExecutionDone() // error in guter await expect(page.locator('.cm-lint-marker-info').first()).toBeVisible() @@ -815,10 +821,12 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { // there shouldn't be any auto complete options for 'lin' in the comment await expect(page.locator('.cm-completionLabel')).not.toBeVisible() - await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XZ) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([3.14, 12], %) - |> xLine(%, length = 5) // lin`) + |> xLine(%, length = 5) // lin`.replaceAll('\n', '') + ) // expect there to be no KCL errors await expect(page.locator('.cm-lint-marker-error')).toHaveCount(0) @@ -888,10 +896,12 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { // there shouldn't be any auto complete options for 'lin' in the comment await expect(page.locator('.cm-completionLabel')).not.toBeVisible() - await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XZ) + await expect(page.locator('.cm-content')).toHaveText( + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([3.14, 12], %) - |> xLine(%, length = 5) // lin`) + |> xLine(%, length = 5) // lin`.replaceAll('\n', '') + ) }) }) test('Can undo a click and point extrude with ctrl+z', async ({ @@ -1206,4 +1216,55 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { }) } ) + + test('Rectangle tool panning with middle click', async ({ + page, + homePage, + toolbar, + scene, + cmdBar, + editor, + }) => { + await page.setBodyDimensions({ width: 1200, height: 900 }) + await homePage.goToModelingScene() + + // wait until scene is ready to be interacted with + await scene.connectionEstablished() + await scene.settled(cmdBar) + + await page.getByRole('button', { name: 'Start Sketch' }).click() + + // select an axis plane + await page.mouse.click(700, 200) + + // Needed as we don't yet have a way to get a signal from the engine that the camera has animated to the sketch plane + await page.waitForTimeout(1000) + + const middleMousePan = async ( + startX: number, + startY: number, + endX: number, + endY: number + ) => { + const initialCode = await editor.getCurrentCode() + + await page.mouse.click(startX, startY, { button: 'middle' }) + await page.mouse.move(endX, endY, { + steps: 10, + }) + + // We expect the code to be the same, middle mouse click should not modify the code, only do panning + await editor.expectEditor.toBe(initialCode) + } + + await test.step(`Verify corner rectangle panning`, async () => { + await page.getByTestId('corner-rectangle').click() + await middleMousePan(800, 500, 900, 600) + }) + + await test.step(`Verify center rectangle panning`, async () => { + await toolbar.selectCenterRectangle() + await middleMousePan(800, 200, 900, 300) + }) + }) }) diff --git a/e2e/playwright/fixtures/editorFixture.ts b/e2e/playwright/fixtures/editorFixture.ts index ea393c26a..3304a8a66 100644 --- a/e2e/playwright/fixtures/editorFixture.ts +++ b/e2e/playwright/fixtures/editorFixture.ts @@ -81,6 +81,13 @@ export class EditorFixture { expectEditor = { toContain: this._expectEditorToContain(), not: { toContain: this._expectEditorToContain(true) }, + toBe: async (code: string) => { + const currentCode = await this.getCurrentCode() + return expect(currentCode).toBe(code) + }, + } + getCurrentCode = async () => { + return await this.codeContent.innerText() } snapshot = async (options?: { timeout?: number; name?: string }) => { const wasPaneOpen = await this.checkIfPaneIsOpen() diff --git a/e2e/playwright/fixtures/sceneFixture.ts b/e2e/playwright/fixtures/sceneFixture.ts index d7189a672..b47538345 100644 --- a/e2e/playwright/fixtures/sceneFixture.ts +++ b/e2e/playwright/fixtures/sceneFixture.ts @@ -310,7 +310,9 @@ export async function expectPixelColor( .toBeTruthy() .catch((cause) => { throw new Error( - `ExpectPixelColor: expecting ${colour} got ${finalValue}`, + `ExpectPixelColor: point ${JSON.stringify( + coords + )} was expecting ${colour} but got ${finalValue}`, { cause } ) }) diff --git a/e2e/playwright/lib/console-error-whitelist.ts b/e2e/playwright/lib/console-error-whitelist.ts index 8fa83cec5..c5b396274 100644 --- a/e2e/playwright/lib/console-error-whitelist.ts +++ b/e2e/playwright/lib/console-error-whitelist.ts @@ -258,14 +258,6 @@ export const isErrorWhitelisted = (exception: Error) => { foundInSpec: 'e2e/playwright/testing-settings.spec.ts', }, // TODO: fix this error in the code - { - name: 'TypeError', - message: "Cannot read properties of undefined (reading 'length')", - stack: '', - project: 'Google Chrome', - foundInSpec: '', // many tests are impacted by this error - }, - // TODO: fix this error in the code { name: 'ReferenceError', message: '_testUtils is not defined', diff --git a/e2e/playwright/machines.spec.ts b/e2e/playwright/machines.spec.ts index 097e522de..113f59ffc 100644 --- a/e2e/playwright/machines.spec.ts +++ b/e2e/playwright/machines.spec.ts @@ -11,7 +11,7 @@ test( const bracketDir = join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), join(bracketDir, 'main.kcl') ) }) @@ -51,7 +51,7 @@ test( const bracketDir = join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), join(bracketDir, 'main.kcl') ) }) diff --git a/e2e/playwright/point-click.spec.ts b/e2e/playwright/point-click.spec.ts index edfb181c5..4be3ac008 100644 --- a/e2e/playwright/point-click.spec.ts +++ b/e2e/playwright/point-click.spec.ts @@ -137,7 +137,7 @@ test.describe('Point-and-click tests', () => { await scene.moveCameraTo(cameraPos, cameraTarget) - await test.step('check chamfer selection changes cursor positon', async () => { + await test.step('check chamfer selection changes cursor position', async () => { await expect(async () => { // sometimes initial click doesn't register await clickChamfer() @@ -173,7 +173,7 @@ test.describe('Point-and-click tests', () => { }) await test.step('Check there is no errors after code created in previous steps executes', async () => { await editor.expectState({ - activeLines: ['sketch001 = startSketchOn(XZ)'], + activeLines: ['@settings(defaultLengthUnit = in)'], highlightedCode: '', diagnostics: [], }) @@ -299,7 +299,8 @@ test.describe('Point-and-click tests', () => { await test.step('verify at the end of the test that final code is what is expected', async () => { await editor.expectEditor.toContain( - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -369,7 +370,7 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) }) }) - test('Works on chamfers that are non in a pipeExpression can break up multi edges in a chamfer array', async ({ + test('Works on chamfers that are not in a pipeExpression can break up multi edges in a chamfer array', async ({ context, page, homePage, @@ -418,7 +419,8 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) |>close()`, }) await editor.expectEditor.toContain( - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -1639,9 +1641,10 @@ loft001 = loft([sketch001, sketch002]) { targetType: 'circle', testPoint: { x: 700, y: 250 }, - initialCode: `sketch001 = startSketchOn('YZ') + initialCode: `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(YZ) profile001 = circle(sketch001, center = [0, 0], radius = 500) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = -500) |> tangentialArcTo([-2000, 500], %)`, @@ -1649,7 +1652,8 @@ sketch002 = startSketchOn('XZ') { targetType: 'rectangle', testPoint: { x: 710, y: 255 }, - initialCode: `sketch001 = startSketchOn('YZ') + initialCode: `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(YZ) profile001 = startProfileAt([-400, -400], sketch001) |> angledLine([0, 800], %, $rectangleSegmentA001) |> angledLine([ @@ -1662,7 +1666,7 @@ profile001 = startProfileAt([-400, -400], sketch001) ], %) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = -500) |> tangentialArcTo([-2000, 500], %)`, @@ -1806,7 +1810,8 @@ sketch002 = startSketchOn('XZ') toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn(YZ) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(YZ) |> circle( center = [0, 0], radius = 500 @@ -2475,7 +2480,8 @@ extrude001 = extrude(profile001, length = 5) cmdBar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn(XY) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0]) @@ -2767,7 +2773,8 @@ extrude001 = extrude(sketch001, length = -12) toolbar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn(XY) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0], tag = $seg02) @@ -2921,7 +2928,8 @@ chamfer04 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg02)]) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn(XZ) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 30) extrude001 = extrude(sketch001, length = 30) ` @@ -3056,7 +3064,8 @@ extrude001 = extrude(sketch001, length = 30) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn(XY) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XY) |> startProfileAt([-20, 20], %) |> xLine(length = 40) |> yLine(length = -60) @@ -3174,7 +3183,8 @@ extrude001 = extrude(sketch001, length = 40) }) const shellSketchOnFacesCases = [ - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 100) |> extrude(length = 100) @@ -3182,7 +3192,8 @@ sketch002 = startSketchOn(sketch001, 'END') |> circle(center = [0, 0], radius = 50) |> extrude(length = 50) `, - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 100) extrude001 = extrude(sketch001, length = 100) @@ -3578,7 +3589,8 @@ radius = 8.69 toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn(XZ) + const initialCode = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = circle( sketch001, center = [0, 0], diff --git a/e2e/playwright/projects.spec.ts b/e2e/playwright/projects.spec.ts index c8d57b112..425fd9d2b 100644 --- a/e2e/playwright/projects.spec.ts +++ b/e2e/playwright/projects.spec.ts @@ -87,7 +87,7 @@ test( const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) }) @@ -124,7 +124,7 @@ test( const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) const errorDir = path.join(dir, 'broken-code') @@ -162,7 +162,7 @@ test( // gray at this pixel means the stream has loaded in the most // user way we can verify it (pixel color) await expect - .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { + .poll(() => u.getGreatestPixDiff(pointOnModel, [110, 110, 110]), { timeout: 10_000, }) .toBeLessThan(20) @@ -213,7 +213,7 @@ test( const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) const emptyDir = path.join(dir, 'empty') @@ -248,7 +248,7 @@ test( // gray at this pixel means the stream has loaded in the most // user way we can verify it (pixel color) await expect - .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { + .poll(() => u.getGreatestPixDiff(pointOnModel, [125, 125, 125]), { timeout: 10_000, }) .toBeLessThan(15) @@ -290,7 +290,7 @@ test( const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) @@ -319,7 +319,7 @@ test( // gray at this pixel means the stream has loaded in the most // user way we can verify it (pixel color) await expect - .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { + .poll(() => u.getGreatestPixDiff(pointOnModel, [125, 125, 125]), { timeout: 10_000, }) .toBeLessThan(15) @@ -359,7 +359,7 @@ test( const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) await fsp.copyFile( @@ -393,7 +393,7 @@ test( // gray at this pixel means the stream has loaded in the most // user way we can verify it (pixel color) await expect - .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { + .poll(() => u.getGreatestPixDiff(pointOnModel, [125, 125, 125]), { timeout: 10_000, }) .toBeLessThan(15) @@ -443,7 +443,6 @@ test( await page.getByText('broken-code').click() // Gotcha: You can not use scene.waitForExecutionDone() since the KCL code is going to fail - await expect(page.getByTestId('loading')).toBeAttached() await expect(page.getByTestId('loading')).not.toBeAttached({ timeout: 20_000, }) @@ -481,7 +480,7 @@ test.describe('Can export from electron app', () => { const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) }) @@ -513,7 +512,7 @@ test.describe('Can export from electron app', () => { // gray at this pixel means the stream has loaded in the most // user way we can verify it (pixel color) await expect - .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { + .poll(() => u.getGreatestPixDiff(pointOnModel, [125, 125, 125]), { timeout: 10_000, }) .toBeLessThan(15) @@ -554,7 +553,7 @@ test.describe('Can export from electron app', () => { }, { timeout: 15_000 } ) - .toBeGreaterThan(300_000) + .toBeGreaterThan(50_000) // clean up exported file await fsp.rm(filepath) @@ -1507,7 +1506,12 @@ test( await u.waitForPageLoad() - await page.locator('.cm-content').fill(`sketch001 = startSketchOn(XZ) + // The file should be prepopulated with the user's unit settings. + await expect(page.locator('.cm-content')).toHaveText( + '@settings(defaultLengthUnit = in)' + ) + + await page.locator('.cm-content').fill(`sketch001 = startSketchOn('XZ') |> startProfileAt([-87.4, 282.92], %) |> line(end = [324.07, 27.199], tag = $seg01) |> line(end = [118.328, -291.754]) diff --git a/e2e/playwright/regression-tests.spec.ts b/e2e/playwright/regression-tests.spec.ts index deb17303f..c261120c6 100644 --- a/e2e/playwright/regression-tests.spec.ts +++ b/e2e/playwright/regression-tests.spec.ts @@ -4,9 +4,9 @@ import path from 'path' import * as fsp from 'fs/promises' import { getUtils, - executorInputPath, TEST_COLORS, TestColor, + executorInputPath, orRunWhenFullSuiteEnabled, } from './test-utils' import { TEST_CODE_TRIGGER_ENGINE_EXPORT_ERROR } from './storageStates' @@ -331,7 +331,7 @@ extrude001 = extrude(sketch001, length = 50) localStorage.setItem( 'persistCode', `@settings(defaultLengthUnit = mm) -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) profile002 = startProfileAt([72.24, -52.05], sketch002) |> angledLine([0, 181.26], %, $rectangleSegmentA001) |> angledLine([ @@ -582,7 +582,7 @@ extrude002 = extrude(profile002, length = 150) const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), path.join(bracketDir, 'main.kcl') ) }) @@ -619,6 +619,7 @@ extrude002 = extrude(profile002, length = 150) test(`View gizmo stays visible even when zoomed out all the way`, async ({ page, homePage, + scene, }) => { const u = await getUtils(page) @@ -632,7 +633,7 @@ extrude002 = extrude(profile002, length = 150) await test.step(`Load an empty file`, async () => { await page.addInitScript(async () => { - localStorage.setItem('persistCode', '') + localStorage.setItem('persistCode', '@settings(defaultLengthUnit = in)') }) await page.setBodyDimensions({ width: 1200, height: 500 }) await homePage.goToModelingScene() @@ -646,22 +647,31 @@ extrude002 = extrude(profile002, length = 150) timeout: 5000, message: 'Plane color is visible', }) - .toBeLessThanOrEqual(15) + .toBeLessThanOrEqual(20) + await expect(scene.startEditSketchBtn).toBeEnabled() let maxZoomOuts = 10 let middlePixelIsBackgroundColor = (await middlePixelIsColor(bgColor)) < 10 + + console.time('pressing control') + await page.keyboard.down('Control') + while (!middlePixelIsBackgroundColor && maxZoomOuts > 0) { - await page.keyboard.down('Control') - await page.mouse.move(600, 460) - await page.mouse.down({ button: 'right' }) - await page.mouse.move(600, 50, { steps: 20 }) - await page.mouse.up({ button: 'right' }) - await page.keyboard.up('Control') await page.waitForTimeout(100) + await page.mouse.move(650, 460) + console.time('moved to start point') + await page.mouse.down({ button: 'right' }) + console.time('moused down') + await page.mouse.move(650, 50, { steps: 20 }) + console.time('moved to end point') + await page.waitForTimeout(100) + await page.mouse.up({ button: 'right' }) + console.time('moused up') maxZoomOuts-- - middlePixelIsBackgroundColor = (await middlePixelIsColor(bgColor)) < 10 + middlePixelIsBackgroundColor = (await middlePixelIsColor(bgColor)) < 15 } + await page.keyboard.up('Control') expect(middlePixelIsBackgroundColor, { message: 'We should not see the default planes', @@ -678,13 +688,12 @@ extrude002 = extrude(profile002, length = 150) homePage, scene, toolbar, - viewport, }) => { await context.folderSetupFn(async (dir) => { const legoDir = path.join(dir, 'lego') await fsp.mkdir(legoDir, { recursive: true }) await fsp.copyFile( - executorInputPath('lego.kcl'), + executorInputPath('e2e-can-sketch-on-chamfer.kcl'), path.join(legoDir, 'main.kcl') ) }) @@ -697,11 +706,8 @@ extrude002 = extrude(profile002, length = 150) await scene.loadingIndicator.waitFor({ state: 'detached' }) }) await test.step(`The part should start loading quickly, not waiting until execution is complete`, async () => { - await scene.expectPixelColor( - [143, 143, 143], - { x: (viewport?.width ?? 1200) / 2, y: (viewport?.height ?? 500) / 2 }, - 15 - ) + // TODO: use the viewport size to pick the center point, but the `viewport` fixture's values were wrong. + await scene.expectPixelColor([116, 116, 116], { x: 500, y: 250 }, 15) }) }) diff --git a/e2e/playwright/sketch-tests.spec.ts b/e2e/playwright/sketch-tests.spec.ts index 40d5eafb8..628f55bca 100644 --- a/e2e/playwright/sketch-tests.spec.ts +++ b/e2e/playwright/sketch-tests.spec.ts @@ -113,7 +113,8 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([2.61, -4.01], %) |> xLine(length = 8.73) |> tangentialArcTo([8.33, -1.31], %)` @@ -159,7 +160,10 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { await page.mouse.click(700, 200) await expect.poll(u.normalisedEditorCode, { timeout: 1000 }) - .toBe(`sketch002 = startSketchOn(XZ) + .toBe(`@settings(defaultLengthUnit = in) + + +sketch002 = startSketchOn(XZ) sketch001 = startProfileAt([12.34, -12.34], sketch002) |> yLine(length = 12.34) @@ -789,7 +793,8 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) 200 ) - let codeStr = 'sketch001 = startSketchOn(XY)' + let codeStr = + '@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XY)' await page.mouse.click(center.x, viewportSize.height * 0.55) await expect(u.codeLocator).toHaveText(codeStr) @@ -868,7 +873,8 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await u.openDebugPanel() - const code = `sketch001 = startSketchOn(-XZ) + const code = `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(-XZ) profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( scale * 34.8 )}], sketch001) @@ -898,7 +904,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.mouse.move(700, 200, { steps: 10 }) await page.mouse.click(700, 200, { delay: 200 }) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(-XZ)` + `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(-XZ)` ) let prevContent = await page.locator('.cm-content').innerText() @@ -1426,7 +1432,8 @@ test.describe(`Sketching with offset planes`, () => { await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `offsetPlane001 = offsetPlane(XY, offset = 10)` + `@settings(defaultLengthUnit = in) +offsetPlane001 = offsetPlane(XY, offset = 10)` ) }) @@ -1440,7 +1447,7 @@ test.describe(`Sketching with offset planes`, () => { await test.step(`Hovering should highlight code`, async () => { await planeHover() await editor.expectState({ - activeLines: [`offsetPlane001=offsetPlane(XY,offset=10)`], + activeLines: [`@settings(defaultLengthUnit = in)`], diagnostics: [], highlightedCode: 'offsetPlane(XY, offset = 10)', }) @@ -1453,7 +1460,7 @@ test.describe(`Sketching with offset planes`, () => { await expect(toolbar.lineBtn).toBeEnabled() await editor.expectEditor.toContain('startSketchOn(offsetPlane001)') await editor.expectState({ - activeLines: [`offsetPlane001=offsetPlane(XY,offset=10)`], + activeLines: [`@settings(defaultLengthUnit = in)`], diagnostics: [], highlightedCode: '', }) @@ -1604,7 +1611,8 @@ profile002 = startProfileAt([117.2, 56.08], sketch001) await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile002 = startProfileAt([40.68, 87.67], sketch001) |> xLine(length = 239.17) profile003 = startProfileAt([206.63, -56.73], sketch001) @@ -2172,7 +2180,8 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.24, 4.54], sketch001) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) @@ -2317,7 +2326,8 @@ profile004 = circleThreePoint(sketch001, p1 = [13.44, -6.8], p2 = [13.39, -2.07] await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.24, 4.54], sketch001) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) @@ -2422,7 +2432,8 @@ profile003 = circle(sketch001, center = [6.92, -4.2], radius = 3.16) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([-63.43, 193.08], sketch001) |> line(end = [168.52, 149.87]) |> line(end = [190.29, -39.18]) @@ -2486,7 +2497,11 @@ extrude001 = extrude(profile003, length = 5) page, }) => { await page.addInitScript(async () => { - localStorage.setItem('persistCode', `myVar = 5`) + localStorage.setItem( + 'persistCode', + `@settings(defaultLengthUnit = in) + myVar = 5` + ) }) await page.setBodyDimensions({ width: 1000, height: 500 }) @@ -2533,7 +2548,8 @@ extrude001 = extrude(profile003, length = 5) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([85.19, 338.59], sketch001) |> line(end = [213.3, -94.52]) |> line(end = [-230.09, -55.34]) @@ -2575,7 +2591,8 @@ profile002 = startProfileAt([85.81, 52.55], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `thePart = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +thePart = startSketchOn(XZ) |> startProfileAt([7.53, 10.51], %) |> line(end = [12.54, 1.83]) |> line(end = [6.65, -6.91]) @@ -2636,7 +2653,8 @@ extrude001 = extrude(thePart, length = 75) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.71, -3.66], sketch001) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) @@ -2809,7 +2827,8 @@ extrude003 = extrude(profile011, length = 2.5) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([34, 42.66], sketch001) |> line(end = [102.65, 151.99]) |> line(end = [76, -138.66]) diff --git a/e2e/playwright/snapshot-tests.spec.ts b/e2e/playwright/snapshot-tests.spec.ts index 8e2171696..67d40bb6a 100644 --- a/e2e/playwright/snapshot-tests.spec.ts +++ b/e2e/playwright/snapshot-tests.spec.ts @@ -76,11 +76,11 @@ part001 = startSketchOn(-XZ) |> xLine(endAbsolute = totalLen, tag = $seg03) |> yLine(length = -armThick, tag = $seg01) |> angledLineThatIntersects({ - angle = HALF_TURN, + angle = turns::HALF_TURN, offset = -armThick, intersectTag = seg04 }, %) - |> angledLineToY([segAng(seg04, %) + 180, ZERO], %) + |> angledLineToY([segAng(seg04, %) + 180, turns::ZERO], %) |> angledLineToY({ angle = -bottomAng, to = -totalHeightHalf - armThick, @@ -88,12 +88,12 @@ part001 = startSketchOn(-XZ) |> xLine(length = endAbsolute = segEndX(seg03) + 0) |> yLine(length = -segLen(seg01, %)) |> angledLineThatIntersects({ - angle = HALF_TURN, + angle = turns::HALF_TURN, offset = -armThick, intersectTag = seg02 }, %) |> angledLineToY([segAng(seg02, %) + 180, -baseHeight], %) - |> xLine(endAbsolute = ZERO) + |> xLine(endAbsolute = turns::ZERO) |> close() |> extrude(length = 4)` ) diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-1-Google-Chrome-linux.png index bafda85ec..6c1e7328f 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-2-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-2-Google-Chrome-linux.png index a9b804037..c296a47dd 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-2-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Inch-scale-2-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png index b76e1d372..f9ccdb768 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-rectangles-should-look-right-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-rectangles-should-look-right-1-Google-Chrome-linux.png index 4639dd176..ae548a4c7 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-rectangles-should-look-right-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-rectangles-should-look-right-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-1-Google-Chrome-linux.png index 67be72dda..1982b8e27 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-2-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-2-Google-Chrome-linux.png index 54f4245f4..bf368ba0d 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-2-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-2-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-3-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-3-Google-Chrome-linux.png index 99c8f10b7..d7eef465c 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-3-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-3-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-4-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-4-Google-Chrome-linux.png index 50f96a32c..3b65cf723 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-4-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-4-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-1-Google-Chrome-linux.png index 810142ea3..d2a9c2f82 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-to-on-via-command-bar-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-to-on-via-command-bar-1-Google-Chrome-linux.png index ab06182d5..1335cd834 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-to-on-via-command-bar-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Grid-visibility-Grid-turned-off-to-on-via-command-bar-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Sketch-on-face-with-none-z-up-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Sketch-on-face-with-none-z-up-1-Google-Chrome-linux.png index ab57f9878..0b8272eec 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Sketch-on-face-with-none-z-up-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Sketch-on-face-with-none-z-up-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-3d-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-3d-1-Google-Chrome-linux.png index b5d4021ed..89360c26b 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-3d-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-3d-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-1-Google-Chrome-linux.png index 64eca362c..448f90c91 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-opening-window-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-opening-window-1-Google-Chrome-linux.png index 6108c993e..194f2f225 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-opening-window-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/code-color-goober-code-color-goober-opening-window-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XY-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XY-1-Google-Chrome-linux.png index 8d2141c5b..e83edbcd2 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XY-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XY-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XZ-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XZ-1-Google-Chrome-linux.png index 318b7e38a..d519fa0d7 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XZ-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--XZ-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--YZ-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--YZ-1-Google-Chrome-linux.png index 13796e571..0f3146fd6 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--YZ-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable--YZ-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XY-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XY-1-Google-Chrome-linux.png index 9359b7a8a..be1d17822 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XY-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XY-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XZ-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XZ-1-Google-Chrome-linux.png index 08c79298d..1ddd4a57a 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XZ-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-XZ-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-YZ-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-YZ-1-Google-Chrome-linux.png index e3bd750ff..c19e3f422 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-YZ-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/extrude-on-default-planes-should-be-stable-YZ-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--change-colour.snap.json b/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--change-colour.snap.json index 5058c2c40..00de798d1 100644 --- a/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--change-colour.snap.json +++ b/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--change-colour.snap.json @@ -1,5 +1,5 @@ { - "original_source_code": "sketch001 = startSketchOn('XZ')\nprofile001 = startProfileAt([57.81, 250.51], sketch001)\n |> line(end = [121.13, 56.63], tag = $seg02)\n |> line(end = [83.37, -34.61], tag = $seg01)\n |> line(end = [19.66, -116.4])\n |> line(end = [-221.8, -41.69])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude001 = extrude(profile001, length = 200)\nsketch002 = startSketchOn('XZ')\n |> startProfileAt([-73.64, -42.89], %)\n |> xLine(length = 173.71)\n |> line(end = [-22.12, -94.4])\n |> xLine(length = -156.98)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude002 = extrude(sketch002, length = 50)\nsketch003 = startSketchOn('XY')\n |> startProfileAt([52.92, 157.81], %)\n |> angledLine([0, 176.4], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 53.4\n ], %, $rectangleSegmentB001)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %, $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", + "original_source_code": "sketch001 = startSketchOn('XZ')\nprofile001 = startProfileAt([57.81, 250.51], sketch001)\n |> line(end = [121.13, 56.63], tag = $seg02)\n |> line(end = [83.37, -34.61], tag = $seg01)\n |> line(end = [19.66, -116.4])\n |> line(end = [-221.8, -41.69])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude001 = extrude(profile001, length = 200)\nsketch002 = startSketchOn('XZ')\n |> startProfileAt([-73.64, -42.89], %)\n |> xLine(length = 173.71)\n |> line(end = [-22.12, -94.4])\n |> xLine(length = -156.98)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude002 = extrude(sketch002, length = 50)\nsketch003 = startSketchOn(XY)\n |> startProfileAt([52.92, 157.81], %)\n |> angledLine([0, 176.4], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 53.4\n ], %, $rectangleSegmentB001)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %, $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", "prompt": "make this neon green please, use #39FF14", "source_ranges": [ { @@ -30,4 +30,4 @@ } ], "kcl_version": "0.2.48" -} \ No newline at end of file +} diff --git a/e2e/playwright/testing-constraints.spec.ts b/e2e/playwright/testing-constraints.spec.ts index 57ae5e8da..c1bcb2bb7 100644 --- a/e2e/playwright/testing-constraints.spec.ts +++ b/e2e/playwright/testing-constraints.spec.ts @@ -4,7 +4,6 @@ import { getUtils, TEST_COLORS, pollEditorLinesSelectedLength, - executorInputPath, orRunWhenFullSuiteEnabled, } from './test-utils' import { XOR } from 'lib/utils' @@ -81,7 +80,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 79 + `@settings(defaultLengthUnit = in) + yo = 79 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4], tag = $seg01) @@ -145,7 +145,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4], tag = $seg01) @@ -277,7 +278,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -387,7 +389,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -486,13 +489,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { testName: 'Add variable, selecting axis', addVariable: true, axisSelect: true, - value: 'QUARTER_TURN - angle001', + value: 'turns::QUARTER_TURN - angle001', }, { testName: 'No variable, selecting axis', addVariable: false, axisSelect: true, - value: 'QUARTER_TURN - 7', + value: 'turns::QUARTER_TURN - 7', }, ] as const for (const { testName, addVariable, value, axisSelect } of cases) { @@ -500,7 +503,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -602,7 +606,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -688,7 +693,8 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) +yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -768,7 +774,8 @@ part002 = startSketchOn(XZ) await page.addInitScript(async (customCode) => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -869,7 +876,8 @@ part002 = startSketchOn(XZ) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -935,12 +943,12 @@ part002 = startSketchOn(XZ) test.describe('Axis & segment - no modal constraints', () => { const cases = [ { - codeAfter: `|> line(endAbsolute = [154.9, ZERO])`, + codeAfter: `|> line(endAbsolute = [154.9, turns::ZERO])`, axisClick: { x: 950, y: 250 }, constraintName: 'Snap To X', }, { - codeAfter: `|> line(endAbsolute = [ZERO, 61.34])`, + codeAfter: `|> line(endAbsolute = [turns::ZERO, 61.34])`, axisClick: { x: 600, y: 150 }, constraintName: 'Snap To Y', }, @@ -950,7 +958,8 @@ part002 = startSketchOn(XZ) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yo = 5 + `@settings(defaultLengthUnit = in) + yo = 5 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4]) @@ -1117,9 +1126,19 @@ test.describe('Electron constraint tests', () => { await context.folderSetupFn(async (dir) => { const bracketDir = path.join(dir, 'test-sample') await fsp.mkdir(bracketDir, { recursive: true }) - await fsp.copyFile( - executorInputPath('angled_line.kcl'), - path.join(bracketDir, 'main.kcl') + await fsp.writeFile( + path.join(bracketDir, 'main.kcl'), + `@settings(defaultLengthUnit = in) + const part001 = startSketchOn(XY) + |> startProfileAt([4.83, 12.56], %) + |> line(end = [15.1, 2.48]) + |> line(end = [3.15, -9.85], tag = $seg01) + |> line(end = [-15.17, -4.1]) + |> angledLine([segAng(seg01), 12.35], %) + |> line(end = [-13.02, 10.03]) + |> close() + |> extrude(length = 4)`, + 'utf-8' ) }) diff --git a/e2e/playwright/testing-gizmo.spec.ts b/e2e/playwright/testing-gizmo.spec.ts index a08382412..75b222b32 100644 --- a/e2e/playwright/testing-gizmo.spec.ts +++ b/e2e/playwright/testing-gizmo.spec.ts @@ -255,7 +255,7 @@ test.describe(`Testing gizmo, fixture-based`, () => { await context.addInitScript(() => { localStorage.setItem( 'persistCode', - ` + `@settings(defaultLengthUnit = in) const sketch002 = startSketchOn(XZ) |> startProfileAt([-108.83, -57.48], %) |> angledLine([0, 105.13], %, $rectangleSegmentA001) diff --git a/e2e/playwright/testing-samples-loading.spec.ts b/e2e/playwright/testing-samples-loading.spec.ts index c894547d4..182925fe9 100644 --- a/e2e/playwright/testing-samples-loading.spec.ts +++ b/e2e/playwright/testing-samples-loading.spec.ts @@ -46,7 +46,7 @@ test.describe('Testing in-app sample loading', () => { page.getByRole('option', { name, }) - const warningText = page.getByText('Overwrite current file and units?') + const warningText = page.getByText('Overwrite current file with sample?') const confirmButton = page.getByRole('button', { name: 'Submit command' }) await test.step(`Precondition: check the initial code`, async () => { @@ -110,11 +110,9 @@ test.describe('Testing in-app sample loading', () => { const commandMethodOption = page.getByRole('option', { name: 'Overwrite', }) - const newFileWarning = page.getByText( - 'Create a new file, overwrite project units?' - ) + const newFileWarning = page.getByText('Create a new file from sample?') const overwriteWarning = page.getByText( - 'Overwrite current file and units?' + 'Overwrite current file with sample?' ) const confirmButton = page.getByRole('button', { name: 'Submit command' }) const projectMenuButton = page.getByTestId('project-sidebar-toggle') diff --git a/e2e/playwright/testing-segment-overlays.spec.ts b/e2e/playwright/testing-segment-overlays.spec.ts index f888909f9..809ad55bb 100644 --- a/e2e/playwright/testing-segment-overlays.spec.ts +++ b/e2e/playwright/testing-segment-overlays.spec.ts @@ -210,7 +210,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([5 + 0, 20 + 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -380,7 +381,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `yRel001 = -14 + `@settings(defaultLengthUnit = in) + yRel001 = -14 xRel001 = 0.5 angle001 = 3 len001 = 32 @@ -459,7 +461,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -590,7 +593,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -751,7 +755,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -831,7 +836,8 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([56.37, 120.33], sketch001) |> line(end = [162.86, 106.48]) |> arcTo({ @@ -957,7 +963,8 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +part001 = startSketchOn(XZ) |> circle(center = [1 + 0, 0], radius = 8) ` ) @@ -1077,7 +1084,8 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +part001 = startSketchOn(XZ) |>startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -1351,7 +1359,8 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) async ({ lineToBeDeleted, extraLine }) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([5, 6], %) |> ${lineToBeDeleted} |> line(end = [-10, -15]) @@ -1516,7 +1525,8 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) async ({ lineToBeDeleted }) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + part001 = startSketchOn(XZ) |> startProfileAt([5, 6], %) |> ${lineToBeDeleted} |> line(end = [-10, -15]) diff --git a/e2e/playwright/testing-selections.spec.ts b/e2e/playwright/testing-selections.spec.ts index 3db4e7f43..0b1ded979 100644 --- a/e2e/playwright/testing-selections.spec.ts +++ b/e2e/playwright/testing-selections.spec.ts @@ -68,20 +68,20 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await u.closeDebugPanel() await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` + `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` ) await page.waitForTimeout(100) await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 10) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + .toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) |> xLine(length = ${commonPoints.num1})`) await page.waitForTimeout(100) await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + .toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -89,7 +89,7 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await page.waitForTimeout(100) await page.mouse.click(startXPx, 500 - PUR * 20) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + .toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -260,7 +260,8 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([-79.26, 95.04], %) |> line(end = [112.54, 127.64], tag = $seg02) |> line(end = [170.36, -121.61], tag = $seg01) @@ -528,7 +529,8 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.addInitScript(async (KCL_DEFAULT_LENGTH) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +part001 = startSketchOn(XZ) |> startProfileAt([20, 0], %) |> line(end = [7.13, 4 + 0]) |> angledLine({ angle = 3 + 0, length = 3.14 + 0 }, %) @@ -747,7 +749,8 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.waitForTimeout(200) await u.removeCurrentCode() - await u.codeLocator.fill(`sketch001 = startSketchOn(XZ) + await u.codeLocator.fill(`@settings(defaultLengthUnit = in) + sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -965,7 +968,8 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) async ({ cases }) => { localStorage.setItem( 'persistCode', - `yo = 79 + `@settings(defaultLengthUnit = in) + yo = 79 part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> ${cases[0].expectedCode} @@ -1020,7 +1024,8 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) + sketch001 = startSketchOn(XZ) |> startProfileAt([-79.26, 95.04], %) |> line(end = [112.54, 127.64]) |> line(end = [170.36, -121.61], tag = $seg01) @@ -1253,7 +1258,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.mouse.click(700, 200) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ)` + `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)` ) await page.waitForTimeout(600) diff --git a/e2e/playwright/testing-settings.spec.ts b/e2e/playwright/testing-settings.spec.ts index 4c24644e8..c57eccf23 100644 --- a/e2e/playwright/testing-settings.spec.ts +++ b/e2e/playwright/testing-settings.spec.ts @@ -271,7 +271,7 @@ test.describe('Testing settings', () => { const bracketDir = join(dir, projectName) await fsp.mkdir(bracketDir, { recursive: true }) await fsp.copyFile( - executorInputPath('focusrite_scarlett_mounting_braket.kcl'), + executorInputPath('cylinder-inches.kcl'), join(bracketDir, 'main.kcl') ) } @@ -699,19 +699,19 @@ test.describe('Testing settings', () => { name: 'Current units are: ', }) await gizmo.click() - const button = page.getByRole('button', { + const button = page.locator('ul').getByRole('button', { name: copy, exact: true, }) await button.click() const toastMessage = page.getByText( - `Set default unit to "${unitOfMeasure}" for this project` + `Updated per-file units to ${unitOfMeasure}` ) await expect(toastMessage).toBeVisible() } - await changeUnitOfMeasureInGizmo('in', 'Inches') await changeUnitOfMeasureInGizmo('ft', 'Feet') + await changeUnitOfMeasureInGizmo('in', 'Inches') await changeUnitOfMeasureInGizmo('yd', 'Yards') await changeUnitOfMeasureInGizmo('mm', 'Millimeters') await changeUnitOfMeasureInGizmo('cm', 'Centimeters') @@ -951,9 +951,9 @@ test.describe('Testing settings', () => { ) }) - await test.step(`Initial units from settings`, async () => { + await test.step(`Initial units from settings are ignored`, async () => { await homePage.openProject('project-000') - await expect(unitsIndicator).toHaveText('Current units are: in') + await expect(unitsIndicator).toHaveText('Current units are: mm') }) await test.step(`Manually write inline settings`, async () => { diff --git a/e2e/playwright/various.spec.ts b/e2e/playwright/various.spec.ts index 3591a6f7d..d49ff9514 100644 --- a/e2e/playwright/various.spec.ts +++ b/e2e/playwright/various.spec.ts @@ -67,11 +67,11 @@ part001 = startSketchOn(-XZ) |> xLine(endAbsolute = totalLen, tag = $seg03) |> yLine(length = -armThick, tag = $seg01) |> angledLineThatIntersects({ - angle = HALF_TURN, + angle = turns::HALF_TURN, offset = -armThick, intersectTag = seg04 }, %) -|> angledLineToY([segAng(seg04) + 180, ZERO], %) +|> angledLineToY([segAng(seg04) + 180, turns::ZERO], %) |> angledLineToY({ angle = -bottomAng, to = -totalHeightHalf - armThick, @@ -79,12 +79,12 @@ part001 = startSketchOn(-XZ) |> xLine(endAbsolute = segEndX(seg03) + 0) |> yLine(length = -segLen(seg01)) |> angledLineThatIntersects({ - angle = HALF_TURN, + angle = turns::HALF_TURN, offset = -armThick, intersectTag = seg02 }, %) |> angledLineToY([segAng(seg02) + 180, -baseHeight], %) -|> xLine(endAbsolute = ZERO) +|> xLine(endAbsolute = turns::ZERO) |> close() |> extrude(length = 4)` ) @@ -483,7 +483,8 @@ test('Sketch on face', async ({ page, homePage, scene, cmdBar, toolbar }) => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn(XZ) + `@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) diff --git a/package.json b/package.json index 658b9d649..fe5c1a0ad 100644 --- a/package.json +++ b/package.json @@ -13,20 +13,20 @@ "license": "MIT", "dependencies": { "@codemirror/autocomplete": "^6.18.6", - "@codemirror/commands": "^6.8.0", + "@codemirror/commands": "^6.8.1", "@codemirror/language": "^6.11.0", - "@codemirror/lint": "^6.8.4", + "@codemirror/lint": "^6.8.5", "@codemirror/search": "^6.5.10", - "@codemirror/state": "^6.4.1", + "@codemirror/state": "^6.5.2", "@codemirror/theme-one-dark": "^6.1.2", - "@csstools/postcss-oklab-function": "^4.0.7", + "@csstools/postcss-oklab-function": "^4.0.8", "@fortawesome/fontawesome-svg-core": "^6.7.2", "@fortawesome/free-brands-svg-icons": "^6.7.2", "@fortawesome/free-solid-svg-icons": "^6.7.2", "@fortawesome/react-fontawesome": "^0.2.0", "@headlessui/react": "^1.7.19", - "@headlessui/tailwindcss": "^0.2.0", - "@kittycad/lib": "2.0.21", + "@headlessui/tailwindcss": "^0.2.2", + "@kittycad/lib": "2.0.23", "@lezer/highlight": "^1.2.1", "@lezer/lr": "^1.4.1", "@react-hook/resize-observer": "^2.0.1", @@ -37,11 +37,11 @@ "@xstate/react": "^4.1.1", "bonjour-service": "^1.3.0", "bson": "^6.10.3", - "chokidar": "^4.0.1", + "chokidar": "^4.0.3", "codemirror": "^6.0.1", "decamelize": "^6.0.0", "diff": "^7.0.0", - "electron-updater": "^6.6.0", + "electron-updater": "^6.6.2", "fuse.js": "^7.1.0", "html2canvas-pro": "^1.5.8", "isomorphic-fetch": "^3.0.0", @@ -164,15 +164,15 @@ "@iarna/toml": "^2.2.5", "@lezer/generator": "^1.7.2", "@nabla/vite-plugin-eslint": "^2.0.5", - "@playwright/test": "^1.51.0", + "@playwright/test": "^1.51.1", "@testing-library/jest-dom": "^5.14.1", "@testing-library/react": "^15.0.2", - "@types/diff": "^7.0.1", + "@types/diff": "^7.0.2", "@types/electron": "^1.6.10", "@types/isomorphic-fetch": "^0.0.39", "@types/minimist": "^1.2.5", "@types/mocha": "^10.0.10", - "@types/node": "^22.13.9", + "@types/node": "^22.13.14", "@types/pixelmatch": "^5.2.6", "@types/pngjs": "^6.0.4", "@types/react": "^18.3.4", @@ -182,13 +182,13 @@ "@types/ua-parser-js": "^0.7.39", "@types/uuid": "^9.0.8", "@types/wicg-file-system-access": "^2023.10.5", - "@types/ws": "^8.5.13", - "@vitejs/plugin-react": "^4.3.0", + "@types/ws": "^8.18.0", + "@vitejs/plugin-react": "^4.3.4", "@vitest/web-worker": "^1.5.0", "@xstate/cli": "^0.5.17", - "autoprefixer": "^10.4.19", + "autoprefixer": "^10.4.21", "electron": "^34.1.1", - "electron-builder": "^26.0.6", + "electron-builder": "^26.0.12", "eslint": "^8.0.1", "eslint-plugin-css-modules": "^2.12.0", "eslint-plugin-import": "^2.31.0", @@ -220,7 +220,7 @@ "vite-tsconfig-paths": "^4.3.2", "vitest": "^1.6.1", "vitest-webgl-canvas-mock": "^1.1.0", - "ws": "^8.17.0", + "ws": "^8.18.1", "yarn": "^1.22.22" }, "packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e" diff --git a/public/kcl-samples/car-wheel-assembly/main.kcl b/public/kcl-samples/car-wheel-assembly/main.kcl index ab22ee318..d4c0e165e 100644 --- a/public/kcl-samples/car-wheel-assembly/main.kcl +++ b/public/kcl-samples/car-wheel-assembly/main.kcl @@ -12,7 +12,7 @@ import "car-tire.kcl" as carTire import lugCount from "globals.kcl" carRotor - |> translate(translate = [0, 0.5, 0]) + |> translate(x = 0, y = 0.5, z = 0) carWheel lugNut |> patternCircular3d( @@ -23,5 +23,5 @@ lugNut rotateDuplicates = false, ) brakeCaliper - |> translate(translate = [0, 0.5, 0]) + |> translate(x = 0, y = 0.5, z = 0) carTire diff --git a/public/kcl-samples/dual-basin-utility-sink/main.kcl b/public/kcl-samples/dual-basin-utility-sink/main.kcl index 686928e12..4485f540f 100644 --- a/public/kcl-samples/dual-basin-utility-sink/main.kcl +++ b/public/kcl-samples/dual-basin-utility-sink/main.kcl @@ -1,6 +1,7 @@ // Dual-Basin Utility Sink // A stainless steel sink unit with dual rectangular basins and six under-counter storage compartments. +// set units @settings(defaultLengthUnit = mm) // globals @@ -12,7 +13,7 @@ profileThickness = 13 metalThickness = 2 blockCount = 3 -blockWidth = (tableWidth-profileThickness) / 3 +blockWidth = (tableWidth - profileThickness) / 3 blockHeight = tableHeight - metalThickness - 0.5 blockDepth = tableDepth - profileThickness @@ -27,9 +28,9 @@ legHeight = blockHeight - profileThickness legCount = blockCount + 1 legBody = startProfileAt([0, 0], floorPlane) - |> yLine(length=profileThickness) - |> xLine(length=profileThickness) - |> yLine(length=-profileThickness) + |> yLine(length = profileThickness) + |> xLine(length = profileThickness) + |> yLine(length = -profileThickness) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = legCount, distance = blockWidth) @@ -42,9 +43,9 @@ lowerBeltLengthX = blockWidth - profileThickness lowerBeltPlane = startSketchOn(offsetPlane(XY, offset = lowerBeltHeightAboveTheFloor)) lowerBeltBodyX = startProfileAt([profileThickness, 0], lowerBeltPlane) - |> yLine(length=profileThickness) - |> xLine(length=lowerBeltLengthX) - |> yLine(length=-profileThickness) + |> yLine(length = profileThickness) + |> xLine(length = lowerBeltLengthX) + |> yLine(length = -profileThickness) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = blockCount, distance = blockWidth) @@ -53,12 +54,12 @@ lowerBeltBodyX = startProfileAt([profileThickness, 0], lowerBeltPlane) lowerBeltLengthY = blockDepth - profileThickness lowerBeltBodyY = startProfileAt([0, profileThickness], lowerBeltPlane) - |> yLine(length=lowerBeltLengthY) - |> xLine(length=profileThickness) - |> yLine(length=-lowerBeltLengthY) + |> yLine(length = lowerBeltLengthY) + |> xLine(length = profileThickness) + |> yLine(length = -lowerBeltLengthY) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() - |> patternLinear2d(axis = [1, 0], instances = 2, distance = tableWidth-profileThickness) + |> patternLinear2d(axis = [1, 0], instances = 2, distance = tableWidth - profileThickness) |> extrude(length = profileThickness) // pillars @@ -67,9 +68,9 @@ pillarPlane = startSketchOn(offsetPlane(XY, offset = pillarHeightAboveTheFloor)) pillarTotalHeight = blockHeight - profileThickness - pillarHeightAboveTheFloor pillarBody = startProfileAt([blockSubdivisionWidth, 0], pillarPlane) - |> yLine(length=profileThickness) - |> xLine(length=profileThickness) - |> yLine(length=-profileThickness) + |> yLine(length = profileThickness) + |> xLine(length = profileThickness) + |> yLine(length = -profileThickness) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = blockCount, distance = blockWidth) @@ -80,9 +81,9 @@ pillarBody = startProfileAt([blockSubdivisionWidth, 0], pillarPlane) upperBeltPlane = startSketchOn(offsetPlane(XY, offset = blockHeight)) upperBeltBodyX = startProfileAt([0, 0], upperBeltPlane) - |> yLine(length=profileThickness) - |> xLine(length=tableWidth) - |> yLine(length=-profileThickness) + |> yLine(length = profileThickness) + |> xLine(length = tableWidth) + |> yLine(length = -profileThickness) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [0, 1], instances = 2, distance = blockDepth) @@ -90,20 +91,20 @@ upperBeltBodyX = startProfileAt([0, 0], upperBeltPlane) upperBeltLengthY = blockDepth - profileThickness upperBeltBodyY = startProfileAt([0, profileThickness], upperBeltPlane) - |> yLine(length=upperBeltLengthY) - |> xLine(length=profileThickness) - |> yLine(length=-upperBeltLengthY) + |> yLine(length = upperBeltLengthY) + |> xLine(length = profileThickness) + |> yLine(length = -upperBeltLengthY) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() - |> patternLinear2d(axis = [1, 0], instances = 2, distance = tableWidth-profileThickness) + |> patternLinear2d(axis = [1, 0], instances = 2, distance = tableWidth - profileThickness) |> extrude(length = -profileThickness) // sink tableTopPlane = startSketchOn(offsetPlane(XY, offset = tableHeight)) tableTopBody = startProfileAt([0, 0], tableTopPlane) - |> yLine(length=tableDepth) - |> xLine(length=tableWidth) - |> yLine(length=-tableDepth) + |> yLine(length = tableDepth) + |> xLine(length = tableWidth) + |> yLine(length = -tableDepth) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> extrude(length = -metalThickness) @@ -114,59 +115,62 @@ sinkLength = 250 sinkDepth = 200 sinkOffsetFront = 40 sinkOffsetLeft = 350 -sinkSpacing = tableWidth - sinkWidth - sinkOffsetLeft*2 +sinkSpacing = tableWidth - sinkWidth - (sinkOffsetLeft * 2) sinkPlaneOutside = startSketchOn(tableTopBody, 'START') sinkBodyOutside = startProfileAt([-sinkOffsetLeft, sinkOffsetFront], sinkPlaneOutside) - |> yLine(length=sinkLength) - |> xLine(length=-sinkWidth) - |> yLine(length=-sinkLength) + |> yLine(length = sinkLength) + |> xLine(length = -sinkWidth) + |> yLine(length = -sinkLength) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [-1, 0], instances = sinkCount, distance = sinkSpacing) |> extrude(length = sinkDepth) sinkPlaneInside = startSketchOn(tableTopBody, 'END') -sinkBodyInside = startProfileAt([sinkOffsetLeft+metalThickness, sinkOffsetFront+metalThickness], sinkPlaneInside) - |> yLine(length=sinkLength-metalThickness*2) - |> xLine(length=sinkWidth-metalThickness*2) - |> yLine(length=-sinkLength+metalThickness*2) +sinkBodyInside = startProfileAt([ + sinkOffsetLeft + metalThickness, + sinkOffsetFront + metalThickness + ], sinkPlaneInside) + |> yLine(length = sinkLength - (metalThickness * 2)) + |> xLine(length = sinkWidth - (metalThickness * 2)) + |> yLine(length = -sinkLength + metalThickness * 2) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = sinkCount, distance = sinkSpacing) |> extrude(length = -sinkDepth) - + // door panels doorGap = 2 -doorWidth = blockSubdivisionWidth - profileThickness - doorGap*2 -doorStart = profileThickness+doorGap +doorWidth = blockSubdivisionWidth - profileThickness - (doorGap * 2) +doorStart = profileThickness + doorGap doorHeightAboveTheFloor = pillarHeightAboveTheFloor + doorGap doorHeight = blockHeight - doorHeightAboveTheFloor - profileThickness - doorGap doorCount = blockCount * blockSubdivisionCount doorPlane = startSketchOn(offsetPlane(XY, offset = doorHeightAboveTheFloor)) doorBody = startProfileAt([doorStart, 0], doorPlane) - |> yLine(length=profileThickness) - |> xLine(length=doorWidth) - |> yLine(length=-profileThickness) + |> yLine(length = profileThickness) + |> xLine(length = doorWidth) + |> yLine(length = -profileThickness) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = doorCount, distance = blockSubdivisionWidth) |> extrude(length = doorHeight) // side panels -panelWidth = blockDepth - profileThickness - doorGap*2 +panelWidth = blockDepth - profileThickness - (doorGap * 2) panelCount = doorCount + 1 panelSpacing = tableWidth - profileThickness panelBody = startProfileAt([0, doorStart], doorPlane) - |> yLine(length=panelWidth) - |> xLine(length=profileThickness) - |> yLine(length=-panelWidth) + |> yLine(length = panelWidth) + |> xLine(length = profileThickness) + |> yLine(length = -panelWidth) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() |> patternLinear2d(axis = [1, 0], instances = 2, distance = panelSpacing) |> extrude(length = doorHeight) - + // handle handleDepth = 40 handleWidth = 120 @@ -179,22 +183,25 @@ handleLengthSegmentB = handleWidth - (handleFillet * 2) handlePlane = startSketchOn(offsetPlane(XY, offset = handleHeightAboveTheFloor)) handleProfilePath = startProfileAt([0 + handleOffset, 0], handlePlane) - |> yLine(length=-handleLengthSegmentA) + |> yLine(length = -handleLengthSegmentA) |> tangentialArcTo([ handleFillet + handleOffset, -handleDepth ], %) - |> xLine(length=handleLengthSegmentB) + |> xLine(length = handleLengthSegmentB) |> tangentialArcTo([ handleOffset + handleWidth, -handleLengthSegmentA ], %) - |> yLine(length=handleLengthSegmentA) + |> yLine(length = handleLengthSegmentA) handleSectionPlane = startSketchOn(XZ) handleProfileSection = circle( handleSectionPlane, - center = [handleOffset, handleHeightAboveTheFloor], - radius = 2) - + center = [ + handleOffset, + handleHeightAboveTheFloor + ], + radius = 2, +) handleBody = sweep(handleProfileSection, path = handleProfilePath) |> patternLinear3d(axis = [1, 0, 0], instances = doorCount, distance = blockSubdivisionWidth) diff --git a/public/kcl-samples/i-beam/main.kcl b/public/kcl-samples/i-beam/main.kcl index 4b21ff85b..3fd810cce 100644 --- a/public/kcl-samples/i-beam/main.kcl +++ b/public/kcl-samples/i-beam/main.kcl @@ -5,7 +5,7 @@ @settings(defaultLengthUnit = in) // Define Beam Dimensions -beamLength = 6*ft() +beamLength = 6 * ft() beamHeight = 4 flangeWidth = 2.663 flangeThickness = 0.293 diff --git a/public/kcl-samples/makeup-mirror/main.kcl b/public/kcl-samples/makeup-mirror/main.kcl index deacc57c5..fea832c7c 100644 --- a/public/kcl-samples/makeup-mirror/main.kcl +++ b/public/kcl-samples/makeup-mirror/main.kcl @@ -52,19 +52,22 @@ armPartB = armFn(XZ, armLength, hingeHeight * 2.5 + hingeGap * 2) // mirror fn mirrorFn(plane, offsetX, offsetY, altitude, radius, tiefe, gestellR, gestellD) { - armPlane = startSketchOn(offsetPlane(plane, offset = offsetY - (tiefe / 2))) + armPlane = startSketchOn( offsetPlane(plane, offset = offsetY - (tiefe / 2))) armBody = circle(armPlane, center = [offsetX, altitude], radius = radius) |> extrude(length = tiefe) - archBody = startProfileAt([offsetX-gestellR, altitude], armPlane) + archBody = startProfileAt([offsetX - gestellR, altitude], armPlane) |> xLine(length = gestellD) |> arcTo({ - interior = [offsetX, altitude-gestellR], - end = [offsetX+gestellR, altitude] + interior = [offsetX, altitude - gestellR], + end = [offsetX + gestellR, altitude] }, %) |> xLine(length = gestellD) |> arcTo({ - interior = [offsetX, altitude-gestellR-gestellD], + interior = [ + offsetX, + altitude - gestellR - gestellD + ], end = [profileStartX(%), profileStartY(%)] }, %) |> close() @@ -72,4 +75,4 @@ fn mirrorFn(plane, offsetX, offsetY, altitude, radius, tiefe, gestellR, gestellD return armBody } -mirror = mirrorFn(XZ, armLength, armLength, hingeHeight * 4 + hingeGap * 3 + mirrorRadius+archToMirrorGap+archThickness, mirrorRadius, mirrorThickness, archRadius, archThickness) +mirror = mirrorFn(XZ, armLength, armLength, hingeHeight * 4 + hingeGap * 3 + mirrorRadius + archToMirrorGap + archThickness, mirrorRadius, mirrorThickness, archRadius, archThickness) diff --git a/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl b/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl index 2b264a563..94159764f 100644 --- a/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl +++ b/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl @@ -4,7 +4,6 @@ // set units @settings(defaultLengthUnit = in) - // import constants import boltDiameter, boltLength, boltHeadLength, boltHeadDiameter, boltHexDrive, boltHexFlatLength, boltThreadLength from "globals.kcl" diff --git a/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl b/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl index ca2980293..0f0a7c066 100644 --- a/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl +++ b/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl @@ -1,5 +1,5 @@ // 98017A257 Washer -// washer for the screws in the pipe flange assembly. +// washer for the screws in the pipe flange assembly. // set units @settings(defaultLengthUnit = in) diff --git a/public/kcl-samples/pipe-flange-assembly/main.kcl b/public/kcl-samples/pipe-flange-assembly/main.kcl index 15d083ff6..9855056a8 100644 --- a/public/kcl-samples/pipe-flange-assembly/main.kcl +++ b/public/kcl-samples/pipe-flange-assembly/main.kcl @@ -19,27 +19,15 @@ import pipe from "1120t74-pipe.kcl" flange() flange() |> rotate(axis = [0, 1, 0], angle = 180) - |> translate(translate = [ - 0, - 0, - flangeBackHeight * 2 + gasketThickness - ]) + |> translate(x = 0, y = 0, z = flangeBackHeight * 2 + gasketThickness) // place gasket between the flanges gasket() - |> translate(translate = [ - 0, - 0, - -flangeBackHeight - gasketThickness - ]) + |> translate(x = 0, y = 0, z = -flangeBackHeight - gasketThickness) // place eight washers (four front, four back) washer() - |> translate(translate = [ - mountingHolePlacementDiameter / 2, - 0, - flangeBaseThickness - ]) + |> translate(x = mountingHolePlacementDiameter / 2, y = 0, z = flangeBaseThickness) |> patternCircular3d( %, instances = 4, @@ -57,11 +45,7 @@ washer() // place four bolts bolt() - |> translate(translate = [ - mountingHolePlacementDiameter / 2, - 0, - flangeBaseThickness + washerThickness - ]) + |> translate(x = mountingHolePlacementDiameter / 2, y = 0, z = flangeBaseThickness + washerThickness) |> rotate(roll = 90, pitch = 0, yaw = 0) |> patternCircular3d( %, @@ -74,11 +58,7 @@ bolt() // place four hex nuts hexNut() - |> translate(translate = [ - mountingHolePlacementDiameter / 2, - 0, - -(flangeBackHeight * 2 + gasketThickness + flangeBaseThickness + washerThickness + hexNutThickness) - ]) + |> translate(x = mountingHolePlacementDiameter / 2, y = 0, z = -(flangeBackHeight * 2 + gasketThickness + flangeBaseThickness + washerThickness + hexNutThickness)) |> patternCircular3d( %, instances = 4, @@ -98,11 +78,9 @@ pipe() ) |> translate( %, - translate = [ - 0, - 0, - flangeBaseThickness + flangeFrontHeight - 0.5 - ], + x = 0, + y = 0, + z = flangeBaseThickness + flangeFrontHeight - 0.5, global = true, ) @@ -115,10 +93,8 @@ pipe() ) |> translate( %, - translate = [ - 0, - 0, - -(flangeBackHeight * 2 + gasketThickness + flangeBaseThickness + flangeFrontHeight - 0.5) - ], + x = 0, + y = 0, + z = -(flangeBackHeight * 2 + gasketThickness + flangeBaseThickness + flangeFrontHeight - 0.5), global = true, ) diff --git a/public/kcl-samples/router-template-cross-bar/main.kcl b/public/kcl-samples/router-template-cross-bar/main.kcl index ee84d1ed6..34fcfe4e4 100644 --- a/public/kcl-samples/router-template-cross-bar/main.kcl +++ b/public/kcl-samples/router-template-cross-bar/main.kcl @@ -14,7 +14,7 @@ radius = 10 depth = 30 distanceToInsideEdge = slateWidthHalf + templateThickness + templateGap sketch001 = startSketchOn(XZ) - |> startProfileAt([ZERO, depth + templateGap], %) + |> startProfileAt([0, depth + templateGap], %) |> xLine(length = slateWidthHalf - radius, tag = $seg01) |> arc({ angleEnd = 0, @@ -28,7 +28,7 @@ sketch001 = startSketchOn(XZ) |> yLine(length = templateThickness * 2, tag = $seg08) |> xLine(endAbsolute = segEndX(seg02) + 0, tag = $seg05) |> yLine(endAbsolute = segEndY(seg01) + templateThickness, tag = $seg10) - |> xLine(endAbsolute = ZERO, tag = $seg04) + |> xLine(endAbsolute = 0, tag = $seg04) |> xLine(length = -segLen(seg04)) |> yLine(length = -segLen(seg10)) |> xLine(length = -segLen(seg05)) diff --git a/public/kcl-samples/router-template-slate/main.kcl b/public/kcl-samples/router-template-slate/main.kcl index adbde8403..2d1c876e4 100644 --- a/public/kcl-samples/router-template-slate/main.kcl +++ b/public/kcl-samples/router-template-slate/main.kcl @@ -28,7 +28,7 @@ sketch001 = startSketchOn(XZ) |> yLine(endAbsolute = -templateGap * 2 - (templateDiameter / 2), tag = $seg05) |> xLine(endAbsolute = slateWidthHalf + templateThickness, tag = $seg04) |> yLine(length = -length002, tag = $seg03) - |> xLine(endAbsolute = ZERO, tag = $seg02) + |> xLine(endAbsolute = 0, tag = $seg02) // |> line(end = [7.78, 11.16]) |> xLine(length = -segLen(seg02)) |> yLine(length = segLen(seg03)) diff --git a/public/kcl-samples/walkie-talkie/main.kcl b/public/kcl-samples/walkie-talkie/main.kcl index 203880722..8d68708cd 100644 --- a/public/kcl-samples/walkie-talkie/main.kcl +++ b/public/kcl-samples/walkie-talkie/main.kcl @@ -20,37 +20,25 @@ body() // import the antenna antenna() - |> translate(translate = [-width / 2 + .45, -0.10, height / 2]) + |> translate(x = -width / 2 + .45, y = -0.10, z = height / 2) // import the case case() - |> translate(translate = [0, -1, 0]) + |> translate(x = 0, y = -1, z = 0) // import the talk button talkButton() - |> translate(translate = [width / 2, -thickness / 2, .5]) + |> translate(x = width / 2, y = -thickness / 2, z = .5) // import the frequency knob knob() - |> translate(translate = [ - width / 2 - 0.70, - -thickness / 2, - height / 2 - ]) + |> translate(x = width / 2 - 0.70, y = -thickness / 2, z = height / 2) // import the buttons button() - |> translate(translate = [ - -(screenWidth / 2 + tolerance), - -1, - screenYPosition - ]) + |> translate(x = -(screenWidth / 2 + tolerance), y = -1, z = screenYPosition) button() - |> translate(translate = [ - -(screenWidth / 2 + tolerance), - -1, - screenYPosition - buttonHeight - (tolerance * 2) - ]) + |> translate(x = -(screenWidth / 2 + tolerance), y = -1, z = screenYPosition - buttonHeight - (tolerance * 2)) button() |> rotate( %, @@ -59,11 +47,9 @@ button() yaw = 0, ) |> translate( - translate = [ - screenWidth / 2 + tolerance, - -1, - screenYPosition - buttonHeight - ], + x = screenWidth / 2 + tolerance, + y = -1, + z = screenYPosition - buttonHeight, global = true, ) button() @@ -74,10 +60,8 @@ button() yaw = 0, ) |> translate( - translate = [ - screenWidth / 2 + tolerance, - -1, - screenYPosition - (buttonHeight * 2) - (tolerance * 2) - ], + x = screenWidth / 2 + tolerance, + y = -1, + z = screenYPosition - (buttonHeight * 2) - (tolerance * 2), global = true, ) diff --git a/rust/Cargo.lock b/rust/Cargo.lock index ba2521209..d3c912e7b 100644 --- a/rust/Cargo.lock +++ b/rust/Cargo.lock @@ -1780,7 +1780,7 @@ dependencies = [ [[package]] name = "kcl-bumper" -version = "0.1.55" +version = "0.1.56" dependencies = [ "anyhow", "clap", @@ -1791,7 +1791,7 @@ dependencies = [ [[package]] name = "kcl-derive-docs" -version = "0.1.55" +version = "0.1.56" dependencies = [ "Inflector", "anyhow", @@ -1810,7 +1810,7 @@ dependencies = [ [[package]] name = "kcl-directory-test-macro" -version = "0.1.55" +version = "0.1.56" dependencies = [ "proc-macro2", "quote", @@ -1819,7 +1819,7 @@ dependencies = [ [[package]] name = "kcl-language-server" -version = "0.2.55" +version = "0.2.56" dependencies = [ "anyhow", "clap", @@ -1840,7 +1840,7 @@ dependencies = [ [[package]] name = "kcl-language-server-release" -version = "0.1.55" +version = "0.1.56" dependencies = [ "anyhow", "clap", @@ -1860,7 +1860,7 @@ dependencies = [ [[package]] name = "kcl-lib" -version = "0.2.55" +version = "0.2.56" dependencies = [ "anyhow", "approx 0.5.1", @@ -1928,7 +1928,7 @@ dependencies = [ [[package]] name = "kcl-python-bindings" -version = "0.3.55" +version = "0.3.56" dependencies = [ "anyhow", "kcl-lib", @@ -1943,7 +1943,7 @@ dependencies = [ [[package]] name = "kcl-test-server" -version = "0.1.55" +version = "0.1.56" dependencies = [ "anyhow", "hyper 0.14.32", @@ -1956,7 +1956,7 @@ dependencies = [ [[package]] name = "kcl-to-core" -version = "0.1.55" +version = "0.1.56" dependencies = [ "anyhow", "async-trait", @@ -1970,7 +1970,7 @@ dependencies = [ [[package]] name = "kcl-wasm-lib" -version = "0.1.55" +version = "0.1.56" dependencies = [ "bson", "console_error_panic_hook", @@ -1996,9 +1996,9 @@ dependencies = [ [[package]] name = "kittycad" -version = "0.3.33" +version = "0.3.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f6f65645cc07a8f43c34584e4979bf4da16c047cce50c4715fa9381227574d5" +checksum = "0a345fd2a4cb16205f32bd1aa41715045830c59d78c59927fca6580e2a651ac9" dependencies = [ "anyhow", "async-trait", diff --git a/rust/Cargo.toml b/rust/Cargo.toml index 3de4d4ebb..a2909ba41 100644 --- a/rust/Cargo.toml +++ b/rust/Cargo.toml @@ -35,7 +35,7 @@ clap = { version = "4.5.31", features = ["derive"] } dashmap = { version = "6.1.0" } http = "1" indexmap = "2.7.0" -kittycad = { version = "0.3.33", default-features = false, features = ["js", "requests"] } +kittycad = { version = "0.3.36", default-features = false, features = ["js", "requests"] } kittycad-modeling-cmds = { version = "0.2.107", features = ["ts-rs", "websocket"] } lazy_static = "1.5.0" miette = "7.5.0" diff --git a/rust/kcl-bumper/Cargo.toml b/rust/kcl-bumper/Cargo.toml index 9476ce192..9aeae2585 100644 --- a/rust/kcl-bumper/Cargo.toml +++ b/rust/kcl-bumper/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-bumper" -version = "0.1.55" +version = "0.1.56" edition = "2021" repository = "https://github.com/KittyCAD/modeling-api" rust-version = "1.76" diff --git a/rust/kcl-derive-docs/Cargo.toml b/rust/kcl-derive-docs/Cargo.toml index 66e139449..eddd97ecf 100644 --- a/rust/kcl-derive-docs/Cargo.toml +++ b/rust/kcl-derive-docs/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-derive-docs" description = "A tool for generating documentation from Rust derive macros" -version = "0.1.55" +version = "0.1.56" edition = "2021" license = "MIT" repository = "https://github.com/KittyCAD/modeling-app" diff --git a/rust/kcl-derive-docs/src/lib.rs b/rust/kcl-derive-docs/src/lib.rs index 58ed9e83b..2aa2e0c0e 100644 --- a/rust/kcl-derive-docs/src/lib.rs +++ b/rust/kcl-derive-docs/src/lib.rs @@ -816,7 +816,7 @@ fn generate_code_block_test(fn_name: &str, code_block: &str, index: usize) -> pr async fn #test_name() -> miette::Result<()> { let code = #code_block; // Note, `crate` must be kcl_lib - let result = match crate::test_server::execute_and_snapshot(code, crate::settings::types::UnitLength::Mm, None).await { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/args_with_lifetime.gen b/rust/kcl-derive-docs/tests/args_with_lifetime.gen index 60c38a161..a79915c3c 100644 --- a/rust/kcl-derive-docs/tests/args_with_lifetime.gen +++ b/rust/kcl-derive-docs/tests/args_with_lifetime.gen @@ -31,13 +31,7 @@ mod test_examples_someFn { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_someFn0() -> miette::Result<()> { let code = "someFn()"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/args_with_refs.gen b/rust/kcl-derive-docs/tests/args_with_refs.gen index 679b8194c..5b6c36566 100644 --- a/rust/kcl-derive-docs/tests/args_with_refs.gen +++ b/rust/kcl-derive-docs/tests/args_with_refs.gen @@ -31,13 +31,7 @@ mod test_examples_someFn { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_someFn0() -> miette::Result<()> { let code = "someFn()"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/array.gen b/rust/kcl-derive-docs/tests/array.gen index 56d7871d4..9af507c30 100644 --- a/rust/kcl-derive-docs/tests/array.gen +++ b/rust/kcl-derive-docs/tests/array.gen @@ -32,13 +32,7 @@ mod test_examples_show { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_show0() -> miette::Result<()> { let code = "This is another code block.\nyes sirrr.\nshow"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/box.gen b/rust/kcl-derive-docs/tests/box.gen index be96f7080..a613af7bc 100644 --- a/rust/kcl-derive-docs/tests/box.gen +++ b/rust/kcl-derive-docs/tests/box.gen @@ -32,13 +32,7 @@ mod test_examples_show { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_show0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nshow"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/doc_comment_with_code.gen b/rust/kcl-derive-docs/tests/doc_comment_with_code.gen index b1ba0cfe9..b4410a3e5 100644 --- a/rust/kcl-derive-docs/tests/doc_comment_with_code.gen +++ b/rust/kcl-derive-docs/tests/doc_comment_with_code.gen @@ -33,13 +33,7 @@ mod test_examples_my_func { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_my_func0() -> miette::Result<()> { let code = "This is another code block.\nyes sirrr.\nmyFunc"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/lineTo.gen b/rust/kcl-derive-docs/tests/lineTo.gen index ff2f2bd4e..17acfb8a0 100644 --- a/rust/kcl-derive-docs/tests/lineTo.gen +++ b/rust/kcl-derive-docs/tests/lineTo.gen @@ -33,13 +33,7 @@ mod test_examples_line_to { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_line_to0() -> miette::Result<()> { let code = "This is another code block.\nyes sirrr.\nlineTo"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/min.gen b/rust/kcl-derive-docs/tests/min.gen index 6009394a2..435322812 100644 --- a/rust/kcl-derive-docs/tests/min.gen +++ b/rust/kcl-derive-docs/tests/min.gen @@ -32,13 +32,7 @@ mod test_examples_min { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_min0() -> miette::Result<()> { let code = "This is another code block.\nyes sirrr.\nmin"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/option.gen b/rust/kcl-derive-docs/tests/option.gen index e44a8c461..3441316c8 100644 --- a/rust/kcl-derive-docs/tests/option.gen +++ b/rust/kcl-derive-docs/tests/option.gen @@ -32,13 +32,7 @@ mod test_examples_show { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_show0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nshow"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/option_input_format.gen b/rust/kcl-derive-docs/tests/option_input_format.gen index b0c801e47..b6fb3b4bf 100644 --- a/rust/kcl-derive-docs/tests/option_input_format.gen +++ b/rust/kcl-derive-docs/tests/option_input_format.gen @@ -32,13 +32,7 @@ mod test_examples_import { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_import0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nimport"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/return_vec_box_sketch.gen b/rust/kcl-derive-docs/tests/return_vec_box_sketch.gen index 8a2d46da0..b7bc31f51 100644 --- a/rust/kcl-derive-docs/tests/return_vec_box_sketch.gen +++ b/rust/kcl-derive-docs/tests/return_vec_box_sketch.gen @@ -32,13 +32,7 @@ mod test_examples_import { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_import0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nimport"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/return_vec_sketch.gen b/rust/kcl-derive-docs/tests/return_vec_sketch.gen index 1501d992f..08c97efbd 100644 --- a/rust/kcl-derive-docs/tests/return_vec_sketch.gen +++ b/rust/kcl-derive-docs/tests/return_vec_sketch.gen @@ -32,13 +32,7 @@ mod test_examples_import { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_import0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nimport"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/show.gen b/rust/kcl-derive-docs/tests/show.gen index 00ae5ecdf..26aa3613b 100644 --- a/rust/kcl-derive-docs/tests/show.gen +++ b/rust/kcl-derive-docs/tests/show.gen @@ -32,13 +32,7 @@ mod test_examples_show { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_show0() -> miette::Result<()> { let code = "This is code.\nIt does other shit.\nshow"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-derive-docs/tests/test_args_with_exec_state.gen b/rust/kcl-derive-docs/tests/test_args_with_exec_state.gen index 6fa5ac694..ce8088a64 100644 --- a/rust/kcl-derive-docs/tests/test_args_with_exec_state.gen +++ b/rust/kcl-derive-docs/tests/test_args_with_exec_state.gen @@ -31,13 +31,7 @@ mod test_examples_some_function { #[tokio::test(flavor = "multi_thread", worker_threads = 5)] async fn kcl_test_example_some_function0() -> miette::Result<()> { let code = "someFunction()"; - let result = match crate::test_server::execute_and_snapshot( - code, - crate::settings::types::UnitLength::Mm, - None, - ) - .await - { + let result = match crate::test_server::execute_and_snapshot(code, None).await { Err(crate::errors::ExecError::Kcl(e)) => { return Err(miette::Report::new(crate::errors::Report { error: e.error, diff --git a/rust/kcl-directory-test-macro/Cargo.toml b/rust/kcl-directory-test-macro/Cargo.toml index 64a2aba41..df302b97f 100644 --- a/rust/kcl-directory-test-macro/Cargo.toml +++ b/rust/kcl-directory-test-macro/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-directory-test-macro" description = "A tool for generating tests from a directory of kcl files" -version = "0.1.55" +version = "0.1.56" edition = "2021" license = "MIT" repository = "https://github.com/KittyCAD/modeling-app" diff --git a/rust/kcl-language-server-release/Cargo.toml b/rust/kcl-language-server-release/Cargo.toml index e48fe3baa..e21f4d468 100644 --- a/rust/kcl-language-server-release/Cargo.toml +++ b/rust/kcl-language-server-release/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "kcl-language-server-release" -version = "0.1.55" +version = "0.1.56" edition = "2021" authors = ["KittyCAD Inc "] publish = false diff --git a/rust/kcl-language-server/Cargo.toml b/rust/kcl-language-server/Cargo.toml index cd779f078..2a8320b7d 100644 --- a/rust/kcl-language-server/Cargo.toml +++ b/rust/kcl-language-server/Cargo.toml @@ -2,7 +2,7 @@ name = "kcl-language-server" description = "A language server for KCL." authors = ["KittyCAD Inc "] -version = "0.2.55" +version = "0.2.56" edition = "2021" license = "MIT" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html diff --git a/rust/kcl-language-server/yarn.lock b/rust/kcl-language-server/yarn.lock index 70459fea4..2d232da91 100644 --- a/rust/kcl-language-server/yarn.lock +++ b/rust/kcl-language-server/yarn.lock @@ -2194,9 +2194,9 @@ supports-color@^8.1.1: has-flag "^4.0.0" tar-fs@^2.0.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/tar-fs/-/tar-fs-2.1.1.tgz#489a15ab85f1f0befabb370b7de4f9eb5cbe8784" - integrity sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng== + version "2.1.2" + resolved "https://registry.yarnpkg.com/tar-fs/-/tar-fs-2.1.2.tgz#425f154f3404cb16cb8ff6e671d45ab2ed9596c5" + integrity sha512-EsaAXwxmx8UB7FRKqeozqEPop69DXcmYwTQwXvyAPF352HJsPdkVhvTaDPYqfNgruveJIJy3TA2l+2zj8LJIJA== dependencies: chownr "^1.1.1" mkdirp-classic "^0.5.2" diff --git a/rust/kcl-lib/Cargo.toml b/rust/kcl-lib/Cargo.toml index 795c90cd8..f771c73fc 100644 --- a/rust/kcl-lib/Cargo.toml +++ b/rust/kcl-lib/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-lib" description = "KittyCAD Language implementation and tools" -version = "0.2.55" +version = "0.2.56" edition = "2021" license = "MIT" repository = "https://github.com/KittyCAD/modeling-app" @@ -104,7 +104,7 @@ tower-lsp = { workspace = true, features = ["proposed", "default"] } [features] default = ["engine"] -cli = ["dep:clap"] +cli = ["dep:clap", "kittycad/clap"] dhat-heap = ["dep:dhat"] # For the lsp server, when run with stdout for rpc we want to disable println. # This is used for editor extensions that use the lsp server. @@ -153,8 +153,3 @@ harness = false name = "executor" path = "e2e/executor/main.rs" required-features = ["engine"] - -[[test]] -name = "modify" -path = "e2e/modify/main.rs" -required-features = ["engine"] diff --git a/rust/kcl-lib/benches/benchmark_kcl_samples.rs b/rust/kcl-lib/benches/benchmark_kcl_samples.rs index 7f32df1ee..80a69a1f4 100644 --- a/rust/kcl-lib/benches/benchmark_kcl_samples.rs +++ b/rust/kcl-lib/benches/benchmark_kcl_samples.rs @@ -76,7 +76,7 @@ fn run_benchmarks(c: &mut Criterion) { group.bench_function(format!("execute_{}", dir_name), |b| { b.iter(|| { if let Err(err) = rt.block_on(async { - let ctx = kcl_lib::ExecutorContext::new_with_default_client(Default::default()).await?; + let ctx = kcl_lib::ExecutorContext::new_with_default_client().await?; let mut exec_state = kcl_lib::ExecState::new(&ctx); ctx.run(black_box(&program), &mut exec_state).await?; ctx.close().await; diff --git a/rust/kcl-lib/e2e/executor/cache.rs b/rust/kcl-lib/e2e/executor/cache.rs index 991dd58ce..07e81cc28 100644 --- a/rust/kcl-lib/e2e/executor/cache.rs +++ b/rust/kcl-lib/e2e/executor/cache.rs @@ -1,6 +1,8 @@ //! Cache testing framework. use kcl_lib::{bust_cache, ExecError, ExecOutcome}; +use kcmc::{each_cmd as mcmd, ModelingCmd}; +use kittycad_modeling_cmds as kcmc; #[derive(Debug)] struct Variation<'a> { @@ -49,45 +51,6 @@ async fn cache_test( img_results } -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_cache_change_units_changes_output() { - let code = r#"part001 = startSketchOn('XY') - |> startProfileAt([5.5229, 5.25217], %) - |> line(end = [10.50433, -1.19122]) - |> line(end = [8.01362, -5.48731]) - |> line(end = [-1.02877, -6.76825]) - |> line(end = [-11.53311, 2.81559]) - |> close() - |> extrude(length = 4) -"#; - - let result = cache_test( - "change_units_changes_output", - vec![ - Variation { - code, - settings: &kcl_lib::ExecutorSettings { - units: kcl_lib::UnitLength::In, - ..Default::default() - }, - }, - Variation { - code, - settings: &kcl_lib::ExecutorSettings { - units: kcl_lib::UnitLength::Mm, - ..Default::default() - }, - }, - ], - ) - .await; - - let first = result.first().unwrap(); - let second = result.last().unwrap(); - - assert!(first.1 != second.1); -} - #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cache_change_grid_visualizes_grid_off_to_on() { let code = r#"part001 = startSketchOn('XY') @@ -253,3 +216,69 @@ extrude(sketch001, length = 4) second.artifact_graph.len() ); } + +#[tokio::test(flavor = "multi_thread")] +async fn kcl_test_cache_empty_file_pop_cache_empty_file_planes_work() { + // Get the current working directory. + let code = ""; + + let ctx = kcl_lib::ExecutorContext::new_with_default_client().await.unwrap(); + let program = kcl_lib::Program::parse_no_errs(code).unwrap(); + let outcome = ctx.run_with_caching(program).await.unwrap(); + + // Ensure nothing is left in the batch + assert!(ctx.engine.batch().read().await.is_empty()); + assert!(ctx.engine.batch_end().read().await.is_empty()); + + // Ensure the planes work, and we can show or hide them. + // Hide/show the grid. + let default_planes = ctx.engine.get_default_planes().read().await.clone().unwrap(); + + // Assure the outcome is the same. + assert_eq!(outcome.default_planes, Some(default_planes.clone())); + + ctx.engine + .send_modeling_cmd( + uuid::Uuid::new_v4(), + Default::default(), + &ModelingCmd::from(mcmd::ObjectVisible { + hidden: false, + object_id: default_planes.xy, + }), + ) + .await + .unwrap(); + + // Now simulate an engine pause/network disconnect. + // Raw dog clear the scene entirely. + ctx.engine + .send_modeling_cmd( + uuid::Uuid::new_v4(), + Default::default(), + &ModelingCmd::from(mcmd::SceneClearAll {}), + ) + .await + .unwrap(); + + // Bust the cache and reset the scene. + let outcome = ctx.bust_cache_and_reset_scene().await.unwrap(); + // Get the default planes. + let default_planes = ctx.engine.get_default_planes().read().await.clone().unwrap(); + + assert_eq!(outcome.default_planes, Some(default_planes.clone())); + + // Ensure we can show a plane. + ctx.engine + .send_modeling_cmd( + uuid::Uuid::new_v4(), + Default::default(), + &ModelingCmd::from(mcmd::ObjectVisible { + hidden: false, + object_id: default_planes.xz, + }), + ) + .await + .unwrap(); + + ctx.close().await; +} diff --git a/rust/kcl-lib/e2e/executor/inputs/cylinder-inches.kcl b/rust/kcl-lib/e2e/executor/inputs/cylinder-inches.kcl new file mode 100644 index 000000000..a23ac0b81 --- /dev/null +++ b/rust/kcl-lib/e2e/executor/inputs/cylinder-inches.kcl @@ -0,0 +1,4 @@ +@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) + |> circle(center = [0, 0], radius = 20) +extrude001 = extrude(sketch001, length = 10) diff --git a/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer-no-pipeExpr.kcl b/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer-no-pipeExpr.kcl index 1ee7bf174..66bbbdfb3 100644 --- a/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer-no-pipeExpr.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer-no-pipeExpr.kcl @@ -1,4 +1,5 @@ -const sketch001 = startSketchOn(XZ) +@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -11,8 +12,8 @@ const sketch001 = startSketchOn(XZ) ], %, $yo) |> line(endAbsolute = [profileStartX(%), profileStartY(%)], tag = $seg02) |> close() -const extrude001 = extrude(sketch001, length = 100) -const chamf = chamfer( +extrude001 = extrude(sketch001, length = 100) +chamf = chamfer( extrude001, length = 30, tags = [ diff --git a/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer.kcl b/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer.kcl index 30b0e8367..d36ebcf9e 100644 --- a/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/e2e-can-sketch-on-chamfer.kcl @@ -1,4 +1,5 @@ -const sketch001 = startSketchOn(XZ) +@settings(defaultLengthUnit = in) +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -11,7 +12,7 @@ const sketch001 = startSketchOn(XZ) ], %, $yo) |> line(endAbsolute = [profileStartX(%), profileStartY(%)], tag = $seg02) |> close() -const extrude001 = extrude(sketch001, length = 100) +extrude001 = extrude(sketch001, length = 100) |> chamfer( length = 30, tags = [ diff --git a/rust/kcl-lib/e2e/executor/main.rs b/rust/kcl-lib/e2e/executor/main.rs index 32f1759b6..327cb9ab3 100644 --- a/rust/kcl-lib/e2e/executor/main.rs +++ b/rust/kcl-lib/e2e/executor/main.rs @@ -2,7 +2,7 @@ mod cache; use kcl_lib::{ test_server::{execute_and_export_step, execute_and_snapshot, execute_and_snapshot_no_auth}, - ExecError, UnitLength, + ExecError, }; /// The minimum permissible difference between asserted twenty-twenty images. @@ -26,7 +26,7 @@ pub(crate) fn assert_out(test_name: &str, result: &image::DynamicImage) -> Strin async fn kcl_test_fillet_duplicate_tags() { let code = kcl_input!("fillet_duplicate_tags"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = result.expect_err("Code should have failed due to the duplicate edges being filletted"); let err = err.as_kcl_error().unwrap(); @@ -48,7 +48,7 @@ async fn kcl_test_execute_engine_error_return() { |> extrude(length = 4) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -61,7 +61,7 @@ async fn kcl_test_execute_i_shape() { // This is some code from lee that starts a pipe expression with a variable. let code = kcl_input!("i_shape"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("i_shape", &result); } @@ -70,7 +70,7 @@ async fn kcl_test_execute_i_shape() { async fn kcl_test_execute_pipes_on_pipes() { let code = kcl_input!("pipes_on_pipes"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("pipes_on_pipes", &result); } @@ -78,7 +78,7 @@ async fn kcl_test_execute_pipes_on_pipes() { async fn kcl_test_execute_cylinder() { let code = kcl_input!("cylinder"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cylinder", &result); } @@ -86,7 +86,7 @@ async fn kcl_test_execute_cylinder() { async fn kcl_test_execute_kittycad_svg() { let code = kcl_input!("kittycad_svg"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("kittycad_svg", &result); } @@ -94,7 +94,7 @@ async fn kcl_test_execute_kittycad_svg() { async fn kcl_test_execute_lsystem() { let code = kcl_input!("lsystem"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("lsystem", &result); } @@ -102,7 +102,7 @@ async fn kcl_test_execute_lsystem() { async fn kcl_test_member_expression_sketch() { let code = kcl_input!("member_expression_sketch"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("member_expression_sketch", &result); } @@ -110,7 +110,7 @@ async fn kcl_test_member_expression_sketch() { async fn kcl_test_helix_defaults() { let code = kcl_input!("helix_defaults"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("helix_defaults", &result); } @@ -118,7 +118,7 @@ async fn kcl_test_helix_defaults() { async fn kcl_test_helix_defaults_negative_extrude() { let code = kcl_input!("helix_defaults_negative_extrude"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("helix_defaults_negative_extrude", &result); } @@ -126,7 +126,7 @@ async fn kcl_test_helix_defaults_negative_extrude() { async fn kcl_test_helix_with_length() { let code = kcl_input!("helix_with_length"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("helix_with_length", &result); } @@ -134,7 +134,7 @@ async fn kcl_test_helix_with_length() { async fn kcl_test_dimensions_match() { let code = kcl_input!("dimensions_match"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("dimensions_match", &result); } @@ -142,7 +142,7 @@ async fn kcl_test_dimensions_match() { async fn kcl_test_close_arc() { let code = kcl_input!("close_arc"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("close_arc", &result); } @@ -150,7 +150,7 @@ async fn kcl_test_close_arc() { async fn kcl_test_negative_args() { let code = kcl_input!("negative_args"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("negative_args", &result); } @@ -164,7 +164,7 @@ async fn kcl_test_basic_tangential_arc_with_point() { |> extrude(length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("tangential_arc_with_point", &result); } @@ -178,7 +178,7 @@ async fn kcl_test_basic_tangential_arc_to() { |> extrude(length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("tangential_arc_to", &result); } @@ -205,7 +205,7 @@ box(30, 43, 18, '-xy') let thing = box(-12, -15, 10, 'yz') box(-20, -5, 10, 'xy')"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("different_planes_same_drawing", &result); } @@ -263,7 +263,7 @@ part004 = startSketchOn(YZ) |> close() "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("lots_of_planes", &result); } @@ -280,7 +280,7 @@ async fn kcl_test_holes() { |> extrude(length = 2) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("holes", &result); } @@ -299,7 +299,7 @@ async fn optional_params() { thing = other_circle([2, 2], 20) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("optional_params", &result); } @@ -335,7 +335,7 @@ part = roundedRectangle([0, 0], 20, 20, 4) |> extrude(length = 2) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("rounded_with_holes", &result); } @@ -343,7 +343,7 @@ part = roundedRectangle([0, 0], 20, 20, 4) async fn kcl_test_top_level_expression() { let code = r#"startSketchOn(XY) |> circle(center = [0,0], radius= 22) |> extrude(length = 14)"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("top_level_expression", &result); } @@ -357,7 +357,7 @@ part = startSketchOn(XY) |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic_with_math", &result); } @@ -369,7 +369,7 @@ async fn kcl_test_patterns_linear_basic() { |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic", &result); } @@ -385,7 +385,7 @@ async fn kcl_test_patterns_linear_basic_3d() { |> patternLinear3d(axis = [1, 0, 1], instances = 4, distance = 6) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic_3d", &result); } @@ -397,7 +397,7 @@ async fn kcl_test_patterns_linear_basic_negative_distance() { |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic_negative_distance", &result); } @@ -409,7 +409,7 @@ async fn kcl_test_patterns_linear_basic_negative_axis() { |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic_negative_axis", &result); } @@ -430,7 +430,7 @@ rectangle = startSketchOn(XY) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_linear_basic_holes", &result); } @@ -442,7 +442,7 @@ async fn kcl_test_patterns_circular_basic_2d() { |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_circular_basic_2d", &result); } @@ -458,7 +458,7 @@ async fn kcl_test_patterns_circular_basic_3d() { |> patternCircular3d(axis = [0,0, 1], center = [-20, -20, -20], instances = 41, arcDegrees = 360, rotateDuplicates = false) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_circular_basic_3d", &result); } @@ -474,7 +474,7 @@ async fn kcl_test_patterns_circular_3d_tilted_axis() { |> patternCircular3d(axis = [1,1,0], center = [10, 0, 10], instances = 11, arcDegrees = 360, rotateDuplicates = true) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("patterns_circular_3d_tilted_axis", &result); } @@ -483,7 +483,7 @@ async fn kcl_test_import_file_doesnt_exist() { let code = r#"import 'thing.obj' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -496,7 +496,7 @@ async fn kcl_test_import_obj_with_mtl() { let code = r#"import 'e2e/executor/inputs/cube.obj' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_obj_with_mtl", &result); } @@ -506,7 +506,7 @@ async fn kcl_test_import_obj_with_mtl_units() { import 'e2e/executor/inputs/cube.obj' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_obj_with_mtl_units", &result); } @@ -515,7 +515,7 @@ async fn kcl_test_import_stl() { let code = r#"import 'e2e/executor/inputs/2-5-long-m8-chc-screw.stl' as screw model = screw"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_stl", &result); } @@ -524,7 +524,7 @@ async fn kcl_test_import_gltf_with_bin() { let code = r#"import 'e2e/executor/inputs/cube.gltf' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_gltf_with_bin", &result); } @@ -533,7 +533,7 @@ async fn kcl_test_import_gltf_embedded() { let code = r#"import 'e2e/executor/inputs/cube-embedded.gltf' as cube model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_gltf_embedded", &result); } @@ -542,7 +542,7 @@ async fn kcl_test_import_glb() { let code = r#"import 'e2e/executor/inputs/cube.glb' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_glb", &result); } @@ -551,7 +551,7 @@ async fn kcl_test_import_glb_no_assign() { let code = r#"import 'e2e/executor/inputs/cube.glb' cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("import_glb_no_assign", &result); } @@ -561,7 +561,7 @@ async fn kcl_test_import_ext_doesnt_match() { import 'e2e/executor/inputs/cube.gltf' model = cube"#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -586,14 +586,15 @@ async fn kcl_test_cube_mm() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_mm", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_cm() { - let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) + let code = r#"@settings(defaultLengthUnit = cm) +fn cube = (pos, scale) => { + sg = startSketchOn('XY') |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -607,14 +608,15 @@ async fn kcl_test_cube_cm() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::Cm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_cm", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_m() { - let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) + let code = r#"@settings(defaultLengthUnit = m) +fn cube = (pos, scale) => { + sg = startSketchOn('XY') |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -628,14 +630,15 @@ async fn kcl_test_cube_m() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::M, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_m", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_in() { - let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) + let code = r#"@settings(defaultLengthUnit = in) +fn cube = (pos, scale) => { + sg = startSketchOn('XY') |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -649,14 +652,15 @@ async fn kcl_test_cube_in() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::In, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_in", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_ft() { - let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) + let code = r#"@settings(defaultLengthUnit = ft) +fn cube = (pos, scale) => { + sg = startSketchOn('XY') |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -670,14 +674,15 @@ async fn kcl_test_cube_ft() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::Ft, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_ft", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_yd() { - let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) + let code = r#"@settings(defaultLengthUnit = yd) +fn cube = (pos, scale) => { + sg = startSketchOn('XY') |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -691,7 +696,7 @@ async fn kcl_test_cube_yd() { myCube = cube([0,0], 10) "#; - let result = execute_and_snapshot(code, UnitLength::Yd, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("cube_yd", &result); } @@ -719,7 +724,7 @@ part002 = startSketchOn(part001, part001.sketch.tags.here) |> extrude(length = 1) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = result.err().unwrap(); let ExecError::Kcl(err) = err else { @@ -763,7 +768,7 @@ part003 = startSketchOn(part002, "end") |> extrude(length = 5) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("sketch_on_face_of_face", &result); } @@ -780,7 +785,7 @@ async fn kcl_test_stdlib_kcl_error_right_code_path() { |> extrude(length = 2) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = result.err().unwrap(); let ExecError::Kcl(err) = err else { panic!("Expected KCL error, found {err}"); @@ -811,7 +816,7 @@ part002 = startSketchOn(part001, "end") |> extrude(length = 5) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("sketch_on_face_circle", &result); } @@ -853,7 +858,7 @@ part = rectShape([0, 0], 20, 20) ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = result.err().unwrap(); let ExecError::Kcl(err) = err else { panic!("Expected KCL error, found {err}"); @@ -880,7 +885,7 @@ async fn kcl_test_simple_revolve() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve", &result); } @@ -900,7 +905,7 @@ async fn kcl_test_simple_revolve_uppercase() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve_uppercase", &result); } @@ -920,7 +925,7 @@ async fn kcl_test_simple_revolve_negative() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve_negative", &result); } @@ -940,7 +945,7 @@ async fn kcl_test_revolve_bad_angle_low() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert!(result @@ -966,7 +971,7 @@ async fn kcl_test_revolve_bad_angle_high() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert!(result @@ -992,7 +997,7 @@ async fn kcl_test_simple_revolve_custom_angle() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve_custom_angle", &result); } @@ -1012,7 +1017,7 @@ async fn kcl_test_simple_revolve_custom_axis() { "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve_custom_axis", &result); } @@ -1036,7 +1041,7 @@ sketch001 = startSketchOn(box, "end") "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("revolve_on_edge", &result); } @@ -1060,7 +1065,7 @@ sketch001 = startSketchOn(box, revolveAxis) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; result.unwrap_err(); //this fails right now, but slightly differently, lets just say its enough for it to fail - mike @@ -1088,7 +1093,7 @@ sketch001 = startSketchOn(box, "END") ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("revolve_on_face_circle_edge", &result); } @@ -1110,7 +1115,7 @@ sketch001 = startSketchOn(box, "END") ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("revolve_on_face_circle", &result); } @@ -1136,7 +1141,7 @@ sketch001 = startSketchOn(box, "end") ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("revolve_on_face", &result); } @@ -1150,7 +1155,7 @@ async fn kcl_test_basic_revolve_circle() { ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("basic_revolve_circle", &result); } @@ -1177,7 +1182,7 @@ part002 = startSketchOn(part001, 'end') |> extrude(length = 5) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("simple_revolve_sketch_on_edge", &result); } @@ -1240,7 +1245,7 @@ plumbus1 = circle1 ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("plumbus_fillets", &result); } @@ -1248,7 +1253,7 @@ plumbus1 = circle1 async fn kcl_test_empty_file_is_ok() { let code = r#""#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; result.unwrap(); } @@ -1278,7 +1283,7 @@ async fn kcl_test_member_expression_in_params() { capScrew([0, 0.5, 0], 50, 37.5, 50, 25) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("member_expression_in_params", &result); } @@ -1323,7 +1328,7 @@ bracket = startSketchOn(XY) ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; result.unwrap(); } @@ -1343,7 +1348,7 @@ secondSketch = startSketchOn(part001, '') |> extrude(length = 20) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1374,7 +1379,7 @@ extrusion = startSketchOn(XY) |> extrude(length = height) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1407,7 +1412,7 @@ sketch001 = [profile001, profile002] extrude(sketch001, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("array_of_sketches", &result); } @@ -1444,7 +1449,7 @@ pattn1 = patternLinear3d( ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("pattern3d_array_of_extrudes", &result); } @@ -1492,7 +1497,7 @@ baseExtrusion = extrude(sketch001, length = width) ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("fillets_referencing_other_fillets", &result); } @@ -1540,7 +1545,7 @@ baseExtrusion = extrude(sketch001, length = width) ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("chamfers_referencing_other_chamfers", &result); } @@ -1560,7 +1565,7 @@ async fn kcl_test_shell_with_tag() { ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("shell_with_tag", &result); } @@ -1591,7 +1596,7 @@ pattn1 = patternLinear3d( ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("linear_pattern3d_filleted_sketch", &result); } @@ -1618,7 +1623,7 @@ pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], i "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("circular_pattern3d_filleted_sketch", &result); } @@ -1644,7 +1649,7 @@ part001 = cube([0,0], 20) pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], instances = 5, arcDegrees = 360, rotateDuplicates = false) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("circular_pattern3d_chamfered_sketch", &result); } @@ -1671,7 +1676,7 @@ part001 = cube([0,0], 20) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = result.err().unwrap(); let ExecError::Kcl(err) = err else { panic!("Expected KCL error, found {err}"); @@ -1701,7 +1706,7 @@ async fn kcl_test_duplicate_tags_should_error() { let p = triangle(200) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1712,49 +1717,49 @@ let p = triangle(200) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_global_tags() { let code = kcl_input!("global-tags"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("global_tags", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_extrude_inside_fn_with_tags() { let code = kcl_input!("extrude-inside-fn-with-tags"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("extrude-inside-fn-with-tags", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_pattern_vase() { let code = kcl_input!("pattern_vase"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("pattern_vase", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_scoped_tags() { let code = kcl_input!("scoped-tags"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("scoped_tags", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_order_sketch_extrude_in_order() { let code = kcl_input!("order-sketch-extrude-in-order"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("order-sketch-extrude-in-order", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_order_sketch_extrude_out_of_order() { let code = kcl_input!("order-sketch-extrude-out-of-order"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("order-sketch-extrude-out-of-order", &result); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_extrude_custom_plane() { let code = kcl_input!("extrude-custom-plane"); - let result = execute_and_snapshot(code, UnitLength::Mm, None).await.unwrap(); + let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("extrude-custom-plane", &result); } @@ -1776,7 +1781,7 @@ async fn kcl_test_arc_error_same_start_end() { ) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1796,7 +1801,7 @@ async fn kcl_test_angled_line_to_x_90() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1816,7 +1821,7 @@ async fn kcl_test_angled_line_to_x_270() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1836,7 +1841,7 @@ async fn kcl_test_angled_line_to_y_0() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1856,7 +1861,7 @@ async fn kcl_test_angled_line_to_y_180() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1876,7 +1881,7 @@ async fn kcl_test_angled_line_of_x_length_90() { extrusion = extrude(sketch001, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1896,7 +1901,7 @@ async fn kcl_test_angled_line_of_x_length_270() { extrusion = extrude(sketch001, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1918,7 +1923,7 @@ async fn kcl_test_angled_line_of_y_length_0() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1940,7 +1945,7 @@ async fn kcl_test_angled_line_of_y_length_180() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1962,7 +1967,7 @@ async fn kcl_test_angled_line_of_y_length_negative_180() { example = extrude(exampleSketch, length = 10) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -1979,7 +1984,7 @@ async fn kcl_test_error_inside_fn_also_has_source_range_of_call_site() { someFunction('INVALID') "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -2000,7 +2005,7 @@ async fn kcl_test_error_inside_fn_also_has_source_range_of_call_site_recursive() someFunction('INVALID') "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), @@ -2024,7 +2029,7 @@ async fn kcl_test_error_no_auth_websocket() { ) "#; - let result = execute_and_snapshot_no_auth(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot_no_auth(code, None).await; assert!(result.is_err()); assert!(result .err() @@ -2050,9 +2055,7 @@ sketch000 = startSketchOn(XY) |> line(end = [0, innerDiameter / 2]) "#; - let ctx = kcl_lib::ExecutorContext::new_with_default_client(Default::default()) - .await - .unwrap(); + let ctx = kcl_lib::ExecutorContext::new_with_default_client().await.unwrap(); let mut exec_state = kcl_lib::ExecState::new(&ctx); let program = kcl_lib::Program::parse_no_errs(code).unwrap(); ctx.run(&program, &mut exec_state).await.unwrap(); @@ -2075,9 +2078,7 @@ async fn kcl_test_ensure_nothing_left_in_batch_multi_file() { // Change the current working directory to the test directory. std::env::set_current_dir(path.parent().unwrap()).unwrap(); - let ctx = kcl_lib::ExecutorContext::new_with_default_client(Default::default()) - .await - .unwrap(); + let ctx = kcl_lib::ExecutorContext::new_with_default_client().await.unwrap(); let mut exec_state = kcl_lib::ExecState::new(&ctx); let program = kcl_lib::Program::parse_no_errs(&code).unwrap(); ctx.run(&program, &mut exec_state).await.unwrap(); @@ -2095,7 +2096,7 @@ async fn kcl_test_better_type_names() { |> circle(center = [-95.51, -74.7], radius = 262.23) |> appearance(metalness = 0.9) "#; - let result = execute_and_snapshot(code, UnitLength::Mm, None).await; + let result = execute_and_snapshot(code, None).await; let err = match result.err() { Some(x) => match x { @@ -2114,7 +2115,7 @@ async fn kcl_test_exporting_step_file() { // This tests export like how we do it in cli and kcl.py. let code = kcl_input!("helix_defaults_negative_extrude"); - let (_, _, files) = execute_and_export_step(code, UnitLength::Mm, None).await.unwrap(); + let (_, _, files) = execute_and_export_step(code, None).await.unwrap(); for file in files { expectorate::assert_contents( format!("e2e/executor/outputs/helix_defaults_negative_extrude_{}", file.name), diff --git a/rust/kcl-lib/e2e/modify/main.rs b/rust/kcl-lib/e2e/modify/main.rs deleted file mode 100644 index c443437f4..000000000 --- a/rust/kcl-lib/e2e/modify/main.rs +++ /dev/null @@ -1,232 +0,0 @@ -use anyhow::Result; -use kcl_lib::{ - exec::{KclValue, PlaneType}, - modify_ast_for_sketch, ExecState, ExecutorContext, ModuleId, Program, SourceRange, -}; -use kittycad_modeling_cmds::{each_cmd as mcmd, length_unit::LengthUnit, shared::Point3d, ModelingCmd}; -use pretty_assertions::assert_eq; - -/// Setup the engine and parse code for an ast. -async fn setup(code: &str, name: &str) -> Result<(ExecutorContext, Program, ModuleId, uuid::Uuid)> { - let program = Program::parse_no_errs(code)?; - let ctx = kcl_lib::ExecutorContext::new_with_default_client(Default::default()).await?; - let mut exec_state = ExecState::new(&ctx); - let result = ctx.run(&program, &mut exec_state).await?; - let outcome = exec_state.to_wasm_outcome(result.0).await; - - // We need to get the sketch ID. - let KclValue::Sketch { value: sketch } = outcome.variables.get(name).unwrap() else { - anyhow::bail!("part001 not found in: {:?}", outcome.variables); - }; - let sketch_id = sketch.id; - - let plane_id = uuid::Uuid::new_v4(); - ctx.engine - .send_modeling_cmd( - plane_id, - SourceRange::default(), - &ModelingCmd::from(mcmd::MakePlane { - clobber: false, - origin: Point3d::default(), - size: LengthUnit(60.0), - x_axis: Point3d { x: 1.0, y: 0.0, z: 0.0 }, - y_axis: Point3d { x: 0.0, y: 1.0, z: 0.0 }, - hide: Some(true), - }), - ) - .await?; - - // Enter sketch mode. - // We can't get control points without being in sketch mode. - // You can however get path info without sketch mode. - ctx.engine - .send_modeling_cmd( - uuid::Uuid::new_v4(), - SourceRange::default(), - &ModelingCmd::from(mcmd::EnableSketchMode { - animated: false, - ortho: true, - entity_id: plane_id, - planar_normal: Some(Point3d { x: 0.0, y: 0.0, z: 1.0 }), - adjust_camera: false, - }), - ) - .await?; - - Ok((ctx, program, ModuleId::default(), sketch_id)) -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_modify_sketch_part001() { - let name = "part001"; - let code = format!( - r#"{} = startSketchOn(XY) - |> startProfileAt([8.41, 5.78], %) - |> line(end = [7.37, -11]) - |> line(end = [-8.69, -3.75]) - |> line(end = [-5, 4.25]) -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let new_code = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id) - .await - .unwrap(); - - // Make sure the code is the same. - assert_eq!(code, new_code); - // Make sure the program is the same. - assert_eq!(new_program, program); -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_modify_sketch_part002() { - let name = "part002"; - let code = format!( - r#"{} = startSketchOn(XY) - |> startProfileAt([8.41, 5.78], %) - |> line(end = [7.42, -8.62]) - |> line(end = [-6.38, -3.51]) - |> line(end = [-3.77, 3.56]) -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let new_code = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id) - .await - .unwrap(); - - // Make sure the code is the same. - assert_eq!(code, new_code); - // Make sure the program is the same. - assert_eq!(new_program, program); -} - -#[tokio::test(flavor = "multi_thread")] -#[ignore] // until KittyCAD/engine#1434 is fixed. -async fn kcl_test_modify_close_sketch() { - let name = "part002"; - let code = format!( - r#"{} = startSketchOn(XY) - |> startProfileAt([7.91, 3.89], %) - |> line(end = [7.42, -8.62]) - |> line(end = [-6.38, -3.51]) - |> line(end = [-3.77, 3.56]) - |> close() -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let new_code = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id) - .await - .unwrap(); - - // Make sure the code is the same. - assert_eq!(code, new_code); - // Make sure the program is the same. - assert_eq!(new_program, program); -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_modify_line_to_close_sketch() { - let name = "part002"; - let code = format!( - r#"const {} = startSketchOn(XY) - |> startProfileAt([7.91, 3.89], %) - |> line(end = [7.42, -8.62]) - |> line(end = [-6.38, -3.51]) - |> line(end = [-3.77, 3.56]) - |> line(endAbsolute = [7.91, 3.89]) -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let new_code = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id) - .await - .unwrap(); - - // Make sure the code is the same. - assert_eq!( - new_code, - format!( - r#"{} = startSketchOn(XY) - |> startProfileAt([7.91, 3.89], %) - |> line(end = [7.42, -8.62]) - |> line(end = [-6.38, -3.51]) - |> line(end = [-3.77, 3.56]) - |> close() -"#, - name - ) - ); -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_modify_with_constraint() { - let name = "part002"; - let code = format!( - r#"const thing = 12 -const {} = startSketchOn(XY) - |> startProfileAt([7.91, 3.89], %) - |> line(end = [7.42, -8.62]) - |> line(end = [-6.38, -3.51]) - |> line(end = [-3.77, 3.56]) - |> line(endAbsolute = [thing, 3.89]) -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let result = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id).await; - - assert!(result.is_err()); - assert_eq!( - result.unwrap_err().message(), - "Sketch part002 is constrained `partial` and cannot be modified", - ); -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_modify_line_should_close_sketch() { - let name = "part003"; - let code = format!( - r#"const {} = startSketchOn(XY) - |> startProfileAt([13.69, 3.8], %) - |> line(end = [4.23, -11.79]) - |> line(end = [-10.7, -1.16]) - |> line(end = [-3.72, 8.69]) - |> line(end = [10.19, 4.26]) -"#, - name - ); - - let (ctx, program, module_id, sketch_id) = setup(&code, name).await.unwrap(); - let mut new_program = program.clone(); - let new_code = modify_ast_for_sketch(&ctx.engine, &mut new_program, module_id, name, PlaneType::XY, sketch_id) - .await - .unwrap(); - - // Make sure the code is the same. - assert_eq!( - new_code, - format!( - r#"{} = startSketchOn(XY) - |> startProfileAt([13.69, 3.8], %) - |> line(end = [4.23, -11.79]) - |> line(end = [-10.7, -1.16]) - |> line(end = [-3.72, 8.69]) - |> close() -"#, - name - ) - ); -} diff --git a/rust/kcl-lib/src/coredump/mod.rs b/rust/kcl-lib/src/coredump/mod.rs index 3057e3e40..df217a651 100644 --- a/rust/kcl-lib/src/coredump/mod.rs +++ b/rust/kcl-lib/src/coredump/mod.rs @@ -53,7 +53,7 @@ pub trait CoreDump: Clone { .meta() .create_debug_uploads(vec![kittycad::types::multipart::Attachment { name: "".to_string(), - filename: Some(format!(r#"modeling-app/coredump-{coredump_id}-screenshot.png"#)), + filepath: Some(format!(r#"modeling-app/coredump-{coredump_id}-screenshot.png"#).into()), content_type: Some("image/png".to_string()), data, }]) @@ -101,7 +101,7 @@ pub trait CoreDump: Clone { .meta() .create_debug_uploads(vec![kittycad::types::multipart::Attachment { name: "".to_string(), - filename: Some(format!(r#"modeling-app/coredump-{}.json"#, coredump_id)), + filepath: Some(format!(r#"modeling-app/coredump-{}.json"#, coredump_id).into()), content_type: Some("application/json".to_string()), data, }]) diff --git a/rust/kcl-lib/src/docs/gen_std_tests.rs b/rust/kcl-lib/src/docs/gen_std_tests.rs index ce930b392..3702bd70a 100644 --- a/rust/kcl-lib/src/docs/gen_std_tests.rs +++ b/rust/kcl-lib/src/docs/gen_std_tests.rs @@ -339,9 +339,9 @@ fn generate_index(combined: &IndexMap>, kcl_lib: &[Doc } functions.entry(d.mod_name()).or_default().push(match d { - DocData::Fn(f) => (f.name.clone(), d.file_name()), - DocData::Const(c) => (c.name.clone(), d.file_name()), - DocData::Ty(t) => (t.name.clone(), d.file_name()), + DocData::Fn(f) => (f.preferred_name.clone(), d.file_name()), + DocData::Const(c) => (c.preferred_name.clone(), d.file_name()), + DocData::Ty(t) => (t.preferred_name.clone(), d.file_name()), }); if let DocData::Const(c) = d { @@ -1172,7 +1172,7 @@ fn find_examples(text: &str, filename: &str) -> Vec<(String, String)> { async fn run_example(text: &str) -> Result<()> { let program = crate::Program::parse_no_errs(text)?; - let ctx = ExecutorContext::new_with_default_client(crate::UnitLength::Mm).await?; + let ctx = ExecutorContext::new_with_default_client().await?; let mut exec_state = crate::execution::ExecState::new(&ctx); ctx.run(&program, &mut exec_state).await?; Ok(()) diff --git a/rust/kcl-lib/src/docs/kcl_doc.rs b/rust/kcl-lib/src/docs/kcl_doc.rs index 0c72cdd7d..6fb2f1517 100644 --- a/rust/kcl-lib/src/docs/kcl_doc.rs +++ b/rust/kcl-lib/src/docs/kcl_doc.rs @@ -9,7 +9,7 @@ use tower_lsp::lsp_types::{ use crate::{ execution::annotations, parsing::{ - ast::types::{Annotation, Node, PrimitiveType, Type, VariableKind}, + ast::types::{Annotation, ImportSelector, Node, PrimitiveType, Type, VariableKind}, token::NumericSuffix, }, ModuleId, @@ -17,7 +17,7 @@ use crate::{ pub fn walk_prelude() -> Vec { let mut visitor = CollectionVisitor::default(); - visitor.visit_module("prelude").unwrap(); + visitor.visit_module("prelude", "").unwrap(); visitor.result } @@ -29,7 +29,7 @@ struct CollectionVisitor { } impl CollectionVisitor { - fn visit_module(&mut self, name: &str) -> Result<(), String> { + fn visit_module(&mut self, name: &str, preferred_prefix: &str) -> Result<(), String> { let old_name = std::mem::replace(&mut self.name, name.to_owned()); let source = crate::modules::read_std(name).unwrap(); let parsed = crate::parsing::parse_str(source, ModuleId::from_usize(self.id)) @@ -40,14 +40,16 @@ impl CollectionVisitor { for n in &parsed.body { match n { crate::parsing::ast::types::BodyItem::ImportStatement(import) if !import.visibility.is_default() => { - // Only supports glob imports for now. - assert!(matches!( - import.selector, - crate::parsing::ast::types::ImportSelector::Glob(..) - )); match &import.path { crate::parsing::ast::types::ImportPath::Std { path } => { - self.visit_module(&path[1])?; + match import.selector { + ImportSelector::Glob(..) => self.visit_module(&path[1], "")?, + ImportSelector::None { .. } => { + self.visit_module(&path[1], &format!("{}::", import.module_name().unwrap()))? + } + // Only supports glob or whole-module imports for now. + _ => unimplemented!(), + } } p => return Err(format!("Unexpected import: `{p}`")), } @@ -59,8 +61,8 @@ impl CollectionVisitor { format!("std::{}::", self.name) }; let mut dd = match var.kind { - VariableKind::Fn => DocData::Fn(FnData::from_ast(var, qual_name)), - VariableKind::Const => DocData::Const(ConstData::from_ast(var, qual_name)), + VariableKind::Fn => DocData::Fn(FnData::from_ast(var, qual_name, preferred_prefix)), + VariableKind::Const => DocData::Const(ConstData::from_ast(var, qual_name, preferred_prefix)), }; dd.with_meta(&var.outer_attrs); @@ -77,7 +79,7 @@ impl CollectionVisitor { } else { format!("std::{}::", self.name) }; - let mut dd = DocData::Ty(TyData::from_ast(ty, qual_name)); + let mut dd = DocData::Ty(TyData::from_ast(ty, qual_name, preferred_prefix)); dd.with_meta(&ty.outer_attrs); for a in &ty.outer_attrs { @@ -200,6 +202,8 @@ impl DocData { #[derive(Debug, Clone)] pub struct ConstData { pub name: String, + /// How the const is indexed, etc. + pub preferred_name: String, /// The fully qualified name. pub qual_name: String, pub value: Option, @@ -216,7 +220,11 @@ pub struct ConstData { } impl ConstData { - fn from_ast(var: &crate::parsing::ast::types::VariableDeclaration, mut qual_name: String) -> Self { + fn from_ast( + var: &crate::parsing::ast::types::VariableDeclaration, + mut qual_name: String, + preferred_prefix: &str, + ) -> Self { assert_eq!(var.kind, crate::parsing::ast::types::VariableKind::Const); let (value, ty) = match &var.declaration.init { @@ -240,6 +248,7 @@ impl ConstData { let name = var.declaration.id.name.clone(); qual_name.push_str(&name); ConstData { + preferred_name: format!("{preferred_prefix}{name}"), name, qual_name, value, @@ -272,7 +281,7 @@ impl ConstData { detail.push_str(ty); } CompletionItem { - label: self.name.clone(), + label: self.preferred_name.clone(), label_details: Some(CompletionItemLabelDetails { detail: self.value.clone(), description: None, @@ -306,6 +315,8 @@ impl ConstData { pub struct FnData { /// The name of the function. pub name: String, + /// How the function is indexed, etc. + pub preferred_name: String, /// The fully qualified name. pub qual_name: String, /// The args of the function. @@ -326,7 +337,11 @@ pub struct FnData { } impl FnData { - fn from_ast(var: &crate::parsing::ast::types::VariableDeclaration, mut qual_name: String) -> Self { + fn from_ast( + var: &crate::parsing::ast::types::VariableDeclaration, + mut qual_name: String, + preferred_prefix: &str, + ) -> Self { assert_eq!(var.kind, crate::parsing::ast::types::VariableKind::Fn); let crate::parsing::ast::types::Expr::FunctionExpression(expr) = &var.declaration.init else { unreachable!(); @@ -345,6 +360,7 @@ impl FnData { } FnData { + preferred_name: format!("{preferred_prefix}{name}"), name, qual_name, args: expr.params.iter().map(ArgData::from_ast).collect(), @@ -443,7 +459,7 @@ impl FnData { } // We end with ${} so you can jump to the end of the snippet. // After the last argument. - format!("{}({})${{}}", self.name, args.join(", ")) + format!("{}({})${{}}", self.preferred_name, args.join(", ")) } fn to_signature_help(&self) -> SignatureHelp { @@ -452,7 +468,7 @@ impl FnData { SignatureHelp { signatures: vec![SignatureInformation { - label: self.name.clone(), + label: self.preferred_name.clone(), documentation: self.short_docs().map(|s| { Documentation::MarkupContent(MarkupContent { kind: MarkupKind::Markdown, @@ -580,6 +596,8 @@ impl ArgKind { pub struct TyData { /// The name of the function. pub name: String, + /// How the type is indexed, etc. + pub preferred_name: String, /// The fully qualified name. pub qual_name: String, pub properties: Properties, @@ -597,7 +615,11 @@ pub struct TyData { } impl TyData { - fn from_ast(ty: &crate::parsing::ast::types::TypeDeclaration, mut qual_name: String) -> Self { + fn from_ast( + ty: &crate::parsing::ast::types::TypeDeclaration, + mut qual_name: String, + preferred_prefix: &str, + ) -> Self { let name = ty.name.name.clone(); qual_name.push_str(&name); let mut referenced_types = HashSet::new(); @@ -606,6 +628,7 @@ impl TyData { } TyData { + preferred_name: format!("{preferred_prefix}{name}"), name, qual_name, properties: Properties { @@ -641,7 +664,7 @@ impl TyData { fn to_completion_item(&self) -> CompletionItem { CompletionItem { - label: self.name.clone(), + label: self.preferred_name.clone(), label_details: self.alias.as_ref().map(|t| CompletionItemLabelDetails { detail: Some(format!("type {} = {t}", self.name)), description: None, @@ -658,7 +681,7 @@ impl TyData { preselect: None, sort_text: None, filter_text: None, - insert_text: Some(self.name.clone()), + insert_text: Some(self.preferred_name.clone()), insert_text_format: Some(InsertTextFormat::SNIPPET), insert_text_mode: None, text_edit: None, @@ -987,20 +1010,17 @@ mod test { let std = walk_prelude(); for d in std { for (i, eg) in d.examples().enumerate() { - let result = - match crate::test_server::execute_and_snapshot(eg, crate::settings::types::UnitLength::Mm, None) - .await - { - Err(crate::errors::ExecError::Kcl(e)) => { - return Err(miette::Report::new(crate::errors::Report { - error: e.error, - filename: format!("{}{i}", d.name()), - kcl_source: eg.to_string(), - })); - } - Err(other_err) => panic!("{}", other_err), - Ok(img) => img, - }; + let result = match crate::test_server::execute_and_snapshot(eg, None).await { + Err(crate::errors::ExecError::Kcl(e)) => { + return Err(miette::Report::new(crate::errors::Report { + error: e.error, + filename: format!("{}{i}", d.name()), + kcl_source: eg.to_string(), + })); + } + Err(other_err) => panic!("{}", other_err), + Ok(img) => img, + }; twenty_twenty::assert_image( format!("tests/outputs/serial_test_example_{}{i}.png", d.example_name()), &result, diff --git a/rust/kcl-lib/src/docs/mod.rs b/rust/kcl-lib/src/docs/mod.rs index 458176629..4c3558c66 100644 --- a/rust/kcl-lib/src/docs/mod.rs +++ b/rust/kcl-lib/src/docs/mod.rs @@ -1141,7 +1141,7 @@ mod tests { let snippet = scale_fn.to_autocomplete_snippet().unwrap(); assert_eq!( snippet, - r#"scale(${0:%}, scale = [${1:3.14}, ${2:3.14}, ${3:3.14}])${}"# + r#"scale(${0:%}, x = ${1:3.14}, y = ${2:3.14}, z = ${3:3.14})${}"# ); } @@ -1152,7 +1152,7 @@ mod tests { let snippet = translate_fn.to_autocomplete_snippet().unwrap(); assert_eq!( snippet, - r#"translate(${0:%}, translate = [${1:3.14}, ${2:3.14}, ${3:3.14}])${}"# + r#"translate(${0:%}, x = ${1:3.14}, y = ${2:3.14}, z = ${3:3.14})${}"# ); } diff --git a/rust/kcl-lib/src/engine/conn_wasm.rs b/rust/kcl-lib/src/engine/conn_wasm.rs index ee023ce24..2242f8f83 100644 --- a/rust/kcl-lib/src/engine/conn_wasm.rs +++ b/rust/kcl-lib/src/engine/conn_wasm.rs @@ -121,6 +121,13 @@ impl EngineConnection { } })?; + if value.is_null() || value.is_undefined() { + return Err(KclError::Engine(KclErrorDetails { + message: "Received null or undefined response from engine".into(), + source_ranges: vec![source_range], + })); + } + // Convert JsValue to a Uint8Array let data = js_sys::Uint8Array::from(value); diff --git a/rust/kcl-lib/src/engine/mod.rs b/rust/kcl-lib/src/engine/mod.rs index fd20fcd80..6cef90c8e 100644 --- a/rust/kcl-lib/src/engine/mod.rs +++ b/rust/kcl-lib/src/engine/mod.rs @@ -170,12 +170,16 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { self.clear_queues().await; self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::SceneClearAll(mcmd::SceneClearAll::default()), ) .await?; + // Reset to the default units. Modules assume the engine starts in the + // default state. + self.set_units(Default::default(), source_range, id_generator).await?; + // Flush the batch queue, so clear is run right away. // Otherwise the hooks below won't work. self.flush_batch(false, source_range).await?; @@ -195,9 +199,10 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { &self, visible: bool, source_range: SourceRange, + id_generator: &mut IdGenerator, ) -> Result<(), crate::errors::KclError> { self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::from(mcmd::EdgeLinesVisible { hidden: !visible }), ) @@ -231,10 +236,11 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { &self, units: crate::UnitLength, source_range: SourceRange, + id_generator: &mut IdGenerator, ) -> Result<(), crate::errors::KclError> { // Before we even start executing the program, set the units. self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::from(mcmd::SetSceneUnits { unit: units.into() }), ) @@ -248,15 +254,15 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { &self, settings: &crate::ExecutorSettings, source_range: SourceRange, + id_generator: &mut IdGenerator, ) -> Result<(), crate::errors::KclError> { // Set the edge visibility. - self.set_edge_visibility(settings.highlight_edges, source_range).await?; - - // Change the units. - self.set_units(settings.units, source_range).await?; + self.set_edge_visibility(settings.highlight_edges, source_range, id_generator) + .await?; // Send the command to show the grid. - self.modify_grid(!settings.show_grid, source_range).await?; + self.modify_grid(!settings.show_grid, source_range, id_generator) + .await?; // We do not have commands for changing ssao on the fly. @@ -502,6 +508,7 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { y_axis: Point3d, color: Option, source_range: SourceRange, + id_generator: &mut IdGenerator, ) -> Result { // Create new default planes. let default_size = 100.0; @@ -524,7 +531,7 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { if let Some(color) = color { // Set the color. self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::from(mcmd::PlaneSetColor { color, plane_id }), ) @@ -615,7 +622,7 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { for (name, plane_id, x_axis, y_axis, color) in plane_settings { planes.insert( name, - self.make_default_plane(plane_id, x_axis, y_axis, color, source_range) + self.make_default_plane(plane_id, x_axis, y_axis, color, source_range, id_generator) .await?, ); } @@ -701,10 +708,15 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { })) } - async fn modify_grid(&self, hidden: bool, source_range: SourceRange) -> Result<(), KclError> { + async fn modify_grid( + &self, + hidden: bool, + source_range: SourceRange, + id_generator: &mut IdGenerator, + ) -> Result<(), KclError> { // Hide/show the grid. self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::from(mcmd::ObjectVisible { hidden, @@ -715,7 +727,7 @@ pub trait EngineManager: std::fmt::Debug + Send + Sync + 'static { // Hide/show the grid scale text. self.batch_modeling_cmd( - uuid::Uuid::new_v4(), + id_generator.next_uuid(), source_range, &ModelingCmd::from(mcmd::ObjectVisible { hidden, diff --git a/rust/kcl-lib/src/execution/cache.rs b/rust/kcl-lib/src/execution/cache.rs index dcbecfc1c..b9c69a69f 100644 --- a/rust/kcl-lib/src/execution/cache.rs +++ b/rust/kcl-lib/src/execution/cache.rs @@ -6,7 +6,7 @@ use itertools::{EitherOrBoth, Itertools}; use tokio::sync::RwLock; use crate::{ - execution::{annotations, memory::Stack, EnvironmentRef, ExecState, ExecutorSettings}, + execution::{annotations, memory::Stack, state::ModuleInfoMap, EnvironmentRef, ExecState, ExecutorSettings}, parsing::ast::types::{Annotation, Node, Program}, walk::Node as WalkNode, }; @@ -15,7 +15,7 @@ lazy_static::lazy_static! { /// A static mutable lock for updating the last successful execution state for the cache. static ref OLD_AST: Arc>> = Default::default(); // The last successful run's memory. Not cleared after an unssuccessful run. - static ref PREV_MEMORY: Arc>> = Default::default(); + static ref PREV_MEMORY: Arc>> = Default::default(); } /// Read the old ast memory from the lock. @@ -29,12 +29,12 @@ pub(super) async fn write_old_ast(old_state: OldAstState) { *old_ast = Some(old_state); } -pub(crate) async fn read_old_memory() -> Option { +pub(crate) async fn read_old_memory() -> Option<(Stack, ModuleInfoMap)> { let old_mem = PREV_MEMORY.read().await; old_mem.clone() } -pub(super) async fn write_old_memory(mem: Stack) { +pub(super) async fn write_old_memory(mem: (Stack, ModuleInfoMap)) { let mut old_mem = PREV_MEMORY.write().await; *old_mem = Some(mem); } @@ -97,15 +97,6 @@ pub(super) async fn get_changed_program(old: CacheInformation<'_>, new: CacheInf // If the settings are different we might need to bust the cache. // We specifically do this before checking if they are the exact same. if old.settings != new.settings { - // If the units are different we need to re-execute the whole thing. - if old.settings.units != new.settings.units { - return CacheResult::ReExecute { - clear_scene: true, - reapply_settings: true, - program: new.ast.clone(), - }; - } - // If anything else is different we may not need to re-execute, but rather just // run the settings again. reapply_settings = true; @@ -424,50 +415,6 @@ shell(firstSketch, faces = ['end'], thickness = 0.25)"#; assert_eq!(result, CacheResult::NoAction(false)); } - // Changing the units with the exact same file should bust the cache. - #[tokio::test(flavor = "multi_thread")] - async fn test_get_changed_program_same_code_but_different_units() { - let new = r#"// Remove the end face for the extrusion. -firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) - |> line(end = [24, 0]) - |> line(end = [0, -24]) - |> line(end = [-24, 0]) - |> close() - |> extrude(length = 6) - -// Remove the end face for the extrusion. -shell(firstSketch, faces = ['end'], thickness = 0.25)"#; - - let ExecTestResults { - program, mut exec_ctxt, .. - } = parse_execute(new).await.unwrap(); - - // Change the settings to cm. - exec_ctxt.settings.units = crate::UnitLength::Cm; - - let result = get_changed_program( - CacheInformation { - ast: &program.ast, - settings: &Default::default(), - }, - CacheInformation { - ast: &program.ast, - settings: &exec_ctxt.settings, - }, - ) - .await; - - assert_eq!( - result, - CacheResult::ReExecute { - clear_scene: true, - reapply_settings: true, - program: program.ast - } - ); - } - // Changing the grid settings with the exact same file should NOT bust the cache. #[tokio::test(flavor = "multi_thread")] async fn test_get_changed_program_same_code_but_different_grid_setting() { @@ -615,4 +562,42 @@ startSketchOn('XY') } ); } + + // Removing the units settings using an annotation, when it was non-default + // units, with the exact same file should bust the cache. + #[tokio::test(flavor = "multi_thread")] + async fn test_get_changed_program_same_code_but_removed_unit_setting_using_annotation() { + let old_code = r#"@settings(defaultLengthUnit = in) +startSketchOn('XY') +"#; + let new_code = r#" +startSketchOn('XY') +"#; + + let ExecTestResults { program, exec_ctxt, .. } = parse_execute(old_code).await.unwrap(); + + let mut new_program = crate::Program::parse_no_errs(new_code).unwrap(); + new_program.compute_digest(); + + let result = get_changed_program( + CacheInformation { + ast: &program.ast, + settings: &exec_ctxt.settings, + }, + CacheInformation { + ast: &new_program.ast, + settings: &exec_ctxt.settings, + }, + ) + .await; + + assert_eq!( + result, + CacheResult::ReExecute { + clear_scene: true, + reapply_settings: true, + program: new_program.ast + } + ); + } } diff --git a/rust/kcl-lib/src/execution/exec_ast.rs b/rust/kcl-lib/src/execution/exec_ast.rs index 1c0d400d4..15bc878e2 100644 --- a/rust/kcl-lib/src/execution/exec_ast.rs +++ b/rust/kcl-lib/src/execution/exec_ast.rs @@ -64,7 +64,11 @@ impl ExecutorContext { let new_units = exec_state.length_unit(); if !self.engine.execution_kind().await.is_isolated() { self.engine - .set_units(new_units.into(), annotation.as_source_range()) + .set_units( + new_units.into(), + annotation.as_source_range(), + exec_state.id_generator(), + ) .await?; } } else { @@ -106,12 +110,7 @@ impl ExecutorContext { let old_units = exec_state.length_unit(); let original_execution = self.engine.replace_execution_kind(exec_kind).await; - let mut local_state = ModuleState::new( - &self.settings, - path.std_path(), - exec_state.stack().memory.clone(), - Some(module_id), - ); + let mut local_state = ModuleState::new(path.std_path(), exec_state.stack().memory.clone(), Some(module_id)); if !preserve_mem { std::mem::swap(&mut exec_state.mod_local, &mut local_state); } @@ -143,7 +142,9 @@ impl ExecutorContext { // command and we'd need to flush the batch again. // This avoids that. if !exec_kind.is_isolated() && new_units != old_units && *path != ModulePath::Main { - self.engine.set_units(old_units.into(), Default::default()).await?; + self.engine + .set_units(old_units.into(), Default::default(), exec_state.id_generator()) + .await?; } self.engine.replace_execution_kind(original_execution).await; diff --git a/rust/kcl-lib/src/execution/id_generator.rs b/rust/kcl-lib/src/execution/id_generator.rs index e1cd37e0a..4fb1d0890 100644 --- a/rust/kcl-lib/src/execution/id_generator.rs +++ b/rust/kcl-lib/src/execution/id_generator.rs @@ -2,7 +2,7 @@ use crate::execution::ModuleId; -const NAMESPACE_KCL: uuid::Uuid = uuid::uuid!("efcd6508-4ce6-4a09-8317-e6a6994a3cd7"); +const NAMESPACE_KCL: uuid::Uuid = uuid::uuid!("8bda3118-75eb-58c7-a866-bef1dcb495e7"); /// A generator for ArtifactIds that can be stable across executions. #[derive(Debug, Clone, Default, PartialEq)] diff --git a/rust/kcl-lib/src/execution/mod.rs b/rust/kcl-lib/src/execution/mod.rs index 6c1de6748..d6b66cf59 100644 --- a/rust/kcl-lib/src/execution/mod.rs +++ b/rust/kcl-lib/src/execution/mod.rs @@ -40,7 +40,6 @@ use crate::{ fs::FileManager, modules::{ModuleId, ModulePath}, parsing::ast::types::{Expr, ImportPath, NodeRef}, - settings::types::UnitLength, source_range::SourceRange, std::StdLib, CompilationError, ExecError, ExecutionKind, KclErrorWithOutputs, @@ -266,8 +265,6 @@ pub struct ExecutorContext { #[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)] #[ts(export)] pub struct ExecutorSettings { - /// The project-default unit to use in modeling dimensions. - pub units: UnitLength, /// Highlight edges of 3D objects? pub highlight_edges: bool, /// Whether or not Screen Space Ambient Occlusion (SSAO) is enabled. @@ -288,7 +285,6 @@ pub struct ExecutorSettings { impl Default for ExecutorSettings { fn default() -> Self { Self { - units: Default::default(), highlight_edges: true, enable_ssao: false, show_grid: false, @@ -302,7 +298,6 @@ impl Default for ExecutorSettings { impl From for ExecutorSettings { fn from(config: crate::settings::types::Configuration) -> Self { Self { - units: config.settings.modeling.base_unit, highlight_edges: config.settings.modeling.highlight_edges.into(), enable_ssao: config.settings.modeling.enable_ssao.into(), show_grid: config.settings.modeling.show_scale_grid, @@ -316,7 +311,6 @@ impl From for ExecutorSettings { impl From for ExecutorSettings { fn from(config: crate::settings::types::project::ProjectConfiguration) -> Self { Self { - units: config.settings.modeling.base_unit, highlight_edges: config.settings.modeling.highlight_edges.into(), enable_ssao: config.settings.modeling.enable_ssao.into(), show_grid: Default::default(), @@ -330,7 +324,6 @@ impl From for ExecutorSet impl From for ExecutorSettings { fn from(modeling: crate::settings::types::ModelingSettings) -> Self { Self { - units: modeling.base_unit, highlight_edges: modeling.highlight_edges.into(), enable_ssao: modeling.enable_ssao.into(), show_grid: modeling.show_scale_grid, @@ -344,7 +337,6 @@ impl From for ExecutorSettings { impl From for ExecutorSettings { fn from(modeling: crate::settings::types::project::ProjectModelingSettings) -> Self { Self { - units: modeling.base_unit, highlight_edges: modeling.highlight_edges.into(), enable_ssao: modeling.enable_ssao.into(), show_grid: Default::default(), @@ -492,26 +484,17 @@ impl ExecutorContext { /// This allows for passing in `ZOO_API_TOKEN` and `ZOO_HOST` as environment /// variables. #[cfg(not(target_arch = "wasm32"))] - pub async fn new_with_default_client(units: UnitLength) -> Result { + pub async fn new_with_default_client() -> Result { // Create the client. - let ctx = Self::new_with_client( - ExecutorSettings { - units, - ..Default::default() - }, - None, - None, - ) - .await?; + let ctx = Self::new_with_client(Default::default(), None, None).await?; Ok(ctx) } /// For executing unit tests. #[cfg(not(target_arch = "wasm32"))] - pub async fn new_for_unit_test(units: UnitLength, engine_addr: Option) -> Result { + pub async fn new_for_unit_test(engine_addr: Option) -> Result { let ctx = ExecutorContext::new_with_client( ExecutorSettings { - units, highlight_edges: true, enable_ssao: false, show_grid: false, @@ -545,6 +528,18 @@ impl ExecutorContext { .await } + pub async fn bust_cache_and_reset_scene(&self) -> Result { + cache::bust_cache().await; + + // Execute an empty program to clear and reset the scene. + // We specifically want to be returned the objects after the scene is reset. + // Like the default planes so it is easier to just execute an empty program + // after the cache is busted. + let outcome = self.run_with_caching(crate::Program::empty()).await?; + + Ok(outcome) + } + async fn prepare_mem(&self, exec_state: &mut ExecState) -> Result<(), KclErrorWithOutputs> { self.eval_prelude(exec_state, SourceRange::synthetic()) .await @@ -563,7 +558,10 @@ impl ExecutorContext { let mut exec_state = ExecState::new(self); if use_prev_memory { match cache::read_old_memory().await { - Some(mem) => *exec_state.mut_stack() = mem, + Some(mem) => { + *exec_state.mut_stack() = mem.0; + exec_state.global.module_infos = mem.1; + } None => self.prepare_mem(&mut exec_state).await?, } } else { @@ -581,10 +579,11 @@ impl ExecutorContext { // memory, not to the exec_state which is not cached for mock execution. let mut mem = exec_state.stack().clone(); + let module_infos = exec_state.global.module_infos.clone(); let outcome = exec_state.to_mock_wasm_outcome(result.0).await; mem.squash_env(result.0); - cache::write_old_memory(mem).await; + cache::write_old_memory((mem, module_infos)).await; Ok(outcome) } @@ -618,7 +617,7 @@ impl ExecutorContext { if reapply_settings && self .engine - .reapply_settings(&self.settings, Default::default()) + .reapply_settings(&self.settings, Default::default(), old_state.id_generator()) .await .is_err() { @@ -636,7 +635,7 @@ impl ExecutorContext { CacheResult::NoAction(true) => { if self .engine - .reapply_settings(&self.settings, Default::default()) + .reapply_settings(&self.settings, Default::default(), old_state.id_generator()) .await .is_ok() { @@ -737,7 +736,7 @@ impl ExecutorContext { // Re-apply the settings, in case the cache was busted. self.engine - .reapply_settings(&self.settings, Default::default()) + .reapply_settings(&self.settings, Default::default(), exec_state.id_generator()) .await .map_err(KclErrorWithOutputs::no_outputs)?; @@ -774,7 +773,7 @@ impl ExecutorContext { if !self.is_mock() { let mut mem = exec_state.stack().deep_clone(); mem.restore_env(env_ref); - cache::write_old_memory(mem).await; + cache::write_old_memory((mem, exec_state.global.module_infos.clone())).await; } let session_data = self.engine.get_session_data().await; Ok((env_ref, session_data)) @@ -862,11 +861,6 @@ impl ExecutorContext { Ok(()) } - /// Update the units for the executor. - pub(crate) fn update_units(&mut self, units: UnitLength) { - self.settings.units = units; - } - /// Get a snapshot of the current scene. pub async fn prepare_snapshot(&self) -> std::result::Result { // Zoom to fit. @@ -1008,11 +1002,7 @@ mod tests { use pretty_assertions::assert_eq; use super::*; - use crate::{ - errors::{KclErrorDetails, Severity}, - execution::memory::Stack, - ModuleId, - }; + use crate::{errors::KclErrorDetails, execution::memory::Stack, ModuleId}; /// Convenience function to get a JSON value from memory and unwrap. #[track_caller] @@ -1615,34 +1605,6 @@ const inInches = 2.0 * inch()"#; ); } - #[tokio::test(flavor = "multi_thread")] - async fn test_unit_suggest() { - let src = "foo = 42"; - let program = crate::Program::parse_no_errs(src).unwrap(); - let ctx = ExecutorContext { - engine: Arc::new(Box::new( - crate::engine::conn_mock::EngineConnection::new().await.unwrap(), - )), - fs: Arc::new(crate::fs::FileManager::new()), - stdlib: Arc::new(crate::std::StdLib::new()), - settings: ExecutorSettings { - units: UnitLength::Ft, - ..Default::default() - }, - context_type: ContextType::Mock, - }; - let mut exec_state = ExecState::new(&ctx); - ctx.run(&program, &mut exec_state).await.unwrap(); - let errs = exec_state.errors(); - assert_eq!(errs.len(), 1, "{errs:?}"); - let warn = &errs[0]; - assert_eq!(warn.severity, Severity::Warning); - assert_eq!( - warn.apply_suggestion(src).unwrap(), - "@settings(defaultLengthUnit = ft)\nfoo = 42" - ) - } - #[tokio::test(flavor = "multi_thread")] async fn test_zero_param_fn() { let ast = r#"const sigmaAllow = 35000 // psi @@ -1971,9 +1933,7 @@ let w = f() + f() ) "#; - let ctx = crate::test_server::new_context(UnitLength::Mm, true, None) - .await - .unwrap(); + let ctx = crate::test_server::new_context(true, None).await.unwrap(); let old_program = crate::Program::parse_no_errs(code).unwrap(); // Execute the program. @@ -2026,9 +1986,7 @@ let w = f() + f() ) "#; - let mut ctx = crate::test_server::new_context(UnitLength::Mm, true, None) - .await - .unwrap(); + let mut ctx = crate::test_server::new_context(true, None).await.unwrap(); let old_program = crate::Program::parse_no_errs(code).unwrap(); // Execute the program. @@ -2060,11 +2018,13 @@ let w = f() + f() // Ensure the settings are as expected. assert_eq!(settings_state, ctx.settings); + + ctx.close().await; } #[tokio::test(flavor = "multi_thread")] async fn mock_after_not_mock() { - let ctx = ExecutorContext::new_with_default_client(UnitLength::Mm).await.unwrap(); + let ctx = ExecutorContext::new_with_default_client().await.unwrap(); let program = crate::Program::parse_no_errs("x = 2").unwrap(); let result = ctx.run_with_caching(program).await.unwrap(); assert_eq!(result.variables.get("x").unwrap().as_f64().unwrap(), 2.0); @@ -2073,6 +2033,9 @@ let w = f() + f() let program2 = crate::Program::parse_no_errs("z = x + 1").unwrap(); let result = ctx2.run_mock(program2, true).await.unwrap(); assert_eq!(result.variables.get("z").unwrap().as_f64().unwrap(), 3.0); + + ctx.close().await; + ctx2.close().await; } #[tokio::test(flavor = "multi_thread")] diff --git a/rust/kcl-lib/src/execution/state.rs b/rust/kcl-lib/src/execution/state.rs index 803ea150c..f23e65efe 100644 --- a/rust/kcl-lib/src/execution/state.rs +++ b/rust/kcl-lib/src/execution/state.rs @@ -30,6 +30,8 @@ pub struct ExecState { pub(super) exec_context: Option, } +pub type ModuleInfoMap = IndexMap; + #[derive(Debug, Clone)] pub(super) struct GlobalState { /// Map from source file absolute path to module ID. @@ -37,7 +39,7 @@ pub(super) struct GlobalState { /// Map from module ID to source file. pub id_to_source: IndexMap, /// Map from module ID to module info. - pub module_infos: IndexMap, + pub module_infos: ModuleInfoMap, /// Output map of UUIDs to artifacts. pub artifacts: IndexMap, /// Output commands to allow building the artifact graph by the caller. @@ -80,7 +82,7 @@ impl ExecState { pub fn new(exec_context: &super::ExecutorContext) -> Self { ExecState { global: GlobalState::new(&exec_context.settings), - mod_local: ModuleState::new(&exec_context.settings, None, ProgramMemory::new(), Default::default()), + mod_local: ModuleState::new(None, ProgramMemory::new(), Default::default()), exec_context: Some(exec_context.clone()), } } @@ -90,7 +92,7 @@ impl ExecState { *self = ExecState { global, - mod_local: ModuleState::new(&exec_context.settings, None, ProgramMemory::new(), Default::default()), + mod_local: ModuleState::new(None, ProgramMemory::new(), Default::default()), exec_context: Some(exec_context.clone()), }; } @@ -291,12 +293,7 @@ impl GlobalState { } impl ModuleState { - pub(super) fn new( - exec_settings: &ExecutorSettings, - std_path: Option, - memory: Arc, - module_id: Option, - ) -> Self { + pub(super) fn new(std_path: Option, memory: Arc, module_id: Option) -> Self { ModuleState { id_generator: IdGenerator::new(module_id), stack: memory.new_stack(), @@ -305,14 +302,14 @@ impl ModuleState { explicit_length_units: false, std_path, settings: MetaSettings { - default_length_units: exec_settings.units.into(), + default_length_units: Default::default(), default_angle_units: Default::default(), }, } } } -#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)] +#[derive(Debug, Default, Clone, Deserialize, Serialize, PartialEq, Eq, ts_rs::TS, JsonSchema)] #[ts(export)] #[serde(rename_all = "camelCase")] pub struct MetaSettings { diff --git a/rust/kcl-lib/src/lib.rs b/rust/kcl-lib/src/lib.rs index 1ffd64486..d03015a8e 100644 --- a/rust/kcl-lib/src/lib.rs +++ b/rust/kcl-lib/src/lib.rs @@ -93,11 +93,11 @@ pub use lsp::{ kcl::{Backend as KclLspBackend, Server as KclLspServerSubCommand}, }; pub use modules::ModuleId; -pub use parsing::ast::{modify::modify_ast_for_sketch, types::FormatOptions}; +pub use parsing::ast::types::FormatOptions; pub use settings::types::{project::ProjectConfiguration, Configuration, UnitLength}; pub use source_range::SourceRange; #[cfg(not(target_arch = "wasm32"))] -pub use unparser::recast_dir; +pub use unparser::{recast_dir, walk_dir}; // Rather than make executor public and make lots of it pub(crate), just re-export into a new module. // Ideally we wouldn't export these things at all, they should only be used for testing. @@ -195,6 +195,10 @@ impl Program { }) } + pub fn is_empty_or_only_settings(&self) -> bool { + self.ast.is_empty_or_only_settings() + } + pub fn lint_all(&self) -> Result, anyhow::Error> { self.ast.lint_all() } @@ -211,6 +215,14 @@ impl Program { pub fn recast_with_options(&self, options: &FormatOptions) -> String { self.ast.recast(options, 0) } + + /// Create an empty program. + pub fn empty() -> Self { + Self { + ast: parsing::ast::types::Node::no_src(parsing::ast::types::Program::default()), + original_file_contents: String::new(), + } + } } #[inline] diff --git a/rust/kcl-lib/src/lsp/kcl/mod.rs b/rust/kcl-lib/src/lsp/kcl/mod.rs index c42c1fb66..465abce1b 100644 --- a/rust/kcl-lib/src/lsp/kcl/mod.rs +++ b/rust/kcl-lib/src/lsp/kcl/mod.rs @@ -786,7 +786,7 @@ impl Backend { vec![kittycad::types::multipart::Attachment { // Clean the URI part. name: "attachment".to_string(), - filename: Some("attachment.zip".to_string()), + filepath: Some("attachment.zip".into()), content_type: Some("application/x-zip".to_string()), data: self.create_zip().await?, }], @@ -812,56 +812,6 @@ impl Backend { Ok(()) } - pub async fn update_units( - &self, - params: custom_notifications::UpdateUnitsParams, - ) -> RpcResult> { - { - let mut ctx = self.executor_ctx.write().await; - // Borrow the executor context mutably. - let Some(ref mut executor_ctx) = *ctx else { - self.client - .log_message(MessageType::ERROR, "no executor context set to update units for") - .await; - return Ok(None); - }; - - self.client - .log_message(MessageType::INFO, format!("update units: {:?}", params)) - .await; - - if executor_ctx.settings.units == params.units - && !self.has_diagnostics(params.text_document.uri.as_ref()).await - { - // Return early the units are the same. - return Ok(None); - } - - // Set the engine units. - executor_ctx.update_units(params.units); - } - // Lock is dropped here since nested. - // This is IMPORTANT. - - let new_params = TextDocumentItem { - uri: params.text_document.uri.clone(), - text: std::mem::take(&mut params.text.to_string()), - version: Default::default(), - language_id: Default::default(), - }; - - // Force re-execution. - self.inner_on_change(new_params, true).await; - - // Check if we have diagnostics. - // If we do we return early, since we failed in some way. - if self.has_diagnostics(params.text_document.uri.as_ref()).await { - return Ok(None); - } - - Ok(Some(custom_notifications::UpdateUnitsResponse {})) - } - pub async fn update_can_execute( &self, params: custom_notifications::UpdateCanExecuteParams, @@ -1635,7 +1585,7 @@ fn position_to_char_index(position: Position, code: &str) -> usize { async fn with_cached_var(name: &str, f: impl Fn(&KclValue) -> T) -> Option { let mem = cache::read_old_memory().await?; - let value = mem.get(name, SourceRange::default()).ok()?; + let value = mem.0.get(name, SourceRange::default()).ok()?; Some(f(value)) } diff --git a/rust/kcl-lib/src/lsp/test_util.rs b/rust/kcl-lib/src/lsp/test_util.rs index e757a3a28..3b8aa5011 100644 --- a/rust/kcl-lib/src/lsp/test_util.rs +++ b/rust/kcl-lib/src/lsp/test_util.rs @@ -42,7 +42,6 @@ pub async fn kcl_lsp_server(execute: bool) -> Result { can_execute: Arc::new(tokio::sync::RwLock::new(can_execute)), is_initialized: Default::default(), }) - .custom_method("kcl/updateUnits", crate::lsp::kcl::Backend::update_units) .custom_method("kcl/updateCanExecute", crate::lsp::kcl::Backend::update_can_execute) .finish(); diff --git a/rust/kcl-lib/src/lsp/tests.rs b/rust/kcl-lib/src/lsp/tests.rs index d44c4402b..bd871da38 100644 --- a/rust/kcl-lib/src/lsp/tests.rs +++ b/rust/kcl-lib/src/lsp/tests.rs @@ -1016,6 +1016,8 @@ startSketchOn(XY) } _ => unreachable!(), } + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2318,78 +2320,8 @@ async fn kcl_test_kcl_lsp_on_change_update_memory() { }], }) .await; -} -#[tokio::test(flavor = "multi_thread", worker_threads = 10)] -async fn kcl_test_kcl_lsp_update_units() { - let server = kcl_lsp_server(true).await.unwrap(); - - let same_text = r#"fn cube = (pos, scale) => { - sg = startSketchOn(XY) - |> startProfileAt(pos, %) - |> line(end = [0, scale]) - |> line(end = [scale, 0]) - |> line(end = [0, -scale]) - - return sg -} -part001 = cube([0,0], 20) - |> close() - |> extrude(length = 20)"# - .to_string(); - - // Send open file. - server - .did_open(tower_lsp::lsp_types::DidOpenTextDocumentParams { - text_document: tower_lsp::lsp_types::TextDocumentItem { - uri: "file:///test.kcl".try_into().unwrap(), - language_id: "kcl".to_string(), - version: 1, - text: same_text.clone(), - }, - }) - .await; - - // Get the tokens. - let tokens = server.token_map.get("file:///test.kcl").unwrap().clone(); - assert_eq!(tokens.as_slice().len(), 123); - - // Get the ast. - let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); - assert_eq!(ast.ast.body.len(), 2); - - // Send change file. - server - .did_change(tower_lsp::lsp_types::DidChangeTextDocumentParams { - text_document: tower_lsp::lsp_types::VersionedTextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - version: 1, - }, - content_changes: vec![tower_lsp::lsp_types::TextDocumentContentChangeEvent { - range: None, - range_length: None, - text: same_text.clone(), - }], - }) - .await; - - let units = server.executor_ctx.read().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - - // Update the units. - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::M, - text: same_text.clone(), - }) - .await - .unwrap(); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::M); + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2506,6 +2438,8 @@ async fn kcl_test_kcl_lsp_diagnostics_on_execution_error() { // Get the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2556,6 +2490,8 @@ async fn kcl_test_kcl_lsp_full_to_empty_file_updates_ast_and_memory() { // Get the ast. let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); assert_eq!(ast.ast, default_hashed); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2642,6 +2578,8 @@ async fn kcl_test_kcl_lsp_code_unchanged_but_has_diagnostics_reexecute() { // Assure we have no diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2717,141 +2655,8 @@ async fn kcl_test_kcl_lsp_code_and_ast_unchanged_but_has_diagnostics_reexecute() // Assure we have no diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); -} -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_kcl_lsp_code_and_ast_units_unchanged_but_has_diagnostics_reexecute_on_unit_change() { - let server = kcl_lsp_server(true).await.unwrap(); - - let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) - |> line(end = [20, 0]) - |> line(end = [0, 20]) - |> line(end = [-20, 0]) - |> close() - |> extrude(length = 3.14)"#; - - // Send open file. - server - .did_open(tower_lsp::lsp_types::DidOpenTextDocumentParams { - text_document: tower_lsp::lsp_types::TextDocumentItem { - uri: "file:///test.kcl".try_into().unwrap(), - language_id: "kcl".to_string(), - version: 1, - text: code.to_string(), - }, - }) - .await; - - // Get the ast. - let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); - assert!(ast.ast != Node::::default()); - - // Assure we have no diagnostics. - assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); - - // Add some fake diagnostics. - server.diagnostics_map.insert( - "file:///test.kcl".to_string(), - vec![tower_lsp::lsp_types::Diagnostic { - range: tower_lsp::lsp_types::Range { - start: tower_lsp::lsp_types::Position { line: 0, character: 0 }, - end: tower_lsp::lsp_types::Position { line: 0, character: 0 }, - }, - message: "fake diagnostic".to_string(), - severity: Some(tower_lsp::lsp_types::DiagnosticSeverity::ERROR), - code: None, - source: None, - related_information: None, - tags: None, - data: None, - code_description: None, - }], - ); - // Assure we have one diagnostics. - assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 1); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - - // Update the units to the _same_ units. - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::Mm, - text: code.to_string(), - }) - .await - .unwrap(); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - - // Get the ast. - let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); - assert!(ast.ast != Node::::default()); - - // Assure we have no diagnostics. - assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); -} - -#[tokio::test(flavor = "multi_thread")] -async fn kcl_test_kcl_lsp_code_and_ast_units_unchanged_but_has_memory_reexecute_on_unit_change() { - let server = kcl_lsp_server(true).await.unwrap(); - - let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) - |> line(end = [20, 0]) - |> line(end = [0, 20]) - |> line(end = [-20, 0]) - |> close() - |> extrude(length = 3.14)"#; - - // Send open file. - server - .did_open(tower_lsp::lsp_types::DidOpenTextDocumentParams { - text_document: tower_lsp::lsp_types::TextDocumentItem { - uri: "file:///test.kcl".try_into().unwrap(), - language_id: "kcl".to_string(), - version: 1, - text: code.to_string(), - }, - }) - .await; - - // Get the ast. - let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); - assert!(ast.ast != Node::::default()); - - // Assure we have no diagnostics. - assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - - // Update the units to the _same_ units. - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::Mm, - text: code.to_string(), - }) - .await - .unwrap(); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - - // Get the ast. - let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); - assert!(ast.ast != Node::::default()); - - // Assure we have no diagnostics. - assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -2885,23 +2690,6 @@ async fn kcl_test_kcl_lsp_cant_execute_set() { // Assure we have no diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); - // Update the units to the _same_ units. - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::Mm, - text: code.to_string(), - }) - .await - .unwrap(); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - // Get the ast. let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); assert!(ast.ast != Node::::default()); @@ -2918,23 +2706,6 @@ async fn kcl_test_kcl_lsp_cant_execute_set() { .unwrap(); assert_eq!(server.can_execute().await, false); - // Update the units to the _same_ units. - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::Mm, - text: code.to_string(), - }) - .await - .unwrap(); - - let units = server.executor_ctx().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - let mut default_hashed = Node::::default(); default_hashed.compute_digest(); @@ -2952,29 +2723,14 @@ async fn kcl_test_kcl_lsp_cant_execute_set() { .unwrap(); assert_eq!(server.can_execute().await, true); - // Update the units to the _same_ units. - let units = server.executor_ctx.read().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - server - .update_units(crate::lsp::kcl::custom_notifications::UpdateUnitsParams { - text_document: crate::lsp::kcl::custom_notifications::TextDocumentIdentifier { - uri: "file:///test.kcl".try_into().unwrap(), - }, - units: crate::settings::types::UnitLength::Mm, - text: code.to_string(), - }) - .await - .unwrap(); - - let units = server.executor_ctx.read().await.clone().unwrap().settings.units; - assert_eq!(units, crate::settings::types::UnitLength::Mm); - // Get the ast. let ast = server.ast_map.get("file:///test.kcl").unwrap().clone(); assert!(ast.ast != Node::::default()); // Assure we have no diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 0); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3243,6 +2999,8 @@ part001 = startSketchOn(XY) // Check the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 2); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3310,6 +3068,8 @@ NEW_LINT = 1"# // Check the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 2); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3377,6 +3137,8 @@ NEW_LINT = 1"# // Check the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 1); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3460,6 +3222,8 @@ NEW_LINT = 1"# // Check the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 1); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3551,6 +3315,8 @@ part001 = startSketchOn(XY) // Check the diagnostics. assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 2); + + server.executor_ctx().await.clone().unwrap().close().await; } #[tokio::test(flavor = "multi_thread")] @@ -3649,4 +3415,6 @@ async fn kcl_test_kcl_lsp_multi_file_error() { } else { panic!("Expected diagnostics"); } + + server.executor_ctx().await.clone().unwrap().close().await; } diff --git a/rust/kcl-lib/src/modules.rs b/rust/kcl-lib/src/modules.rs index 9e6c248eb..9107f7714 100644 --- a/rust/kcl-lib/src/modules.rs +++ b/rust/kcl-lib/src/modules.rs @@ -88,6 +88,7 @@ pub(crate) fn read_std(mod_name: &str) -> Option<&'static str> { "prelude" => Some(include_str!("../std/prelude.kcl")), "math" => Some(include_str!("../std/math.kcl")), "sketch" => Some(include_str!("../std/sketch.kcl")), + "turns" => Some(include_str!("../std/turns.kcl")), _ => None, } } diff --git a/rust/kcl-lib/src/parsing/ast/mod.rs b/rust/kcl-lib/src/parsing/ast/mod.rs index 5f58caf9c..ed23328e3 100644 --- a/rust/kcl-lib/src/parsing/ast/mod.rs +++ b/rust/kcl-lib/src/parsing/ast/mod.rs @@ -1,5 +1,4 @@ pub(crate) mod digest; -pub mod modify; pub mod types; use crate::{ diff --git a/rust/kcl-lib/src/parsing/ast/modify.rs b/rust/kcl-lib/src/parsing/ast/modify.rs deleted file mode 100644 index a55da9180..000000000 --- a/rust/kcl-lib/src/parsing/ast/modify.rs +++ /dev/null @@ -1,285 +0,0 @@ -use std::sync::Arc; - -use kcmc::{ - each_cmd as mcmd, ok_response::OkModelingCmdResponse, shared::PathCommand, websocket::OkWebSocketResponseData, - ModelingCmd, -}; -use kittycad_modeling_cmds as kcmc; - -use super::types::{CallExpressionKw, Identifier, LabeledArg, LiteralValue}; -use crate::{ - engine::EngineManager, - errors::{KclError, KclErrorDetails}, - execution::Point2d, - parsing::ast::types::{ - ArrayExpression, CallExpression, ConstraintLevel, FormatOptions, Literal, Node, PipeExpression, - PipeSubstitution, VariableDeclarator, - }, - source_range::SourceRange, - ModuleId, Program, -}; - -type Point3d = kcmc::shared::Point3d; - -#[derive(Debug)] -/// The control point data for a curve or line. -struct ControlPointData { - /// The control points for the curve or line. - points: Vec, - /// The command that created this curve or line. - _command: PathCommand, - /// The id of the curve or line. - _id: uuid::Uuid, -} - -const EPSILON: f64 = 0.015625; // or 2^-6 - -/// Update the AST to reflect the new state of the program after something like -/// a move or a new line. -pub async fn modify_ast_for_sketch( - engine: &Arc>, - program: &mut Program, - module_id: ModuleId, - // The name of the sketch. - sketch_name: &str, - // The type of plane the sketch is on. `XY` or `XZ`, etc - plane: crate::execution::PlaneType, - // The ID of the parent sketch. - sketch_id: uuid::Uuid, -) -> Result { - // First we need to check if this sketch is constrained (even partially). - // If it is, we cannot modify it. - - // Get the information about the sketch. - if let Some(ast_sketch) = program.ast.get_variable(sketch_name) { - let constraint_level = match ast_sketch { - super::types::Definition::Variable(var) => var.get_constraint_level(), - super::types::Definition::Import(import) => import.get_constraint_level(), - super::types::Definition::Type(_) => ConstraintLevel::Ignore { - source_ranges: Vec::new(), - }, - }; - match &constraint_level { - ConstraintLevel::None { source_ranges: _ } => {} - ConstraintLevel::Ignore { source_ranges: _ } => {} - ConstraintLevel::Partial { - source_ranges: _, - levels, - } => { - return Err(KclError::Engine(KclErrorDetails { - message: format!( - "Sketch {} is constrained `{}` and cannot be modified", - sketch_name, constraint_level - ), - source_ranges: levels.get_all_partial_or_full_source_ranges(), - })); - } - ConstraintLevel::Full { source_ranges } => { - return Err(KclError::Engine(KclErrorDetails { - message: format!( - "Sketch {} is constrained `{}` and cannot be modified", - sketch_name, constraint_level - ), - source_ranges: source_ranges.clone(), - })); - } - } - } - - // Let's start by getting the path info. - - // Let's get the path info. - let resp = engine - .send_modeling_cmd( - uuid::Uuid::new_v4(), - SourceRange::default(), - &ModelingCmd::PathGetInfo(mcmd::PathGetInfo { path_id: sketch_id }), - ) - .await?; - - let OkWebSocketResponseData::Modeling { - modeling_response: OkModelingCmdResponse::PathGetInfo(path_info), - } = &resp - else { - return Err(KclError::Engine(KclErrorDetails { - message: format!("Get path info response was not as expected: {:?}", resp), - source_ranges: vec![SourceRange::default()], - })); - }; - - // Now let's get the control points for all the segments. - // TODO: We should probably await all these at once so we aren't going one by one. - // But I guess this is fine for now. - // We absolutely have to preserve the order of the control points. - let mut control_points = Vec::new(); - for segment in &path_info.segments { - if let Some(command_id) = &segment.command_id { - let cmd = ModelingCmd::from(mcmd::CurveGetControlPoints { - curve_id: (*command_id).into(), - }); - let h = engine.send_modeling_cmd(uuid::Uuid::new_v4(), SourceRange::default(), &cmd); - - let OkWebSocketResponseData::Modeling { - modeling_response: OkModelingCmdResponse::CurveGetControlPoints(data), - } = h.await? - else { - return Err(KclError::Engine(KclErrorDetails { - message: format!("Curve get control points response was not as expected: {:?}", resp), - source_ranges: vec![SourceRange::default()], - })); - }; - - control_points.push(ControlPointData { - points: data.control_points.clone(), - _command: segment.command, - _id: (*command_id).into(), - }); - } - } - - if control_points.is_empty() { - return Err(KclError::Engine(KclErrorDetails { - message: format!("No control points found for sketch {}", sketch_name), - source_ranges: vec![SourceRange::default()], - })); - } - - let first_control_points = control_points.first().ok_or_else(|| { - KclError::Engine(KclErrorDetails { - message: format!("No control points found for sketch {}", sketch_name), - source_ranges: vec![SourceRange::default()], - }) - })?; - - let mut additional_lines = Vec::new(); - let mut last_point = first_control_points.points[1]; - for control_point in control_points[1..].iter() { - additional_lines.push([ - (control_point.points[1].x - last_point.x), - (control_point.points[1].y - last_point.y), - ]); - last_point = Point3d { - x: control_point.points[1].x, - y: control_point.points[1].y, - z: control_point.points[1].z, - }; - } - - // Okay now let's recalculate the sketch from the control points. - let start_sketch_at_end = Point3d { - x: (first_control_points.points[1].x - first_control_points.points[0].x), - y: (first_control_points.points[1].y - first_control_points.points[0].y), - z: (first_control_points.points[1].z - first_control_points.points[0].z), - }; - let sketch = create_start_sketch_on( - sketch_name, - [first_control_points.points[0].x, first_control_points.points[0].y], - [start_sketch_at_end.x, start_sketch_at_end.y], - plane, - additional_lines, - )?; - - // Add the sketch back to the program. - program.ast.replace_variable(sketch_name, sketch); - - let recasted = program.ast.recast(&FormatOptions::default(), 0); - - // Re-parse the ast so we get the correct source ranges. - program.ast = crate::parsing::parse_str(&recasted, module_id).parse_errs_as_err()?; - - Ok(recasted) -} - -/// Create a pipe expression that starts a sketch at the given point and draws a line to the given point. -fn create_start_sketch_on( - name: &str, - start: [f64; 2], - end: [f64; 2], - plane: crate::execution::PlaneType, - additional_lines: Vec<[f64; 2]>, -) -> Result, KclError> { - let start_sketch_on = CallExpression::new("startSketchOn", vec![Literal::new(plane.to_string().into()).into()])?; - let start_profile_at = CallExpression::new( - "startProfileAt", - vec![ - ArrayExpression::new(vec![ - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(start[0]))).into(), - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(start[1]))).into(), - ]) - .into(), - PipeSubstitution::new().into(), - ], - )?; - - // Keep track of where we are so we can close the sketch if we need to. - let mut current_position = Point2d { - x: start[0], - y: start[1], - }; - current_position.x += end[0]; - current_position.y += end[1]; - - let expr = ArrayExpression::new(vec![ - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(end[0]))).into(), - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(end[1]))).into(), - ]) - .into(); - let initial_line = CallExpressionKw::new( - "line", - None, - vec![LabeledArg { - label: Node::no_src(super::types::Identifier { - name: "end".to_owned(), - digest: None, - }), - arg: expr, - }], - )?; - - let mut pipe_body = vec![start_sketch_on.into(), start_profile_at.into(), initial_line.into()]; - - for (index, line) in additional_lines.iter().enumerate() { - current_position.x += line[0]; - current_position.y += line[1]; - - // If we are on the last line, check if we have to close the sketch. - if index == additional_lines.len() - 1 { - let diff_x = (current_position.x - start[0]).abs(); - let diff_y = (current_position.y - start[1]).abs(); - // Compare the end of the last line to the start of the first line. - // This is a bit more lenient if you look at the value of epsilon. - if diff_x <= EPSILON && diff_y <= EPSILON { - // We have to close the sketch. - let close = CallExpressionKw::new("close", None, vec![])?; - pipe_body.push(close.into()); - break; - } - } - - // TODO: we should check if we should close the sketch. - let expr = ArrayExpression::new(vec![ - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(line[0]))).into(), - Literal::new(LiteralValue::from_f64_no_uom(round_before_recast(line[1]))).into(), - ]) - .into(); - let line = CallExpressionKw::new( - "line", - None, - vec![LabeledArg { - arg: expr, - label: Node::no_src(Identifier { - name: "end".to_owned(), - digest: None, - }), - }], - )?; - pipe_body.push(line.into()); - } - - Ok(VariableDeclarator::new(name, PipeExpression::new(pipe_body).into())) -} - -fn round_before_recast(num: f64) -> f64 { - // We use 2 decimal places. - (num * 100.0).round() / 100.0 -} diff --git a/rust/kcl-lib/src/parsing/ast/types/mod.rs b/rust/kcl-lib/src/parsing/ast/types/mod.rs index 43f736fb8..f7938a293 100644 --- a/rust/kcl-lib/src/parsing/ast/types/mod.rs +++ b/rust/kcl-lib/src/parsing/ast/types/mod.rs @@ -133,6 +133,13 @@ impl Node { }) } + fn reset_source(&mut self) { + self.start = 0; + self.end = 0; + self.module_id = ModuleId::default(); + self.comment_start = 0; + } + pub fn as_source_range(&self) -> SourceRange { SourceRange::new(self.start, self.end, self.module_id) } @@ -345,7 +352,10 @@ impl Node { let mut found = false; for node in &mut new_program.inner_attrs { if node.name() == Some(annotations::SETTINGS) { - *node = Node::no_src(Annotation::new_from_meta_settings(&settings)); + node.inner = Annotation::new_from_meta_settings(&settings); + // Previous source range no longer makes sense, but we want to + // preserve other things like comments. + node.reset_source(); found = true; break; } @@ -359,6 +369,26 @@ impl Node { Ok(new_program) } + + /// Returns true if the given KCL is empty or only contains settings that + /// would be auto-generated. + pub fn is_empty_or_only_settings(&self) -> bool { + if !self.body.is_empty() { + return false; + } + + if self.non_code_meta.start_nodes.iter().any(|node| node.is_comment()) { + return false; + } + + for item in &self.inner_attrs { + if item.name() != Some(annotations::SETTINGS) { + return false; + } + } + + true + } } impl Program { @@ -1609,19 +1639,21 @@ impl ImportStatement { return Some(alias.name.clone()); } - let mut parts = match &self.path { - ImportPath::Kcl { filename: s } | ImportPath::Foreign { path: s } => s.split('.'), - _ => return None, - }; - let path = parts.next()?; - let _ext = parts.next()?; - let rest = parts.next(); + match &self.path { + ImportPath::Kcl { filename: s } | ImportPath::Foreign { path: s } => { + let mut parts = s.split('.'); + let path = parts.next()?; + let _ext = parts.next()?; + let rest = parts.next(); - if rest.is_some() { - return None; + if rest.is_some() { + return None; + } + + path.rsplit(&['/', '\\']).next().map(str::to_owned) + } + ImportPath::Std { path } => path.last().cloned(), } - - path.rsplit(&['/', '\\']).next().map(str::to_owned) } } @@ -3552,6 +3584,37 @@ mod tests { use super::*; + #[track_caller] + fn parse(code: &str) -> Node { + crate::parsing::top_level_parse(code).unwrap() + } + + #[test] + fn test_empty_or_only_settings() { + // Empty is empty. + assert!(parse("").is_empty_or_only_settings()); + + // Whitespace is empty. + assert!(parse(" ").is_empty_or_only_settings()); + + // Settings are empty. + assert!(parse(r#"@settings(defaultLengthUnit = mm)"#).is_empty_or_only_settings()); + + // Only comments is not empty. + assert!(!parse("// comment").is_empty_or_only_settings()); + + // Any statement is not empty. + assert!(!parse("5").is_empty_or_only_settings()); + + // Any statement is not empty, even with settings. + let code = r#"@settings(defaultLengthUnit = mm) +5"#; + assert!(!parse(code).is_empty_or_only_settings()); + + // Non-settings attributes are not empty. + assert!(!parse("@foo").is_empty_or_only_settings()); + } + // We have this as a test so we can ensure it never panics with an unwrap in the server. #[test] fn test_variable_kind_to_completion() { @@ -4140,6 +4203,50 @@ startSketchOn(XY) r#"@settings(defaultLengthUnit = mm) startSketchOn(XY) +"# + ); + } + + #[tokio::test(flavor = "multi_thread")] + async fn test_change_meta_settings_preserves_comments() { + let code = r#"// Title + +// Set Units +@settings(defaultLengthUnit = in) + +// Between + +// Above Code +5 +"#; + let program = crate::parsing::top_level_parse(code).unwrap(); + + let new_program = program + .change_meta_settings(crate::execution::MetaSettings { + default_length_units: crate::execution::types::UnitLen::Cm, + ..Default::default() + }) + .unwrap(); + + let result = new_program.meta_settings().unwrap(); + assert!(result.is_some()); + let meta_settings = result.unwrap(); + + assert_eq!(meta_settings.default_length_units, crate::execution::types::UnitLen::Cm); + + let formatted = new_program.recast(&Default::default(), 0); + + assert_eq!( + formatted, + r#"// Title + +// Set Units +@settings(defaultLengthUnit = cm) + +// Between + +// Above Code +5 "# ); } diff --git a/rust/kcl-lib/src/parsing/mod.rs b/rust/kcl-lib/src/parsing/mod.rs index d0a81f5cf..b9c734232 100644 --- a/rust/kcl-lib/src/parsing/mod.rs +++ b/rust/kcl-lib/src/parsing/mod.rs @@ -152,7 +152,12 @@ const STR_DEPRECATIONS: [(&str, &str); 6] = [ ("-YZ", "-YZ"), ]; const FN_DEPRECATIONS: [(&str, &str); 3] = [("pi", "PI"), ("e", "E"), ("tau", "TAU")]; -const CONST_DEPRECATIONS: [(&str, &str); 0] = []; +const CONST_DEPRECATIONS: [(&str, &str); 4] = [ + ("ZERO", "turns::ZERO"), + ("QUARTER_TURN", "turns::QUARTER_TURN"), + ("HALF_TURN", "turns::HALF_TURN"), + ("THREE_QUARTER_TURN", "turns::THREE_QUARTER_TURN"), +]; #[derive(Clone, Copy)] pub enum DeprecationKind { diff --git a/rust/kcl-lib/src/parsing/parser.rs b/rust/kcl-lib/src/parsing/parser.rs index b638aa422..bce94ea66 100644 --- a/rust/kcl-lib/src/parsing/parser.rs +++ b/rust/kcl-lib/src/parsing/parser.rs @@ -1823,14 +1823,6 @@ fn import_stmt(i: &mut TokenSlice) -> PResult> { ) .into(), )); - } else if matches!(path, ImportPath::Std { .. }) && matches!(selector, ImportSelector::None { .. }) { - return Err(ErrMode::Cut( - CompilationError::fatal( - SourceRange::new(start, end, module_id), - "the standard library cannot be imported as a part", - ) - .into(), - )); } Ok(Node::boxed( @@ -2341,21 +2333,6 @@ fn nameable_identifier(i: &mut TokenSlice) -> PResult> { )); } - if let Some(suggestion) = super::deprecation(&result.name, DeprecationKind::Const) { - ParseContext::warn( - CompilationError::err( - result.as_source_range(), - format!("Using `{}` is deprecated, prefer using `{}`.", result.name, suggestion), - ) - .with_suggestion( - format!("Replace `{}` with `{}`", result.name, suggestion), - suggestion, - None, - Tag::Deprecated, - ), - ); - } - Ok(result) } @@ -2374,8 +2351,7 @@ fn name(i: &mut TokenSlice) -> PResult> { let name = idents.pop().unwrap(); let end = name.end; let module_id = name.module_id; - - Ok(Node::new( + let result = Node::new( Name { name, path: idents, @@ -2385,7 +2361,24 @@ fn name(i: &mut TokenSlice) -> PResult> { start, end, module_id, - )) + ); + + if let Some(suggestion) = super::deprecation(&result.to_string(), DeprecationKind::Const) { + ParseContext::warn( + CompilationError::err( + result.as_source_range(), + format!("Using `{result}` is deprecated, prefer using `{suggestion}`."), + ) + .with_suggestion( + format!("Replace `{result}` with `{suggestion}`"), + suggestion, + None, + Tag::Deprecated, + ), + ); + } + + Ok(result) } impl TryFrom for Node { diff --git a/rust/kcl-lib/src/simulation_tests.rs b/rust/kcl-lib/src/simulation_tests.rs index b5af5869b..30358e57f 100644 --- a/rust/kcl-lib/src/simulation_tests.rs +++ b/rust/kcl-lib/src/simulation_tests.rs @@ -114,6 +114,8 @@ async fn unparse_test(test: &Test) { let kcl_files = kcl_files.into_iter().filter(|f| f != &entry_point); let futures = kcl_files .into_iter() + .filter(|file| file.extension().is_some_and(|ext| ext == "kcl")) // We only care about kcl + // files here. .map(|file| { let snap_path = Path::new("..").join(&test.output_dir); tokio::spawn(async move { @@ -153,13 +155,9 @@ async fn execute_test(test: &Test, render_to_png: bool, export_step: bool) { let ast = crate::Program::parse_no_errs(&input).unwrap(); // Run the program. - let exec_res = crate::test_server::execute_and_snapshot_ast( - ast, - crate::settings::types::UnitLength::Mm, - Some(test.input_dir.join(&test.entry_point)), - export_step, - ) - .await; + let exec_res = + crate::test_server::execute_and_snapshot_ast(ast, Some(test.input_dir.join(&test.entry_point)), export_step) + .await; match exec_res { Ok((exec_state, env_ref, png, step)) => { let fail_path = test.output_dir.join("execution_error.snap"); diff --git a/rust/kcl-lib/src/simulation_tests/kcl_samples.rs b/rust/kcl-lib/src/simulation_tests/kcl_samples.rs index 27ae5d2db..2f3b590ca 100644 --- a/rust/kcl-lib/src/simulation_tests/kcl_samples.rs +++ b/rust/kcl-lib/src/simulation_tests/kcl_samples.rs @@ -1,6 +1,7 @@ //! Run all the KCL samples in the `kcl_samples` directory. use std::{ fs, + panic::{catch_unwind, AssertUnwindSafe}, path::{Path, PathBuf}, }; @@ -35,9 +36,35 @@ fn parse(dir_name: &str, dir_path: &Path) { #[kcl_directory_test_macro::test_all_dirs("../public/kcl-samples")] async fn unparse(dir_name: &str, dir_path: &Path) { - // TODO: turn this on when we fix the comments recasting. - // let t = test(dir_name, dir_path.join("main.kcl").to_str().unwrap().to_owned()); - // super::unparse_test(&t).await; + let t = test(dir_name, dir_path.join("main.kcl").to_str().unwrap().to_owned()); + unparse_test(&t).await; +} + +/// This is different from the rest of the simulation tests because we want to write +/// back out to the original file. +async fn unparse_test(test: &Test) { + let kcl_files = crate::unparser::walk_dir(&test.input_dir).await.unwrap(); + let futures = kcl_files + .into_iter() + .filter(|file| file.extension().is_some_and(|ext| ext == "kcl")) // We only care about kcl + // files here. + .map(|file| { + tokio::spawn(async move { + let contents = tokio::fs::read_to_string(&file).await.unwrap(); + let program = crate::Program::parse_no_errs(&contents).unwrap(); + let recast = program.recast_with_options(&Default::default()); + + catch_unwind(AssertUnwindSafe(|| { + expectorate::assert_contents(&file, &recast.to_string()); + })) + }) + }) + .collect::>(); + + // Join all futures and await their completion. + for future in futures { + future.await.unwrap().unwrap(); + } } #[kcl_directory_test_macro::test_all_dirs("../public/kcl-samples")] diff --git a/rust/kcl-lib/src/std/appearance.rs b/rust/kcl-lib/src/std/appearance.rs index c19620bf9..d92552a2f 100644 --- a/rust/kcl-lib/src/std/appearance.rs +++ b/rust/kcl-lib/src/std/appearance.rs @@ -66,7 +66,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result, roughness: Option, + exec_state: &mut ExecState, args: Args, ) -> Result, KclError> { for solid in &solids { @@ -306,7 +307,7 @@ async fn inner_appearance( }; args.batch_modeling_cmd( - uuid::Uuid::new_v4(), + exec_state.next_uuid(), ModelingCmd::from(mcmd::ObjectSetMaterialParamsPbr { object_id: solid.id, color, diff --git a/rust/kcl-lib/src/std/fillet.rs b/rust/kcl-lib/src/std/fillet.rs index 0aa08dfcc..7e67eb09d 100644 --- a/rust/kcl-lib/src/std/fillet.rs +++ b/rust/kcl-lib/src/std/fillet.rs @@ -8,6 +8,7 @@ use kittycad_modeling_cmds as kcmc; use schemars::JsonSchema; use serde::{Deserialize, Serialize}; +use super::DEFAULT_TOLERANCE; use crate::{ errors::{KclError, KclErrorDetails}, execution::{ @@ -15,7 +16,6 @@ use crate::{ EdgeCut, ExecState, ExtrudeSurface, FilletSurface, GeoMeta, KclValue, Solid, TagIdentifier, }, parsing::ast::types::TagNode, - settings::types::UnitLength, std::Args, SourceRange, }; @@ -165,7 +165,7 @@ async fn inner_fillet( edge_id, object_id: solid.id, radius: LengthUnit(radius), - tolerance: LengthUnit(tolerance.unwrap_or(default_tolerance(&args.ctx.settings.units))), + tolerance: LengthUnit(tolerance.unwrap_or(DEFAULT_TOLERANCE)), cut_type: CutType::Fillet, // We make this a none so that we can remove it in the future. face_id: None, @@ -195,17 +195,6 @@ async fn inner_fillet( Ok(solid) } -pub(crate) fn default_tolerance(units: &UnitLength) -> f64 { - match units { - UnitLength::Mm => 0.0000001, - UnitLength::Cm => 0.0000001, - UnitLength::In => 0.0000001, - UnitLength::Ft => 0.0001, - UnitLength::Yd => 0.001, - UnitLength::M => 0.001, - } -} - #[cfg(test)] mod tests { use super::*; diff --git a/rust/kcl-lib/src/std/loft.rs b/rust/kcl-lib/src/std/loft.rs index dbe6b47c5..bb8e48db9 100644 --- a/rust/kcl-lib/src/std/loft.rs +++ b/rust/kcl-lib/src/std/loft.rs @@ -7,11 +7,12 @@ use kcl_derive_docs::stdlib; use kcmc::{each_cmd as mcmd, length_unit::LengthUnit, ModelingCmd}; use kittycad_modeling_cmds as kcmc; +use super::DEFAULT_TOLERANCE; use crate::{ errors::{KclError, KclErrorDetails}, execution::{types::RuntimeType, ExecState, KclValue, Sketch, Solid}, parsing::ast::types::TagNode, - std::{extrude::do_post_extrude, fillet::default_tolerance, Args}, + std::{extrude::do_post_extrude, Args}, }; const DEFAULT_V_DEGREE: u32 = 2; @@ -159,7 +160,7 @@ async fn inner_loft( section_ids: sketches.iter().map(|group| group.id).collect(), base_curve_index, bez_approximate_rational, - tolerance: LengthUnit(tolerance.unwrap_or(default_tolerance(&args.ctx.settings.units))), + tolerance: LengthUnit(tolerance.unwrap_or(DEFAULT_TOLERANCE)), v_degree, }), ) diff --git a/rust/kcl-lib/src/std/mod.rs b/rust/kcl-lib/src/std/mod.rs index 8d9027f75..16078e511 100644 --- a/rust/kcl-lib/src/std/mod.rs +++ b/rust/kcl-lib/src/std/mod.rs @@ -278,6 +278,9 @@ pub enum FunctionKind { UserDefined, } +/// The default tolerance for modeling commands in [`kittycad_modeling_cmds::length_unit::LengthUnit`]. +const DEFAULT_TOLERANCE: f64 = 0.0000001; + /// Compute the length of the given leg. pub async fn leg_length(_exec_state: &mut ExecState, args: Args) -> Result { let (hypotenuse, leg, ty) = args.get_hypotenuse_leg()?; diff --git a/rust/kcl-lib/src/std/revolve.rs b/rust/kcl-lib/src/std/revolve.rs index 5a8b839d0..354210c85 100644 --- a/rust/kcl-lib/src/std/revolve.rs +++ b/rust/kcl-lib/src/std/revolve.rs @@ -5,11 +5,12 @@ use kcl_derive_docs::stdlib; use kcmc::{each_cmd as mcmd, length_unit::LengthUnit, shared::Angle, ModelingCmd}; use kittycad_modeling_cmds::{self as kcmc}; +use super::DEFAULT_TOLERANCE; use crate::{ errors::{KclError, KclErrorDetails}, execution::{types::RuntimeType, ExecState, KclValue, Sketch, Solid}, parsing::ast::types::TagNode, - std::{axis_or_reference::Axis2dOrEdgeReference, extrude::do_post_extrude, fillet::default_tolerance, Args}, + std::{axis_or_reference::Axis2dOrEdgeReference, extrude::do_post_extrude, Args}, }; /// Revolve a sketch or set of sketches around an axis. @@ -273,7 +274,7 @@ async fn inner_revolve( target: sketch.id.into(), axis, origin, - tolerance: LengthUnit(tolerance.unwrap_or(default_tolerance(&args.ctx.settings.units))), + tolerance: LengthUnit(tolerance.unwrap_or(DEFAULT_TOLERANCE)), axis_is_2d: true, }), ) @@ -287,7 +288,7 @@ async fn inner_revolve( angle, target: sketch.id.into(), edge_id, - tolerance: LengthUnit(tolerance.unwrap_or(default_tolerance(&args.ctx.settings.units))), + tolerance: LengthUnit(tolerance.unwrap_or(DEFAULT_TOLERANCE)), }), ) .await?; diff --git a/rust/kcl-lib/src/std/sweep.rs b/rust/kcl-lib/src/std/sweep.rs index 3a00ceced..c0f2981da 100644 --- a/rust/kcl-lib/src/std/sweep.rs +++ b/rust/kcl-lib/src/std/sweep.rs @@ -7,11 +7,12 @@ use kittycad_modeling_cmds::{self as kcmc}; use schemars::JsonSchema; use serde::{Deserialize, Serialize}; +use super::DEFAULT_TOLERANCE; use crate::{ errors::KclError, execution::{types::RuntimeType, ExecState, Helix, KclValue, Sketch, Solid}, parsing::ast::types::TagNode, - std::{extrude::do_post_extrude, fillet::default_tolerance, Args}, + std::{extrude::do_post_extrude, Args}, }; /// A path to sweep along. @@ -191,7 +192,7 @@ async fn inner_sweep( target: sketch.id.into(), trajectory, sectional: sectional.unwrap_or(false), - tolerance: LengthUnit(tolerance.unwrap_or(default_tolerance(&args.ctx.settings.units))), + tolerance: LengthUnit(tolerance.unwrap_or(DEFAULT_TOLERANCE)), }), ) .await?; diff --git a/rust/kcl-lib/src/std/transform.rs b/rust/kcl-lib/src/std/transform.rs index 3d9f69774..f4bccbe5f 100644 --- a/rust/kcl-lib/src/std/transform.rs +++ b/rust/kcl-lib/src/std/transform.rs @@ -28,15 +28,22 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result Result hole(pipeHole, %) /// |> sweep(path = sweepPath) /// |> scale( -/// scale = [1.0, 1.0, 2.5], +/// x = 1.0, +/// y = 1.0, +/// z = 2.5, /// ) /// ``` /// @@ -89,7 +98,9 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result scale( -/// scale = [1.0, 1.0, 2.5], +/// x = 1.0, +/// y = 1.0, +/// z = 2.5, /// ) /// ``` /// @@ -124,7 +135,7 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result Result, exec_state: &mut ExecState, args: Args, @@ -159,11 +174,7 @@ async fn inner_scale( object_id, transforms: vec![shared::ComponentTransform { scale: Some(shared::TransformBy::> { - property: Point3d { - x: scale[0], - y: scale[1], - z: scale[2], - }, + property: Point3d { x, y, z }, set: false, is_local: !global.unwrap_or(false), }), @@ -190,15 +201,23 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result Result hole(pipeHole, %) /// |> sweep(path = sweepPath) /// |> translate( -/// translate = [1.0, 1.0, 2.5], +/// x = 1.0, +/// y = 1.0, +/// z = 2.5, /// ) /// ``` /// @@ -243,7 +264,9 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result translate( -/// translate = [1.0, 1.0, 2.5], +/// x = 1.0, +/// y = 1.0, +/// z = 2.5, /// ) /// ``` /// @@ -278,7 +301,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result Result translate( -/// translate = [5, 5, 0], +/// x = 5, +/// y = 5, +/// z = 0, /// ) /// |> extrude( /// length = 10, @@ -324,7 +349,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result translate(translate = [0, 0, 20]) +/// |> translate(x = 0, y = 0, z = 20) /// |> rotate(axis = [0, 0, 1.0], angle = 45) /// /// loft([profile001, profile002]) @@ -336,13 +361,17 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result, exec_state: &mut ExecState, args: Args, @@ -363,9 +392,9 @@ async fn inner_translate( transforms: vec![shared::ComponentTransform { translate: Some(shared::TransformBy::> { property: shared::Point3d { - x: LengthUnit(translate[0]), - y: LengthUnit(translate[1]), - z: LengthUnit(translate[2]), + x: LengthUnit(x), + y: LengthUnit(y), + z: LengthUnit(z), }, set: false, is_local: !global.unwrap_or(false), @@ -506,6 +535,11 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result Result translate(translate = [0, 0, 20]) +/// |> translate(x = 0, y = 0, z = 20) /// |> rotate(axis = [0, 0, 1.0], angle = 45) /// /// loft([profile001, profile002]) diff --git a/rust/kcl-lib/src/test_server.rs b/rust/kcl-lib/src/test_server.rs index e673743fc..c745a4324 100644 --- a/rust/kcl-lib/src/test_server.rs +++ b/rust/kcl-lib/src/test_server.rs @@ -6,7 +6,6 @@ use crate::{ engine::new_zoo_client, errors::ExecErrorWithState, execution::{EnvironmentRef, ExecState, ExecutorContext, ExecutorSettings}, - settings::types::UnitLength, ConnectionError, ExecError, KclError, KclErrorWithOutputs, Program, }; @@ -19,12 +18,8 @@ pub struct RequestBody { /// Executes a kcl program and takes a snapshot of the result. /// This returns the bytes of the snapshot. -pub async fn execute_and_snapshot( - code: &str, - units: UnitLength, - current_file: Option, -) -> Result { - let ctx = new_context(units, true, current_file).await?; +pub async fn execute_and_snapshot(code: &str, current_file: Option) -> Result { + let ctx = new_context(true, current_file).await?; let program = Program::parse_no_errs(code).map_err(KclErrorWithOutputs::no_outputs)?; let res = do_execute_and_snapshot(&ctx, program) .await @@ -38,17 +33,26 @@ pub async fn execute_and_snapshot( /// This returns the bytes of the snapshot. pub async fn execute_and_snapshot_ast( ast: Program, - units: UnitLength, current_file: Option, with_export_step: bool, ) -> Result<(ExecState, EnvironmentRef, image::DynamicImage, Option>), ExecErrorWithState> { - let ctx = new_context(units, true, current_file).await?; - let (exec_state, env, img) = do_execute_and_snapshot(&ctx, ast).await?; + let ctx = new_context(true, current_file).await?; + let (exec_state, env, img) = match do_execute_and_snapshot(&ctx, ast).await { + Ok((exec_state, env_ref, img)) => (exec_state, env_ref, img), + Err(err) => { + // If there was an error executing the program, return it. + // Close the context to avoid any resource leaks. + ctx.close().await; + return Err(err); + } + }; let mut step = None; if with_export_step { let files = match ctx.export_step(true).await { Ok(f) => f, Err(err) => { + // Close the context to avoid any resource leaks. + ctx.close().await; return Err(ExecErrorWithState::new( ExecError::BadExport(format!("Export failed: {:?}", err)), exec_state.clone(), @@ -64,10 +68,9 @@ pub async fn execute_and_snapshot_ast( pub async fn execute_and_snapshot_no_auth( code: &str, - units: UnitLength, current_file: Option, ) -> Result<(image::DynamicImage, EnvironmentRef), ExecError> { - let ctx = new_context(units, false, current_file).await?; + let ctx = new_context(false, current_file).await?; let program = Program::parse_no_errs(code).map_err(KclErrorWithOutputs::no_outputs)?; let res = do_execute_and_snapshot(&ctx, program) .await @@ -111,11 +114,7 @@ async fn do_execute_and_snapshot( Ok((exec_state, result.0, img)) } -pub async fn new_context( - units: UnitLength, - with_auth: bool, - current_file: Option, -) -> Result { +pub async fn new_context(with_auth: bool, current_file: Option) -> Result { let mut client = new_zoo_client(if with_auth { None } else { Some("bad_token".to_string()) }, None) .map_err(ConnectionError::CouldNotMakeClient)?; if !with_auth { @@ -126,7 +125,6 @@ pub async fn new_context( } let mut settings = ExecutorSettings { - units, highlight_edges: true, enable_ssao: false, show_grid: false, @@ -145,7 +143,6 @@ pub async fn new_context( pub async fn execute_and_export_step( code: &str, - units: UnitLength, current_file: Option, ) -> Result< ( @@ -155,7 +152,7 @@ pub async fn execute_and_export_step( ), ExecErrorWithState, > { - let ctx = new_context(units, true, current_file).await?; + let ctx = new_context(true, current_file).await?; let mut exec_state = ExecState::new(&ctx); let program = Program::parse_no_errs(code) .map_err(|err| ExecErrorWithState::new(KclErrorWithOutputs::no_outputs(err).into(), exec_state.clone()))?; diff --git a/rust/kcl-lib/src/unparser.rs b/rust/kcl-lib/src/unparser.rs index d5771d108..8d178cab1 100644 --- a/rust/kcl-lib/src/unparser.rs +++ b/rust/kcl-lib/src/unparser.rs @@ -1,5 +1,8 @@ use std::fmt::Write; +#[cfg(feature = "cli")] +use clap::ValueEnum; + use crate::parsing::{ ast::types::{ Annotation, ArrayExpression, ArrayRangeExpression, BinaryExpression, BinaryOperator, BinaryPart, BodyItem, @@ -864,10 +867,33 @@ impl Parameter { } } -/// Collect all the kcl files in a directory, recursively. +lazy_static::lazy_static! { + + pub static ref IMPORT_FILE_EXTENSIONS: Vec = { + let mut import_file_extensions = vec!["stp".to_string(), "glb".to_string(), "fbxb".to_string()]; + #[cfg(feature = "cli")] + let named_extensions = kittycad::types::FileImportFormat::value_variants() + .iter() + .map(|x| format!("{}", x)) + .collect::>(); + #[cfg(not(feature = "cli"))] + let named_extensions = vec![]; // We don't really need this outside of the CLI. + // Add all the default import formats. + import_file_extensions.extend_from_slice(&named_extensions); + import_file_extensions + }; + + pub static ref RELEVANT_EXTENSIONS: Vec = { + let mut relevant_extensions = IMPORT_FILE_EXTENSIONS.clone(); + relevant_extensions.push("kcl".to_string()); + relevant_extensions + }; +} + +/// Collect all the kcl (and other relevant) files in a directory, recursively. #[cfg(not(target_arch = "wasm32"))] #[async_recursion::async_recursion] -pub(crate) async fn walk_dir(dir: &std::path::PathBuf) -> Result, anyhow::Error> { +pub async fn walk_dir(dir: &std::path::PathBuf) -> Result, anyhow::Error> { // Make sure we actually have a directory. if !dir.is_dir() { anyhow::bail!("`{}` is not a directory", dir.display()); @@ -881,7 +907,10 @@ pub(crate) async fn walk_dir(dir: &std::path::PathBuf) -> Result[76, 113, 4]"] - 3["Segment
[119, 136, 4]"] - 4["Segment
[142, 160, 4]"] - 5["Segment
[166, 184, 4]"] - 6["Segment
[190, 246, 4]"] - 7["Segment
[252, 259, 4]"] + 2["Path
[76, 113, 5]"] + 3["Segment
[119, 136, 5]"] + 4["Segment
[142, 160, 5]"] + 5["Segment
[166, 184, 5]"] + 6["Segment
[190, 246, 5]"] + 7["Segment
[252, 259, 5]"] 8[Solid2d] end subgraph path25 [Path] - 25["Path
[76, 111, 5]"] - 26["Segment
[117, 134, 5]"] - 27["Segment
[140, 158, 5]"] - 28["Segment
[164, 182, 5]"] - 29["Segment
[188, 244, 5]"] - 30["Segment
[250, 257, 5]"] + 25["Path
[76, 111, 6]"] + 26["Segment
[117, 134, 6]"] + 27["Segment
[140, 158, 6]"] + 28["Segment
[164, 182, 6]"] + 29["Segment
[188, 244, 6]"] + 30["Segment
[250, 257, 6]"] 31[Solid2d] end - 1["Plane
[47, 66, 4]"] - 9["Sweep Extrusion
[265, 287, 4]"] + 1["Plane
[47, 66, 5]"] + 9["Sweep Extrusion
[265, 287, 5]"] 10[Wall] 11[Wall] 12[Wall] @@ -34,8 +34,8 @@ flowchart LR 21["SweepEdge Adjacent"] 22["SweepEdge Opposite"] 23["SweepEdge Adjacent"] - 24["Plane
[47, 66, 5]"] - 32["Sweep Extrusion
[263, 285, 5]"] + 24["Plane
[47, 66, 6]"] + 32["Sweep Extrusion
[263, 285, 6]"] 33[Wall] 34[Wall] 35[Wall] diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/program_memory.snap b/rust/kcl-lib/tests/assembly_mixed_units_cubes/program_memory.snap index e5b7aa3ff..1a6491220 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/program_memory.snap +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/program_memory.snap @@ -5,10 +5,10 @@ description: Variables in memory after executing assembly_mixed_units_cubes.kcl { "cubeIn": { "type": "Module", - "value": 4 + "value": 5 }, "cubeMm": { "type": "Module", - "value": 5 + "value": 6 } } diff --git a/rust/kcl-lib/tests/assembly_non_default_units/artifact_commands.snap b/rust/kcl-lib/tests/assembly_non_default_units/artifact_commands.snap index 8d0a44ccb..35d0f62ab 100644 --- a/rust/kcl-lib/tests/assembly_non_default_units/artifact_commands.snap +++ b/rust/kcl-lib/tests/assembly_non_default_units/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands assembly_non_default_units.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/assembly_non_default_units/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/assembly_non_default_units/artifact_graph_flowchart.snap.md index df59ea4bb..3c76048bf 100644 --- a/rust/kcl-lib/tests/assembly_non_default_units/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/assembly_non_default_units/artifact_graph_flowchart.snap.md @@ -1,17 +1,17 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[197, 232, 4]"] - 3["Segment
[197, 232, 4]"] + 2["Path
[197, 232, 5]"] + 3["Segment
[197, 232, 5]"] 4[Solid2d] end subgraph path6 [Path] - 6["Path
[113, 148, 5]"] - 7["Segment
[113, 148, 5]"] + 6["Path
[113, 148, 6]"] + 7["Segment
[113, 148, 6]"] 8[Solid2d] end - 1["Plane
[172, 191, 4]"] - 5["Plane
[88, 107, 5]"] + 1["Plane
[172, 191, 5]"] + 5["Plane
[88, 107, 6]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/assembly_non_default_units/program_memory.snap b/rust/kcl-lib/tests/assembly_non_default_units/program_memory.snap index 0d6c82eda..9d0c227bf 100644 --- a/rust/kcl-lib/tests/assembly_non_default_units/program_memory.snap +++ b/rust/kcl-lib/tests/assembly_non_default_units/program_memory.snap @@ -5,10 +5,10 @@ description: Variables in memory after executing assembly_non_default_units.kcl { "other1": { "type": "Module", - "value": 4 + "value": 5 }, "other2": { "type": "Module", - "value": 5 + "value": 6 } } diff --git a/rust/kcl-lib/tests/bad_units_in_annotation/artifact_commands.snap b/rust/kcl-lib/tests/bad_units_in_annotation/artifact_commands.snap index 85f71544a..7ff70d0a1 100644 --- a/rust/kcl-lib/tests/bad_units_in_annotation/artifact_commands.snap +++ b/rust/kcl-lib/tests/bad_units_in_annotation/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands bad_units_in_annotation.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/artifact_commands.snap b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/artifact_commands.snap index a59a1e02e..db68c4afd 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/artifact_commands.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands basic_fillet_cube_close_opposite.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/basic_fillet_cube_end/artifact_commands.snap b/rust/kcl-lib/tests/basic_fillet_cube_end/artifact_commands.snap index 9077b89fe..26400b300 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_end/artifact_commands.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_end/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands basic_fillet_cube_end.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/artifact_commands.snap b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/artifact_commands.snap index fe0d4a7bf..651745e1d 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/artifact_commands.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands basic_fillet_cube_next_adjacent.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/artifact_commands.snap b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/artifact_commands.snap index cf4588ae6..5909434e8 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/artifact_commands.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands basic_fillet_cube_previous_adjacent.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/basic_fillet_cube_start/artifact_commands.snap b/rust/kcl-lib/tests/basic_fillet_cube_start/artifact_commands.snap index 9389d855b..3ce091a41 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_start/artifact_commands.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_start/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands basic_fillet_cube_start.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_x/artifact_commands.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/artifact_commands.snap index 7070a10ba..7f9c6109a 100644 --- a/rust/kcl-lib/tests/big_number_angle_to_match_length_x/artifact_commands.snap +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands big_number_angle_to_match_length_x.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_y/artifact_commands.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/artifact_commands.snap index 99e9a0dd5..eda9181f3 100644 --- a/rust/kcl-lib/tests/big_number_angle_to_match_length_y/artifact_commands.snap +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands big_number_angle_to_match_length_y.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/boolean_logical_and/artifact_commands.snap b/rust/kcl-lib/tests/boolean_logical_and/artifact_commands.snap index 902522491..9cd09307a 100644 --- a/rust/kcl-lib/tests/boolean_logical_and/artifact_commands.snap +++ b/rust/kcl-lib/tests/boolean_logical_and/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands boolean_logical_and.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/boolean_logical_multiple/artifact_commands.snap b/rust/kcl-lib/tests/boolean_logical_multiple/artifact_commands.snap index 78c0c63ed..a53ce5526 100644 --- a/rust/kcl-lib/tests/boolean_logical_multiple/artifact_commands.snap +++ b/rust/kcl-lib/tests/boolean_logical_multiple/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands boolean_logical_multiple.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/boolean_logical_or/artifact_commands.snap b/rust/kcl-lib/tests/boolean_logical_or/artifact_commands.snap index 4cd801e11..374262ba5 100644 --- a/rust/kcl-lib/tests/boolean_logical_or/artifact_commands.snap +++ b/rust/kcl-lib/tests/boolean_logical_or/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands boolean_logical_or.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/circle_three_point/artifact_commands.snap b/rust/kcl-lib/tests/circle_three_point/artifact_commands.snap index f57bf4e09..ae1e90596 100644 --- a/rust/kcl-lib/tests/circle_three_point/artifact_commands.snap +++ b/rust/kcl-lib/tests/circle_three_point/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands circle_three_point.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/artifact_commands.snap b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/artifact_commands.snap index 00e1f220f..bca7d582c 100644 --- a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/artifact_commands.snap +++ b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands circular_pattern3d_a_pattern.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/comparisons/artifact_commands.snap b/rust/kcl-lib/tests/comparisons/artifact_commands.snap index 3aa02f17a..4d84ea423 100644 --- a/rust/kcl-lib/tests/comparisons/artifact_commands.snap +++ b/rust/kcl-lib/tests/comparisons/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands comparisons.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/comparisons_multiple/artifact_commands.snap b/rust/kcl-lib/tests/comparisons_multiple/artifact_commands.snap index f3eabeea4..c7f2d8842 100644 --- a/rust/kcl-lib/tests/comparisons_multiple/artifact_commands.snap +++ b/rust/kcl-lib/tests/comparisons_multiple/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands comparisons_multiple.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/computed_var/artifact_commands.snap b/rust/kcl-lib/tests/computed_var/artifact_commands.snap index 040f1571b..5b4200403 100644 --- a/rust/kcl-lib/tests/computed_var/artifact_commands.snap +++ b/rust/kcl-lib/tests/computed_var/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands computed_var.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/crazy_multi_profile/artifact_commands.snap b/rust/kcl-lib/tests/crazy_multi_profile/artifact_commands.snap index 17dbe7722..403cfd8a8 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/artifact_commands.snap +++ b/rust/kcl-lib/tests/crazy_multi_profile/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands crazy_multi_profile.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/cube/artifact_commands.snap b/rust/kcl-lib/tests/cube/artifact_commands.snap index e9086ae16..f25d36f1c 100644 --- a/rust/kcl-lib/tests/cube/artifact_commands.snap +++ b/rust/kcl-lib/tests/cube/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands cube.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/cube_with_error/artifact_commands.snap b/rust/kcl-lib/tests/cube_with_error/artifact_commands.snap index 711c3f7c6..93b9411b9 100644 --- a/rust/kcl-lib/tests/cube_with_error/artifact_commands.snap +++ b/rust/kcl-lib/tests/cube_with_error/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands cube_with_error.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/double_map_fn/artifact_commands.snap b/rust/kcl-lib/tests/double_map_fn/artifact_commands.snap index 9fd3e7dba..1dbd81b6d 100644 --- a/rust/kcl-lib/tests/double_map_fn/artifact_commands.snap +++ b/rust/kcl-lib/tests/double_map_fn/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands double_map_fn.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/fillet-and-shell/artifact_commands.snap b/rust/kcl-lib/tests/fillet-and-shell/artifact_commands.snap index 392ae4bd9..e8a8c7f18 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/artifact_commands.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands fillet-and-shell.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/flush_batch_on_end/artifact_commands.snap b/rust/kcl-lib/tests/flush_batch_on_end/artifact_commands.snap index bd44e849e..5983766de 100644 --- a/rust/kcl-lib/tests/flush_batch_on_end/artifact_commands.snap +++ b/rust/kcl-lib/tests/flush_batch_on_end/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands flush_batch_on_end.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/function_sketch/artifact_commands.snap b/rust/kcl-lib/tests/function_sketch/artifact_commands.snap index af09bcdf9..3a741b800 100644 --- a/rust/kcl-lib/tests/function_sketch/artifact_commands.snap +++ b/rust/kcl-lib/tests/function_sketch/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands function_sketch.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/function_sketch_with_position/artifact_commands.snap b/rust/kcl-lib/tests/function_sketch_with_position/artifact_commands.snap index f1bbba0a5..c05b55d86 100644 --- a/rust/kcl-lib/tests/function_sketch_with_position/artifact_commands.snap +++ b/rust/kcl-lib/tests/function_sketch_with_position/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands function_sketch_with_position.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/helix_ccw/artifact_commands.snap b/rust/kcl-lib/tests/helix_ccw/artifact_commands.snap index d64456fa1..6b40a6102 100644 --- a/rust/kcl-lib/tests/helix_ccw/artifact_commands.snap +++ b/rust/kcl-lib/tests/helix_ccw/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands helix_ccw.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/helix_simple/artifact_commands.snap b/rust/kcl-lib/tests/helix_simple/artifact_commands.snap index 34c27f06d..2db09c2e7 100644 --- a/rust/kcl-lib/tests/helix_simple/artifact_commands.snap +++ b/rust/kcl-lib/tests/helix_simple/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands helix_simple.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/i_shape/artifact_commands.snap b/rust/kcl-lib/tests/i_shape/artifact_commands.snap index c733c4e44..3f7335fe8 100644 --- a/rust/kcl-lib/tests/i_shape/artifact_commands.snap +++ b/rust/kcl-lib/tests/i_shape/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands i_shape.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/if_else/artifact_commands.snap b/rust/kcl-lib/tests/if_else/artifact_commands.snap index 762e10c0b..a33ac287d 100644 --- a/rust/kcl-lib/tests/if_else/artifact_commands.snap +++ b/rust/kcl-lib/tests/if_else/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands if_else.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_constant/artifact_commands.snap b/rust/kcl-lib/tests/import_constant/artifact_commands.snap index 028aaffc2..78eeb4c8c 100644 --- a/rust/kcl-lib/tests/import_constant/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_constant/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_constant.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_cycle1/artifact_commands.snap b/rust/kcl-lib/tests/import_cycle1/artifact_commands.snap index 6dd19278b..0075075f7 100644 --- a/rust/kcl-lib/tests/import_cycle1/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_cycle1/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_cycle1.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_export/artifact_commands.snap b/rust/kcl-lib/tests/import_export/artifact_commands.snap index 36d9f17ec..7ac69634b 100644 --- a/rust/kcl-lib/tests/import_export/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_export/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_export.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_file_not_exist_error/artifact_commands.snap b/rust/kcl-lib/tests/import_file_not_exist_error/artifact_commands.snap index 54fb9c7d6..8b760a128 100644 --- a/rust/kcl-lib/tests/import_file_not_exist_error/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_file_not_exist_error/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_file_not_exist_error.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_file_parse_error/artifact_commands.snap b/rust/kcl-lib/tests/import_file_parse_error/artifact_commands.snap index a69103651..ff504f24c 100644 --- a/rust/kcl-lib/tests/import_file_parse_error/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_file_parse_error/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_file_parse_error.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_foreign/artifact_commands.snap b/rust/kcl-lib/tests/import_foreign/artifact_commands.snap index 484765b69..a7971688c 100644 --- a/rust/kcl-lib/tests/import_foreign/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_foreign/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_foreign.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_foreign/program_memory.snap b/rust/kcl-lib/tests/import_foreign/program_memory.snap index 585e23400..88d57cd00 100644 --- a/rust/kcl-lib/tests/import_foreign/program_memory.snap +++ b/rust/kcl-lib/tests/import_foreign/program_memory.snap @@ -5,7 +5,7 @@ description: Variables in memory after executing import_foreign.kcl { "cube": { "type": "Module", - "value": 4 + "value": 5 }, "model": { "type": "ImportedGeometry", diff --git a/rust/kcl-lib/tests/import_function_not_sketch/artifact_commands.snap b/rust/kcl-lib/tests/import_function_not_sketch/artifact_commands.snap index 4d2508cd3..f9fa43681 100644 --- a/rust/kcl-lib/tests/import_function_not_sketch/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_function_not_sketch/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_function_not_sketch.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_glob/artifact_commands.snap b/rust/kcl-lib/tests/import_glob/artifact_commands.snap index 8d6423f70..eb22fbbc5 100644 --- a/rust/kcl-lib/tests/import_glob/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_glob/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_glob.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_side_effect/artifact_commands.snap b/rust/kcl-lib/tests/import_side_effect/artifact_commands.snap index d92060f6b..a1e39f9d8 100644 --- a/rust/kcl-lib/tests/import_side_effect/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_side_effect/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_side_effect.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_transform/artifact_commands.snap b/rust/kcl-lib/tests/import_transform/artifact_commands.snap index 7eadb5e7a..3c4b223ca 100644 --- a/rust/kcl-lib/tests/import_transform/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_transform/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_transform.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_transform/ast.snap b/rust/kcl-lib/tests/import_transform/ast.snap index 044532537..5c2fb7932 100644 --- a/rust/kcl-lib/tests/import_transform/ast.snap +++ b/rust/kcl-lib/tests/import_transform/ast.snap @@ -151,54 +151,65 @@ description: Result of parsing import_transform.kcl "label": { "commentStart": 159, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 171, - "elements": [ - { - "commentStart": 172, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 178, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 184, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - } - ], + "commentStart": 163, "end": 0, + "raw": "3.14", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 169, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 173, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 179, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 183, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } } } ], @@ -235,65 +246,76 @@ description: Result of parsing import_transform.kcl { "type": "LabeledArg", "label": { - "commentStart": 205, + "commentStart": 203, "end": 0, - "name": "scale", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 213, - "elements": [ - { - "commentStart": 214, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 220, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 226, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - } - ], + "commentStart": 207, "end": 0, + "raw": "3.14", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 213, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 217, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 223, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 227, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } } } ], "callee": { "abs_path": false, - "commentStart": 196, + "commentStart": 194, "end": 0, "name": { - "commentStart": 196, + "commentStart": 194, "end": 0, "name": "scale", "start": 0, @@ -303,13 +325,13 @@ description: Result of parsing import_transform.kcl "start": 0, "type": "Name" }, - "commentStart": 196, + "commentStart": 194, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 202, + "commentStart": 200, "end": 0, "start": 0, "type": "PipeSubstitution", diff --git a/rust/kcl-lib/tests/import_transform/input.kcl b/rust/kcl-lib/tests/import_transform/input.kcl index a09972a87..953c90838 100644 --- a/rust/kcl-lib/tests/import_transform/input.kcl +++ b/rust/kcl-lib/tests/import_transform/input.kcl @@ -7,5 +7,5 @@ screw pitch = 3.14, yaw = 3.14, ) - |> translate(%, translate = [3.14, 3.14, 3.14]) - |> scale(%, scale = [3.14, 3.14, 3.14]) + |> translate(%, x = 3.14, y = 3.14, z = 3.14) + |> scale(%, x = 3.14, y = 3.14, z = 3.14) diff --git a/rust/kcl-lib/tests/import_transform/program_memory.snap b/rust/kcl-lib/tests/import_transform/program_memory.snap index 8599d50df..ef1a01f7f 100644 --- a/rust/kcl-lib/tests/import_transform/program_memory.snap +++ b/rust/kcl-lib/tests/import_transform/program_memory.snap @@ -5,6 +5,6 @@ description: Variables in memory after executing import_transform.kcl { "screw": { "type": "Module", - "value": 4 + "value": 5 } } diff --git a/rust/kcl-lib/tests/import_transform/unparsed.snap b/rust/kcl-lib/tests/import_transform/unparsed.snap index ea0f378fe..d30f0fbef 100644 --- a/rust/kcl-lib/tests/import_transform/unparsed.snap +++ b/rust/kcl-lib/tests/import_transform/unparsed.snap @@ -11,5 +11,15 @@ screw pitch = 3.14, yaw = 3.14, ) - |> translate(%, translate = [3.14, 3.14, 3.14]) - |> scale(%, scale = [3.14, 3.14, 3.14]) + |> translate( + %, + x = 3.14, + y = 3.14, + z = 3.14, + ) + |> scale( + %, + x = 3.14, + y = 3.14, + z = 3.14, + ) diff --git a/rust/kcl-lib/tests/import_whole/artifact_commands.snap b/rust/kcl-lib/tests/import_whole/artifact_commands.snap index b0c86bfbd..d5018b761 100644 --- a/rust/kcl-lib/tests/import_whole/artifact_commands.snap +++ b/rust/kcl-lib/tests/import_whole/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands import_whole.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/import_whole/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/import_whole/artifact_graph_flowchart.snap.md index 02ba66870..ce1d43882 100644 --- a/rust/kcl-lib/tests/import_whole/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/import_whole/artifact_graph_flowchart.snap.md @@ -1,12 +1,12 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[83, 119, 4]"] - 3["Segment
[83, 119, 4]"] + 2["Path
[83, 119, 5]"] + 3["Segment
[83, 119, 5]"] 4[Solid2d] end - 1["Plane
[60, 77, 4]"] - 5["Sweep Extrusion
[125, 145, 4]"] + 1["Plane
[60, 77, 5]"] + 5["Sweep Extrusion
[125, 145, 5]"] 6[Wall] 7["Cap Start"] 8["Cap End"] diff --git a/rust/kcl-lib/tests/import_whole/program_memory.snap b/rust/kcl-lib/tests/import_whole/program_memory.snap index afceb706f..be03eed1d 100644 --- a/rust/kcl-lib/tests/import_whole/program_memory.snap +++ b/rust/kcl-lib/tests/import_whole/program_memory.snap @@ -111,6 +111,6 @@ description: Variables in memory after executing import_whole.kcl }, "foo": { "type": "Module", - "value": 4 + "value": 5 } } diff --git a/rust/kcl-lib/tests/index_of_array/artifact_commands.snap b/rust/kcl-lib/tests/index_of_array/artifact_commands.snap index 7bab36f3a..28adaa521 100644 --- a/rust/kcl-lib/tests/index_of_array/artifact_commands.snap +++ b/rust/kcl-lib/tests/index_of_array/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands index_of_array.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/intersect_cubes/artifact_commands.snap b/rust/kcl-lib/tests/intersect_cubes/artifact_commands.snap index 06ac34587..665c37255 100644 --- a/rust/kcl-lib/tests/intersect_cubes/artifact_commands.snap +++ b/rust/kcl-lib/tests/intersect_cubes/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands intersect_cubes.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/invalid_index_fractional/artifact_commands.snap b/rust/kcl-lib/tests/invalid_index_fractional/artifact_commands.snap index 8499f44b2..d1a70f78c 100644 --- a/rust/kcl-lib/tests/invalid_index_fractional/artifact_commands.snap +++ b/rust/kcl-lib/tests/invalid_index_fractional/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands invalid_index_fractional.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/invalid_index_negative/artifact_commands.snap b/rust/kcl-lib/tests/invalid_index_negative/artifact_commands.snap index 0670fda9a..3badb4d21 100644 --- a/rust/kcl-lib/tests/invalid_index_negative/artifact_commands.snap +++ b/rust/kcl-lib/tests/invalid_index_negative/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands invalid_index_negative.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/invalid_index_str/artifact_commands.snap b/rust/kcl-lib/tests/invalid_index_str/artifact_commands.snap index 0151c1417..2c5ba5365 100644 --- a/rust/kcl-lib/tests/invalid_index_str/artifact_commands.snap +++ b/rust/kcl-lib/tests/invalid_index_str/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands invalid_index_str.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/invalid_member_object/artifact_commands.snap b/rust/kcl-lib/tests/invalid_member_object/artifact_commands.snap index 765c4b0de..7070f1c03 100644 --- a/rust/kcl-lib/tests/invalid_member_object/artifact_commands.snap +++ b/rust/kcl-lib/tests/invalid_member_object/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands invalid_member_object.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/invalid_member_object_prop/artifact_commands.snap b/rust/kcl-lib/tests/invalid_member_object_prop/artifact_commands.snap index 547a828fa..9a82ca531 100644 --- a/rust/kcl-lib/tests/invalid_member_object_prop/artifact_commands.snap +++ b/rust/kcl-lib/tests/invalid_member_object_prop/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands invalid_member_object_prop.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/80-20-rail/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/80-20-rail/artifact_commands.snap index 6b43582ec..abdf82584 100644 --- a/rust/kcl-lib/tests/kcl_samples/80-20-rail/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/80-20-rail/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands 80-20-rail.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/a-parametric-bearing-pillow-block/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/a-parametric-bearing-pillow-block/artifact_commands.snap index cd45bdffe..b5e677798 100644 --- a/rust/kcl-lib/tests/kcl_samples/a-parametric-bearing-pillow-block/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/a-parametric-bearing-pillow-block/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands a-parametric-bearing-pillow-block.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/ball-bearing/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/ball-bearing/artifact_commands.snap index fc1012146..38bd16c17 100644 --- a/rust/kcl-lib/tests/kcl_samples/ball-bearing/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/ball-bearing/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands ball-bearing.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/bench/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/bench/artifact_commands.snap index d81c96b90..a9d90dc3a 100644 --- a/rust/kcl-lib/tests/kcl_samples/bench/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/bench/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands bench.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/bench/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/bench/artifact_graph_flowchart.snap.md index 5d4b87145..89829e189 100644 --- a/rust/kcl-lib/tests/kcl_samples/bench/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/bench/artifact_graph_flowchart.snap.md @@ -1,239 +1,239 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[361, 394, 4]"] - 3["Segment
[402, 428, 4]"] - 4["Segment
[436, 489, 4]"] - 5["Segment
[497, 550, 4]"] - 6["Segment
[558, 612, 4]"] - 7["Segment
[620, 645, 4]"] - 8["Segment
[653, 673, 4]"] - 9["Segment
[681, 705, 4]"] - 10["Segment
[713, 766, 4]"] - 11["Segment
[774, 799, 4]"] - 12["Segment
[807, 827, 4]"] - 13["Segment
[835, 859, 4]"] - 14["Segment
[867, 919, 4]"] - 15["Segment
[927, 979, 4]"] - 16["Segment
[987, 1012, 4]"] - 17["Segment
[1020, 1044, 4]"] - 18["Segment
[1052, 1105, 4]"] - 19["Segment
[1113, 1138, 4]"] - 20["Segment
[1146, 1173, 4]"] - 21["Segment
[1181, 1233, 4]"] - 22["Segment
[1241, 1276, 4]"] - 23["Segment
[1284, 1291, 4]"] + 2["Path
[361, 394, 5]"] + 3["Segment
[402, 428, 5]"] + 4["Segment
[436, 489, 5]"] + 5["Segment
[497, 550, 5]"] + 6["Segment
[558, 612, 5]"] + 7["Segment
[620, 645, 5]"] + 8["Segment
[653, 673, 5]"] + 9["Segment
[681, 705, 5]"] + 10["Segment
[713, 766, 5]"] + 11["Segment
[774, 799, 5]"] + 12["Segment
[807, 827, 5]"] + 13["Segment
[835, 859, 5]"] + 14["Segment
[867, 919, 5]"] + 15["Segment
[927, 979, 5]"] + 16["Segment
[987, 1012, 5]"] + 17["Segment
[1020, 1044, 5]"] + 18["Segment
[1052, 1105, 5]"] + 19["Segment
[1113, 1138, 5]"] + 20["Segment
[1146, 1173, 5]"] + 21["Segment
[1181, 1233, 5]"] + 22["Segment
[1241, 1276, 5]"] + 23["Segment
[1284, 1291, 5]"] 24[Solid2d] end subgraph path89 [Path] - 89["Path
[361, 394, 4]"] - 90["Segment
[402, 428, 4]"] - 91["Segment
[436, 489, 4]"] - 92["Segment
[497, 550, 4]"] - 93["Segment
[558, 612, 4]"] - 94["Segment
[620, 645, 4]"] - 95["Segment
[653, 673, 4]"] - 96["Segment
[681, 705, 4]"] - 97["Segment
[713, 766, 4]"] - 98["Segment
[774, 799, 4]"] - 99["Segment
[807, 827, 4]"] - 100["Segment
[835, 859, 4]"] - 101["Segment
[867, 919, 4]"] - 102["Segment
[927, 979, 4]"] - 103["Segment
[987, 1012, 4]"] - 104["Segment
[1020, 1044, 4]"] - 105["Segment
[1052, 1105, 4]"] - 106["Segment
[1113, 1138, 4]"] - 107["Segment
[1146, 1173, 4]"] - 108["Segment
[1181, 1233, 4]"] - 109["Segment
[1241, 1276, 4]"] - 110["Segment
[1284, 1291, 4]"] + 89["Path
[361, 394, 5]"] + 90["Segment
[402, 428, 5]"] + 91["Segment
[436, 489, 5]"] + 92["Segment
[497, 550, 5]"] + 93["Segment
[558, 612, 5]"] + 94["Segment
[620, 645, 5]"] + 95["Segment
[653, 673, 5]"] + 96["Segment
[681, 705, 5]"] + 97["Segment
[713, 766, 5]"] + 98["Segment
[774, 799, 5]"] + 99["Segment
[807, 827, 5]"] + 100["Segment
[835, 859, 5]"] + 101["Segment
[867, 919, 5]"] + 102["Segment
[927, 979, 5]"] + 103["Segment
[987, 1012, 5]"] + 104["Segment
[1020, 1044, 5]"] + 105["Segment
[1052, 1105, 5]"] + 106["Segment
[1113, 1138, 5]"] + 107["Segment
[1146, 1173, 5]"] + 108["Segment
[1181, 1233, 5]"] + 109["Segment
[1241, 1276, 5]"] + 110["Segment
[1284, 1291, 5]"] 111[Solid2d] end subgraph path176 [Path] - 176["Path
[361, 394, 4]"] - 177["Segment
[402, 428, 4]"] - 178["Segment
[436, 489, 4]"] - 179["Segment
[497, 550, 4]"] - 180["Segment
[558, 612, 4]"] - 181["Segment
[620, 645, 4]"] - 182["Segment
[653, 673, 4]"] - 183["Segment
[681, 705, 4]"] - 184["Segment
[713, 766, 4]"] - 185["Segment
[774, 799, 4]"] - 186["Segment
[807, 827, 4]"] - 187["Segment
[835, 859, 4]"] - 188["Segment
[867, 919, 4]"] - 189["Segment
[927, 979, 4]"] - 190["Segment
[987, 1012, 4]"] - 191["Segment
[1020, 1044, 4]"] - 192["Segment
[1052, 1105, 4]"] - 193["Segment
[1113, 1138, 4]"] - 194["Segment
[1146, 1173, 4]"] - 195["Segment
[1181, 1233, 4]"] - 196["Segment
[1241, 1276, 4]"] - 197["Segment
[1284, 1291, 4]"] + 176["Path
[361, 394, 5]"] + 177["Segment
[402, 428, 5]"] + 178["Segment
[436, 489, 5]"] + 179["Segment
[497, 550, 5]"] + 180["Segment
[558, 612, 5]"] + 181["Segment
[620, 645, 5]"] + 182["Segment
[653, 673, 5]"] + 183["Segment
[681, 705, 5]"] + 184["Segment
[713, 766, 5]"] + 185["Segment
[774, 799, 5]"] + 186["Segment
[807, 827, 5]"] + 187["Segment
[835, 859, 5]"] + 188["Segment
[867, 919, 5]"] + 189["Segment
[927, 979, 5]"] + 190["Segment
[987, 1012, 5]"] + 191["Segment
[1020, 1044, 5]"] + 192["Segment
[1052, 1105, 5]"] + 193["Segment
[1113, 1138, 5]"] + 194["Segment
[1146, 1173, 5]"] + 195["Segment
[1181, 1233, 5]"] + 196["Segment
[1241, 1276, 5]"] + 197["Segment
[1284, 1291, 5]"] 198[Solid2d] end subgraph path262 [Path] - 262["Path
[361, 394, 4]"] - 263["Segment
[402, 428, 4]"] - 264["Segment
[436, 489, 4]"] - 265["Segment
[497, 550, 4]"] - 266["Segment
[558, 612, 4]"] - 267["Segment
[620, 645, 4]"] - 268["Segment
[653, 673, 4]"] - 269["Segment
[681, 705, 4]"] - 270["Segment
[713, 766, 4]"] - 271["Segment
[774, 799, 4]"] - 272["Segment
[807, 827, 4]"] - 273["Segment
[835, 859, 4]"] - 274["Segment
[867, 919, 4]"] - 275["Segment
[927, 979, 4]"] - 276["Segment
[987, 1012, 4]"] - 277["Segment
[1020, 1044, 4]"] - 278["Segment
[1052, 1105, 4]"] - 279["Segment
[1113, 1138, 4]"] - 280["Segment
[1146, 1173, 4]"] - 281["Segment
[1181, 1233, 4]"] - 282["Segment
[1241, 1276, 4]"] - 283["Segment
[1284, 1291, 4]"] + 262["Path
[361, 394, 5]"] + 263["Segment
[402, 428, 5]"] + 264["Segment
[436, 489, 5]"] + 265["Segment
[497, 550, 5]"] + 266["Segment
[558, 612, 5]"] + 267["Segment
[620, 645, 5]"] + 268["Segment
[653, 673, 5]"] + 269["Segment
[681, 705, 5]"] + 270["Segment
[713, 766, 5]"] + 271["Segment
[774, 799, 5]"] + 272["Segment
[807, 827, 5]"] + 273["Segment
[835, 859, 5]"] + 274["Segment
[867, 919, 5]"] + 275["Segment
[927, 979, 5]"] + 276["Segment
[987, 1012, 5]"] + 277["Segment
[1020, 1044, 5]"] + 278["Segment
[1052, 1105, 5]"] + 279["Segment
[1113, 1138, 5]"] + 280["Segment
[1146, 1173, 5]"] + 281["Segment
[1181, 1233, 5]"] + 282["Segment
[1241, 1276, 5]"] + 283["Segment
[1284, 1291, 5]"] 284[Solid2d] end subgraph path349 [Path] - 349["Path
[361, 394, 4]"] - 350["Segment
[402, 428, 4]"] - 351["Segment
[436, 489, 4]"] - 352["Segment
[497, 550, 4]"] - 353["Segment
[558, 612, 4]"] - 354["Segment
[620, 645, 4]"] - 355["Segment
[653, 673, 4]"] - 356["Segment
[681, 705, 4]"] - 357["Segment
[713, 766, 4]"] - 358["Segment
[774, 799, 4]"] - 359["Segment
[807, 827, 4]"] - 360["Segment
[835, 859, 4]"] - 361["Segment
[867, 919, 4]"] - 362["Segment
[927, 979, 4]"] - 363["Segment
[987, 1012, 4]"] - 364["Segment
[1020, 1044, 4]"] - 365["Segment
[1052, 1105, 4]"] - 366["Segment
[1113, 1138, 4]"] - 367["Segment
[1146, 1173, 4]"] - 368["Segment
[1181, 1233, 4]"] - 369["Segment
[1241, 1276, 4]"] - 370["Segment
[1284, 1291, 4]"] + 349["Path
[361, 394, 5]"] + 350["Segment
[402, 428, 5]"] + 351["Segment
[436, 489, 5]"] + 352["Segment
[497, 550, 5]"] + 353["Segment
[558, 612, 5]"] + 354["Segment
[620, 645, 5]"] + 355["Segment
[653, 673, 5]"] + 356["Segment
[681, 705, 5]"] + 357["Segment
[713, 766, 5]"] + 358["Segment
[774, 799, 5]"] + 359["Segment
[807, 827, 5]"] + 360["Segment
[835, 859, 5]"] + 361["Segment
[867, 919, 5]"] + 362["Segment
[927, 979, 5]"] + 363["Segment
[987, 1012, 5]"] + 364["Segment
[1020, 1044, 5]"] + 365["Segment
[1052, 1105, 5]"] + 366["Segment
[1113, 1138, 5]"] + 367["Segment
[1146, 1173, 5]"] + 368["Segment
[1181, 1233, 5]"] + 369["Segment
[1241, 1276, 5]"] + 370["Segment
[1284, 1291, 5]"] 371[Solid2d] end subgraph path435 [Path] - 435["Path
[361, 394, 4]"] - 436["Segment
[402, 428, 4]"] - 437["Segment
[436, 489, 4]"] - 438["Segment
[497, 550, 4]"] - 439["Segment
[558, 612, 4]"] - 440["Segment
[620, 645, 4]"] - 441["Segment
[653, 673, 4]"] - 442["Segment
[681, 705, 4]"] - 443["Segment
[713, 766, 4]"] - 444["Segment
[774, 799, 4]"] - 445["Segment
[807, 827, 4]"] - 446["Segment
[835, 859, 4]"] - 447["Segment
[867, 919, 4]"] - 448["Segment
[927, 979, 4]"] - 449["Segment
[987, 1012, 4]"] - 450["Segment
[1020, 1044, 4]"] - 451["Segment
[1052, 1105, 4]"] - 452["Segment
[1113, 1138, 4]"] - 453["Segment
[1146, 1173, 4]"] - 454["Segment
[1181, 1233, 4]"] - 455["Segment
[1241, 1276, 4]"] - 456["Segment
[1284, 1291, 4]"] + 435["Path
[361, 394, 5]"] + 436["Segment
[402, 428, 5]"] + 437["Segment
[436, 489, 5]"] + 438["Segment
[497, 550, 5]"] + 439["Segment
[558, 612, 5]"] + 440["Segment
[620, 645, 5]"] + 441["Segment
[653, 673, 5]"] + 442["Segment
[681, 705, 5]"] + 443["Segment
[713, 766, 5]"] + 444["Segment
[774, 799, 5]"] + 445["Segment
[807, 827, 5]"] + 446["Segment
[835, 859, 5]"] + 447["Segment
[867, 919, 5]"] + 448["Segment
[927, 979, 5]"] + 449["Segment
[987, 1012, 5]"] + 450["Segment
[1020, 1044, 5]"] + 451["Segment
[1052, 1105, 5]"] + 452["Segment
[1113, 1138, 5]"] + 453["Segment
[1146, 1173, 5]"] + 454["Segment
[1181, 1233, 5]"] + 455["Segment
[1241, 1276, 5]"] + 456["Segment
[1284, 1291, 5]"] 457[Solid2d] end subgraph path522 [Path] - 522["Path
[1685, 1709, 4]"] + 522["Path
[1685, 1709, 5]"] end subgraph path523 [Path] - 523["Path
[1717, 1847, 4]"] - 524["Segment
[1717, 1847, 4]"] - 525["Segment
[1717, 1847, 4]"] - 526["Segment
[1717, 1847, 4]"] - 527["Segment
[1717, 1847, 4]"] - 528["Segment
[1717, 1847, 4]"] - 529["Segment
[1717, 1847, 4]"] - 530["Segment
[1717, 1847, 4]"] + 523["Path
[1717, 1847, 5]"] + 524["Segment
[1717, 1847, 5]"] + 525["Segment
[1717, 1847, 5]"] + 526["Segment
[1717, 1847, 5]"] + 527["Segment
[1717, 1847, 5]"] + 528["Segment
[1717, 1847, 5]"] + 529["Segment
[1717, 1847, 5]"] + 530["Segment
[1717, 1847, 5]"] 531[Solid2d] end subgraph path553 [Path] - 553["Path
[1685, 1709, 4]"] + 553["Path
[1685, 1709, 5]"] end subgraph path554 [Path] - 554["Path
[1717, 1847, 4]"] - 555["Segment
[1717, 1847, 4]"] - 556["Segment
[1717, 1847, 4]"] - 557["Segment
[1717, 1847, 4]"] - 558["Segment
[1717, 1847, 4]"] - 559["Segment
[1717, 1847, 4]"] - 560["Segment
[1717, 1847, 4]"] - 561["Segment
[1717, 1847, 4]"] + 554["Path
[1717, 1847, 5]"] + 555["Segment
[1717, 1847, 5]"] + 556["Segment
[1717, 1847, 5]"] + 557["Segment
[1717, 1847, 5]"] + 558["Segment
[1717, 1847, 5]"] + 559["Segment
[1717, 1847, 5]"] + 560["Segment
[1717, 1847, 5]"] + 561["Segment
[1717, 1847, 5]"] 562[Solid2d] end subgraph path585 [Path] - 585["Path
[2123, 2150, 4]"] - 586["Segment
[2158, 2180, 4]"] - 587["Segment
[2188, 2210, 4]"] - 588["Segment
[2218, 2240, 4]"] - 589["Segment
[2248, 2271, 4]"] - 590["Segment
[2279, 2302, 4]"] - 591["Segment
[2310, 2345, 4]"] - 592["Segment
[2353, 2360, 4]"] + 585["Path
[2123, 2150, 5]"] + 586["Segment
[2158, 2180, 5]"] + 587["Segment
[2188, 2210, 5]"] + 588["Segment
[2218, 2240, 5]"] + 589["Segment
[2248, 2271, 5]"] + 590["Segment
[2279, 2302, 5]"] + 591["Segment
[2310, 2345, 5]"] + 592["Segment
[2353, 2360, 5]"] 593[Solid2d] end subgraph path618 [Path] - 618["Path
[2632, 2661, 4]"] - 619["Segment
[2669, 2692, 4]"] - 620["Segment
[2700, 2725, 4]"] - 621["Segment
[2733, 2757, 4]"] - 622["Segment
[2765, 2789, 4]"] - 623["Segment
[2797, 2819, 4]"] - 624["Segment
[2827, 2862, 4]"] - 625["Segment
[2870, 2877, 4]"] + 618["Path
[2632, 2661, 5]"] + 619["Segment
[2669, 2692, 5]"] + 620["Segment
[2700, 2725, 5]"] + 621["Segment
[2733, 2757, 5]"] + 622["Segment
[2765, 2789, 5]"] + 623["Segment
[2797, 2819, 5]"] + 624["Segment
[2827, 2862, 5]"] + 625["Segment
[2870, 2877, 5]"] 626[Solid2d] end subgraph path650 [Path] - 650["Path
[3152, 3179, 4]"] - 651["Segment
[3187, 3206, 4]"] - 652["Segment
[3214, 3304, 4]"] + 650["Path
[3152, 3179, 5]"] + 651["Segment
[3187, 3206, 5]"] + 652["Segment
[3214, 3304, 5]"] end subgraph path654 [Path] - 654["Path
[3404, 3437, 4]"] - 655["Segment
[3445, 3464, 4]"] - 656["Segment
[3472, 3494, 4]"] - 657["Segment
[3502, 3525, 4]"] - 658["Segment
[3533, 3553, 4]"] - 659["Segment
[3561, 3585, 4]"] - 660["Segment
[3593, 3616, 4]"] - 661["Segment
[3624, 3631, 4]"] + 654["Path
[3404, 3437, 5]"] + 655["Segment
[3445, 3464, 5]"] + 656["Segment
[3472, 3494, 5]"] + 657["Segment
[3502, 3525, 5]"] + 658["Segment
[3533, 3553, 5]"] + 659["Segment
[3561, 3585, 5]"] + 660["Segment
[3593, 3616, 5]"] + 661["Segment
[3624, 3631, 5]"] 662[Solid2d] end subgraph path688 [Path] - 688["Path
[3152, 3179, 4]"] - 689["Segment
[3187, 3206, 4]"] - 690["Segment
[3214, 3304, 4]"] + 688["Path
[3152, 3179, 5]"] + 689["Segment
[3187, 3206, 5]"] + 690["Segment
[3214, 3304, 5]"] end subgraph path692 [Path] - 692["Path
[3404, 3437, 4]"] - 693["Segment
[3445, 3464, 4]"] - 694["Segment
[3472, 3494, 4]"] - 695["Segment
[3502, 3525, 4]"] - 696["Segment
[3533, 3553, 4]"] - 697["Segment
[3561, 3585, 4]"] - 698["Segment
[3593, 3616, 4]"] - 699["Segment
[3624, 3631, 4]"] + 692["Path
[3404, 3437, 5]"] + 693["Segment
[3445, 3464, 5]"] + 694["Segment
[3472, 3494, 5]"] + 695["Segment
[3502, 3525, 5]"] + 696["Segment
[3533, 3553, 5]"] + 697["Segment
[3561, 3585, 5]"] + 698["Segment
[3593, 3616, 5]"] + 699["Segment
[3624, 3631, 5]"] 700[Solid2d] end - 1["Plane
[333, 353, 4]"] - 25["Sweep Extrusion
[1379, 1417, 4]"] + 1["Plane
[333, 353, 5]"] + 25["Sweep Extrusion
[1379, 1417, 5]"] 26[Wall] 27[Wall] 28[Wall] @@ -296,8 +296,8 @@ flowchart LR 85["SweepEdge Adjacent"] 86["SweepEdge Opposite"] 87["SweepEdge Adjacent"] - 88["Plane
[333, 353, 4]"] - 112["Sweep Extrusion
[1455, 1494, 4]"] + 88["Plane
[333, 353, 5]"] + 112["Sweep Extrusion
[1455, 1494, 5]"] 113[Wall] 114[Wall] 115[Wall] @@ -361,7 +361,7 @@ flowchart LR 173["SweepEdge Opposite"] 174["SweepEdge Adjacent"] 175["Plane
[823, 865, 0]"] - 199["Sweep Extrusion
[1379, 1417, 4]"] + 199["Sweep Extrusion
[1379, 1417, 5]"] 200[Wall] 201[Wall] 202[Wall] @@ -424,7 +424,7 @@ flowchart LR 259["SweepEdge Adjacent"] 260["SweepEdge Opposite"] 261["SweepEdge Adjacent"] - 285["Sweep Extrusion
[1455, 1494, 4]"] + 285["Sweep Extrusion
[1455, 1494, 5]"] 286[Wall] 287[Wall] 288[Wall] @@ -488,7 +488,7 @@ flowchart LR 346["SweepEdge Opposite"] 347["SweepEdge Adjacent"] 348["Plane
[875, 916, 0]"] - 372["Sweep Extrusion
[1379, 1417, 4]"] + 372["Sweep Extrusion
[1379, 1417, 5]"] 373[Wall] 374[Wall] 375[Wall] @@ -551,7 +551,7 @@ flowchart LR 432["SweepEdge Adjacent"] 433["SweepEdge Opposite"] 434["SweepEdge Adjacent"] - 458["Sweep Extrusion
[1455, 1494, 4]"] + 458["Sweep Extrusion
[1455, 1494, 5]"] 459[Wall] 460[Wall] 461[Wall] @@ -615,7 +615,7 @@ flowchart LR 519["SweepEdge Opposite"] 520["SweepEdge Adjacent"] 521["Plane
[975, 1017, 0]"] - 532["Sweep Extrusion
[1949, 1973, 4]"] + 532["Sweep Extrusion
[1949, 1973, 5]"] 533[Wall] 534[Wall] 535[Wall] @@ -636,7 +636,7 @@ flowchart LR 550["SweepEdge Adjacent"] 551["SweepEdge Opposite"] 552["SweepEdge Adjacent"] - 563["Sweep Extrusion
[2015, 2039, 4]"] + 563["Sweep Extrusion
[2015, 2039, 5]"] 564[Wall] 565[Wall] 566[Wall] @@ -658,7 +658,7 @@ flowchart LR 582["SweepEdge Opposite"] 583["SweepEdge Adjacent"] 584["Plane
[1068, 1135, 0]"] - 594["Sweep Extrusion
[2523, 2547, 4]"] + 594["Sweep Extrusion
[2523, 2547, 5]"] 595[Wall] 596[Wall] 597[Wall] @@ -679,10 +679,10 @@ flowchart LR 612["SweepEdge Adjacent"] 613["SweepEdge Opposite"] 614["SweepEdge Adjacent"] - 615["Sweep Extrusion
[2523, 2547, 4]"] - 616["Sweep Extrusion
[2523, 2547, 4]"] + 615["Sweep Extrusion
[2523, 2547, 5]"] + 616["Sweep Extrusion
[2523, 2547, 5]"] 617["Plane
[1205, 1272, 0]"] - 627["Sweep Extrusion
[3047, 3071, 4]"] + 627["Sweep Extrusion
[3047, 3071, 5]"] 628[Wall] 629[Wall] 630[Wall] @@ -703,10 +703,10 @@ flowchart LR 645["SweepEdge Adjacent"] 646["SweepEdge Opposite"] 647["SweepEdge Adjacent"] - 648["Sweep Extrusion
[3047, 3071, 4]"] - 649["Plane
[3712, 3747, 4]"] - 653["Plane
[3778, 3807, 4]"] - 663["Sweep Sweep
[3819, 3846, 4]"] + 648["Sweep Extrusion
[3047, 3071, 5]"] + 649["Plane
[3712, 3747, 5]"] + 653["Plane
[3778, 3807, 5]"] + 663["Sweep Sweep
[3819, 3846, 5]"] 664[Wall] 665[Wall] 666[Wall] @@ -730,9 +730,9 @@ flowchart LR 684["SweepEdge Adjacent"] 685["SweepEdge Opposite"] 686["SweepEdge Adjacent"] - 687["Plane
[3712, 3747, 4]"] - 691["Plane
[3778, 3807, 4]"] - 701["Sweep Sweep
[3819, 3846, 4]"] + 687["Plane
[3712, 3747, 5]"] + 691["Plane
[3778, 3807, 5]"] + 701["Sweep Sweep
[3819, 3846, 5]"] 702[Wall] 703[Wall] 704[Wall] @@ -756,18 +756,18 @@ flowchart LR 722["SweepEdge Adjacent"] 723["SweepEdge Opposite"] 724["SweepEdge Adjacent"] - 725["StartSketchOnPlane
[333, 353, 4]"] - 726["StartSketchOnPlane
[333, 353, 4]"] - 727["StartSketchOnPlane
[333, 353, 4]"] - 728["StartSketchOnPlane
[333, 353, 4]"] - 729["StartSketchOnPlane
[1657, 1677, 4]"] - 730["StartSketchOnPlane
[1657, 1677, 4]"] - 731["StartSketchOnPlane
[2095, 2115, 4]"] - 732["StartSketchOnPlane
[2604, 2624, 4]"] - 733["StartSketchOnPlane
[3124, 3144, 4]"] - 734["StartSketchOnPlane
[3376, 3396, 4]"] - 735["StartSketchOnPlane
[3124, 3144, 4]"] - 736["StartSketchOnPlane
[3376, 3396, 4]"] + 725["StartSketchOnPlane
[333, 353, 5]"] + 726["StartSketchOnPlane
[333, 353, 5]"] + 727["StartSketchOnPlane
[333, 353, 5]"] + 728["StartSketchOnPlane
[333, 353, 5]"] + 729["StartSketchOnPlane
[1657, 1677, 5]"] + 730["StartSketchOnPlane
[1657, 1677, 5]"] + 731["StartSketchOnPlane
[2095, 2115, 5]"] + 732["StartSketchOnPlane
[2604, 2624, 5]"] + 733["StartSketchOnPlane
[3124, 3144, 5]"] + 734["StartSketchOnPlane
[3376, 3396, 5]"] + 735["StartSketchOnPlane
[3124, 3144, 5]"] + 736["StartSketchOnPlane
[3376, 3396, 5]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/bench/ops.snap b/rust/kcl-lib/tests/kcl_samples/bench/ops.snap index 080fe4fc1..3b7561f6c 100644 --- a/rust/kcl-lib/tests/kcl_samples/bench/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/bench/ops.snap @@ -9,7 +9,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1331, 1606, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -21,7 +21,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -77,7 +77,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -248,7 +248,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1331, 1606, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -260,7 +260,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -316,7 +316,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -487,7 +487,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1331, 1606, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -499,7 +499,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -555,7 +555,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 309, 1312, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -726,7 +726,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1889, 2052, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -738,7 +738,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1626, 1868, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -800,7 +800,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 1626, 1868, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -889,7 +889,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 2474, 2560, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -901,7 +901,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 2071, 2453, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1007,7 +1007,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 2993, 3084, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1019,7 +1019,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 2580, 2972, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1095,7 +1095,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3671, 3859, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1131,7 +1131,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3100, 3325, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1191,7 +1191,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3344, 3652, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1249,7 +1249,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3671, 3859, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1285,7 +1285,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3100, 3325, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1345,7 +1345,7 @@ description: Operations executed bench.kcl "functionSourceRange": [ 3344, 3652, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, diff --git a/rust/kcl-lib/tests/kcl_samples/bracket/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/bracket/artifact_commands.snap index e170b95b0..fa6610892 100644 --- a/rust/kcl-lib/tests/kcl_samples/bracket/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/bracket/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands bracket.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_commands.snap index 5df351670..279904952 100644 --- a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands car-wheel-assembly.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_graph_flowchart.snap.md index f2ee384f1..66a0ae42b 100644 --- a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/artifact_graph_flowchart.snap.md @@ -1,264 +1,264 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[567, 618, 5]"] - 3["Segment
[567, 618, 5]"] + 2["Path
[567, 618, 6]"] + 3["Segment
[567, 618, 6]"] 4[Solid2d] end subgraph path11 [Path] - 11["Path
[803, 859, 5]"] - 12["Segment
[803, 859, 5]"] + 11["Path
[803, 859, 6]"] + 12["Segment
[803, 859, 6]"] 13[Solid2d] end subgraph path19 [Path] - 19["Path
[984, 1037, 5]"] - 20["Segment
[984, 1037, 5]"] + 19["Path
[984, 1037, 6]"] + 20["Segment
[984, 1037, 6]"] 21[Solid2d] end subgraph path30 [Path] - 30["Path
[1420, 1460, 5]"] - 31["Segment
[1420, 1460, 5]"] + 30["Path
[1420, 1460, 6]"] + 31["Segment
[1420, 1460, 6]"] 32[Solid2d] end subgraph path38 [Path] - 38["Path
[1564, 1615, 5]"] - 39["Segment
[1564, 1615, 5]"] + 38["Path
[1564, 1615, 6]"] + 39["Segment
[1564, 1615, 6]"] 40[Solid2d] end subgraph path47 [Path] - 47["Path
[1748, 1801, 5]"] - 48["Segment
[1748, 1801, 5]"] + 47["Path
[1748, 1801, 6]"] + 48["Segment
[1748, 1801, 6]"] 49[Solid2d] end subgraph path58 [Path] - 58["Path
[2044, 2116, 5]"] - 59["Segment
[2044, 2116, 5]"] + 58["Path
[2044, 2116, 6]"] + 59["Segment
[2044, 2116, 6]"] 60[Solid2d] end subgraph path81 [Path] - 81["Path
[2373, 2404, 5]"] - 82["Segment
[2410, 2430, 5]"] - 83["Segment
[2436, 2456, 5]"] - 84["Segment
[2462, 2483, 5]"] - 85["Segment
[2489, 2545, 5]"] - 86["Segment
[2551, 2558, 5]"] + 81["Path
[2373, 2404, 6]"] + 82["Segment
[2410, 2430, 6]"] + 83["Segment
[2436, 2456, 6]"] + 84["Segment
[2462, 2483, 6]"] + 85["Segment
[2489, 2545, 6]"] + 86["Segment
[2551, 2558, 6]"] 87[Solid2d] end subgraph path106 [Path] - 106["Path
[2860, 2892, 5]"] - 107["Segment
[2898, 2919, 5]"] - 108["Segment
[2925, 2945, 5]"] - 109["Segment
[2951, 2971, 5]"] - 110["Segment
[2977, 3033, 5]"] - 111["Segment
[3039, 3046, 5]"] + 106["Path
[2860, 2892, 6]"] + 107["Segment
[2898, 2919, 6]"] + 108["Segment
[2925, 2945, 6]"] + 109["Segment
[2951, 2971, 6]"] + 110["Segment
[2977, 3033, 6]"] + 111["Segment
[3039, 3046, 6]"] 112[Solid2d] end subgraph path132 [Path] - 132["Path
[350, 406, 4]"] - 133["Segment
[350, 406, 4]"] + 132["Path
[350, 406, 5]"] + 133["Segment
[350, 406, 5]"] 134[Solid2d] end subgraph path135 [Path] - 135["Path
[417, 473, 4]"] - 136["Segment
[417, 473, 4]"] + 135["Path
[417, 473, 5]"] + 136["Segment
[417, 473, 5]"] 137[Solid2d] end subgraph path144 [Path] - 144["Path
[638, 694, 4]"] - 145["Segment
[638, 694, 4]"] + 144["Path
[638, 694, 5]"] + 145["Segment
[638, 694, 5]"] 146[Solid2d] end subgraph path147 [Path] - 147["Path
[705, 761, 4]"] - 148["Segment
[705, 761, 4]"] + 147["Path
[705, 761, 5]"] + 148["Segment
[705, 761, 5]"] 149[Solid2d] end subgraph path156 [Path] - 156["Path
[905, 959, 4]"] - 157["Segment
[905, 959, 4]"] + 156["Path
[905, 959, 5]"] + 157["Segment
[905, 959, 5]"] 158[Solid2d] end subgraph path167 [Path] - 167["Path
[1237, 1297, 4]"] - 168["Segment
[1237, 1297, 4]"] + 167["Path
[1237, 1297, 5]"] + 168["Segment
[1237, 1297, 5]"] 169[Solid2d] end subgraph path179 [Path] - 179["Path
[1655, 1701, 4]"] - 180["Segment
[1707, 1759, 4]"] - 181["Segment
[1765, 1870, 4]"] - 182["Segment
[1876, 1898, 4]"] - 183["Segment
[1904, 1960, 4]"] - 184["Segment
[1966, 1973, 4]"] + 179["Path
[1655, 1701, 5]"] + 180["Segment
[1707, 1759, 5]"] + 181["Segment
[1765, 1870, 5]"] + 182["Segment
[1876, 1898, 5]"] + 183["Segment
[1904, 1960, 5]"] + 184["Segment
[1966, 1973, 5]"] 185[Solid2d] end subgraph path195 [Path] - 195["Path
[2107, 2153, 4]"] - 196["Segment
[2159, 2211, 4]"] - 197["Segment
[2217, 2324, 4]"] - 198["Segment
[2330, 2367, 4]"] - 199["Segment
[2373, 2429, 4]"] - 200["Segment
[2435, 2442, 4]"] + 195["Path
[2107, 2153, 5]"] + 196["Segment
[2159, 2211, 5]"] + 197["Segment
[2217, 2324, 5]"] + 198["Segment
[2330, 2367, 5]"] + 199["Segment
[2373, 2429, 5]"] + 200["Segment
[2435, 2442, 5]"] 201[Solid2d] end subgraph path212 [Path] - 212["Path
[2953, 3000, 4]"] - 213["Segment
[3008, 3348, 4]"] - 214["Segment
[3356, 3388, 4]"] - 215["Segment
[3396, 3740, 4]"] - 216["Segment
[3748, 3804, 4]"] - 217["Segment
[3812, 3819, 4]"] + 212["Path
[2953, 3000, 5]"] + 213["Segment
[3008, 3348, 5]"] + 214["Segment
[3356, 3388, 5]"] + 215["Segment
[3396, 3740, 5]"] + 216["Segment
[3748, 3804, 5]"] + 217["Segment
[3812, 3819, 5]"] 218[Solid2d] end subgraph path235 [Path] - 235["Path
[2953, 3000, 4]"] - 236["Segment
[3008, 3348, 4]"] - 237["Segment
[3356, 3388, 4]"] - 238["Segment
[3396, 3740, 4]"] - 239["Segment
[3748, 3804, 4]"] - 240["Segment
[3812, 3819, 4]"] + 235["Path
[2953, 3000, 5]"] + 236["Segment
[3008, 3348, 5]"] + 237["Segment
[3356, 3388, 5]"] + 238["Segment
[3396, 3740, 5]"] + 239["Segment
[3748, 3804, 5]"] + 240["Segment
[3812, 3819, 5]"] 241[Solid2d] end subgraph path258 [Path] - 258["Path
[4347, 4442, 4]"] - 259["Segment
[4448, 4481, 4]"] - 260["Segment
[4487, 4538, 4]"] - 261["Segment
[4544, 4577, 4]"] - 262["Segment
[4583, 4633, 4]"] - 263["Segment
[4639, 4680, 4]"] - 264["Segment
[4686, 4735, 4]"] - 265["Segment
[4741, 4774, 4]"] - 266["Segment
[4780, 4814, 4]"] - 267["Segment
[4820, 4854, 4]"] - 268["Segment
[4860, 4912, 4]"] - 269["Segment
[4918, 4952, 4]"] - 270["Segment
[4958, 5034, 4]"] - 271["Segment
[5040, 5073, 4]"] - 272["Segment
[5079, 5155, 4]"] - 273["Segment
[5161, 5195, 4]"] - 274["Segment
[5201, 5275, 4]"] - 275["Segment
[5281, 5315, 4]"] - 276["Segment
[5321, 5372, 4]"] - 277["Segment
[5378, 5440, 4]"] - 278["Segment
[5446, 5497, 4]"] - 279["Segment
[5503, 5537, 4]"] - 280["Segment
[5543, 5576, 4]"] - 281["Segment
[5582, 5615, 4]"] - 282["Segment
[5621, 5628, 4]"] + 258["Path
[4347, 4442, 5]"] + 259["Segment
[4448, 4481, 5]"] + 260["Segment
[4487, 4538, 5]"] + 261["Segment
[4544, 4577, 5]"] + 262["Segment
[4583, 4633, 5]"] + 263["Segment
[4639, 4680, 5]"] + 264["Segment
[4686, 4735, 5]"] + 265["Segment
[4741, 4774, 5]"] + 266["Segment
[4780, 4814, 5]"] + 267["Segment
[4820, 4854, 5]"] + 268["Segment
[4860, 4912, 5]"] + 269["Segment
[4918, 4952, 5]"] + 270["Segment
[4958, 5034, 5]"] + 271["Segment
[5040, 5073, 5]"] + 272["Segment
[5079, 5155, 5]"] + 273["Segment
[5161, 5195, 5]"] + 274["Segment
[5201, 5275, 5]"] + 275["Segment
[5281, 5315, 5]"] + 276["Segment
[5321, 5372, 5]"] + 277["Segment
[5378, 5440, 5]"] + 278["Segment
[5446, 5497, 5]"] + 279["Segment
[5503, 5537, 5]"] + 280["Segment
[5543, 5576, 5]"] + 281["Segment
[5582, 5615, 5]"] + 282["Segment
[5621, 5628, 5]"] 283[Solid2d] end subgraph path334 [Path] - 334["Path
[740, 780, 7]"] - 335["Segment
[788, 850, 7]"] - 336["Segment
[858, 894, 7]"] - 337["Segment
[902, 932, 7]"] - 338["Segment
[940, 992, 7]"] - 339["Segment
[1000, 1040, 7]"] - 340["Segment
[1048, 1083, 7]"] - 341["Segment
[1091, 1129, 7]"] - 342["Segment
[1137, 1159, 7]"] - 343["Segment
[1167, 1174, 7]"] + 334["Path
[740, 780, 8]"] + 335["Segment
[788, 850, 8]"] + 336["Segment
[858, 894, 8]"] + 337["Segment
[902, 932, 8]"] + 338["Segment
[940, 992, 8]"] + 339["Segment
[1000, 1040, 8]"] + 340["Segment
[1048, 1083, 8]"] + 341["Segment
[1091, 1129, 8]"] + 342["Segment
[1137, 1159, 8]"] + 343["Segment
[1167, 1174, 8]"] 344[Solid2d] end subgraph path365 [Path] - 365["Path
[507, 588, 6]"] - 366["Segment
[594, 695, 6]"] - 367["Segment
[701, 786, 6]"] - 368["Segment
[792, 876, 6]"] - 369["Segment
[882, 968, 6]"] - 370["Segment
[974, 1059, 6]"] - 371["Segment
[1065, 1151, 6]"] - 372["Segment
[1157, 1280, 6]"] - 373["Segment
[1286, 1372, 6]"] - 374["Segment
[1378, 1513, 6]"] - 375["Segment
[1519, 1605, 6]"] - 376["Segment
[1611, 1735, 6]"] - 377["Segment
[1741, 1827, 6]"] - 378["Segment
[1833, 1918, 6]"] - 379["Segment
[1924, 2010, 6]"] - 380["Segment
[2016, 2101, 6]"] - 381["Segment
[2107, 2192, 6]"] - 382["Segment
[2198, 2205, 6]"] + 365["Path
[507, 588, 7]"] + 366["Segment
[594, 695, 7]"] + 367["Segment
[701, 786, 7]"] + 368["Segment
[792, 876, 7]"] + 369["Segment
[882, 968, 7]"] + 370["Segment
[974, 1059, 7]"] + 371["Segment
[1065, 1151, 7]"] + 372["Segment
[1157, 1280, 7]"] + 373["Segment
[1286, 1372, 7]"] + 374["Segment
[1378, 1513, 7]"] + 375["Segment
[1519, 1605, 7]"] + 376["Segment
[1611, 1735, 7]"] + 377["Segment
[1741, 1827, 7]"] + 378["Segment
[1833, 1918, 7]"] + 379["Segment
[1924, 2010, 7]"] + 380["Segment
[2016, 2101, 7]"] + 381["Segment
[2107, 2192, 7]"] + 382["Segment
[2198, 2205, 7]"] 383[Solid2d] end subgraph path439 [Path] - 439["Path
[483, 540, 8]"] - 440["Segment
[546, 680, 8]"] - 441["Segment
[686, 741, 8]"] - 442["Segment
[747, 844, 8]"] - 443["Segment
[850, 882, 8]"] - 444["Segment
[888, 920, 8]"] - 445["Segment
[926, 957, 8]"] - 446["Segment
[963, 1078, 8]"] - 447["Segment
[1084, 1116, 8]"] - 448["Segment
[1122, 1154, 8]"] - 449["Segment
[1160, 1191, 8]"] - 450["Segment
[1197, 1290, 8]"] - 451["Segment
[1296, 1351, 8]"] - 452["Segment
[1357, 1430, 8]"] - 453["Segment
[1436, 1443, 8]"] + 439["Path
[483, 540, 9]"] + 440["Segment
[546, 680, 9]"] + 441["Segment
[686, 741, 9]"] + 442["Segment
[747, 844, 9]"] + 443["Segment
[850, 882, 9]"] + 444["Segment
[888, 920, 9]"] + 445["Segment
[926, 957, 9]"] + 446["Segment
[963, 1078, 9]"] + 447["Segment
[1084, 1116, 9]"] + 448["Segment
[1122, 1154, 9]"] + 449["Segment
[1160, 1191, 9]"] + 450["Segment
[1197, 1290, 9]"] + 451["Segment
[1296, 1351, 9]"] + 452["Segment
[1357, 1430, 9]"] + 453["Segment
[1436, 1443, 9]"] 454[Solid2d] end - 1["Plane
[544, 561, 5]"] - 5["Sweep Extrusion
[627, 683, 5]"] + 1["Plane
[544, 561, 6]"] + 5["Sweep Extrusion
[627, 683, 6]"] 6[Wall] 7["Cap Start"] 8["Cap End"] 9["SweepEdge Opposite"] 10["SweepEdge Adjacent"] - 14["Sweep Extrusion
[872, 934, 5]"] + 14["Sweep Extrusion
[872, 934, 6]"] 15[Wall] 16["Cap End"] 17["SweepEdge Opposite"] 18["SweepEdge Adjacent"] - 22["Sweep Extrusion
[1184, 1263, 5]"] + 22["Sweep Extrusion
[1184, 1263, 6]"] 23[Wall] 24["SweepEdge Opposite"] 25["SweepEdge Adjacent"] - 26["Sweep Extrusion
[1184, 1263, 5]"] - 27["Sweep Extrusion
[1184, 1263, 5]"] - 28["Sweep Extrusion
[1184, 1263, 5]"] - 29["Sweep Extrusion
[1184, 1263, 5]"] - 33["Sweep Extrusion
[1466, 1499, 5]"] + 26["Sweep Extrusion
[1184, 1263, 6]"] + 27["Sweep Extrusion
[1184, 1263, 6]"] + 28["Sweep Extrusion
[1184, 1263, 6]"] + 29["Sweep Extrusion
[1184, 1263, 6]"] + 33["Sweep Extrusion
[1466, 1499, 6]"] 34[Wall] 35["Cap End"] 36["SweepEdge Opposite"] 37["SweepEdge Adjacent"] - 41["Sweep Extrusion
[1630, 1695, 5]"] + 41["Sweep Extrusion
[1630, 1695, 6]"] 42[Wall] 43["Cap Start"] 44["Cap End"] 45["SweepEdge Opposite"] 46["SweepEdge Adjacent"] - 50["Sweep Extrusion
[1948, 1992, 5]"] + 50["Sweep Extrusion
[1948, 1992, 6]"] 51[Wall] 52["SweepEdge Opposite"] 53["SweepEdge Adjacent"] - 54["Sweep Extrusion
[1948, 1992, 5]"] - 55["Sweep Extrusion
[1948, 1992, 5]"] - 56["Sweep Extrusion
[1948, 1992, 5]"] - 57["Sweep Extrusion
[1948, 1992, 5]"] - 61["Sweep Extrusion
[2271, 2315, 5]"] + 54["Sweep Extrusion
[1948, 1992, 6]"] + 55["Sweep Extrusion
[1948, 1992, 6]"] + 56["Sweep Extrusion
[1948, 1992, 6]"] + 57["Sweep Extrusion
[1948, 1992, 6]"] + 61["Sweep Extrusion
[2271, 2315, 6]"] 62[Wall] 63["Cap End"] 64["SweepEdge Opposite"] 65["SweepEdge Adjacent"] - 66["Sweep Extrusion
[2271, 2315, 5]"] - 67["Sweep Extrusion
[2271, 2315, 5]"] - 68["Sweep Extrusion
[2271, 2315, 5]"] - 69["Sweep Extrusion
[2271, 2315, 5]"] - 70["Sweep Extrusion
[2271, 2315, 5]"] - 71["Sweep Extrusion
[2271, 2315, 5]"] - 72["Sweep Extrusion
[2271, 2315, 5]"] - 73["Sweep Extrusion
[2271, 2315, 5]"] - 74["Sweep Extrusion
[2271, 2315, 5]"] - 75["Sweep Extrusion
[2271, 2315, 5]"] - 76["Sweep Extrusion
[2271, 2315, 5]"] - 77["Sweep Extrusion
[2271, 2315, 5]"] - 78["Sweep Extrusion
[2271, 2315, 5]"] - 79["Sweep Extrusion
[2271, 2315, 5]"] - 80["Sweep Extrusion
[2271, 2315, 5]"] - 88["Sweep Extrusion
[2724, 2792, 5]"] + 66["Sweep Extrusion
[2271, 2315, 6]"] + 67["Sweep Extrusion
[2271, 2315, 6]"] + 68["Sweep Extrusion
[2271, 2315, 6]"] + 69["Sweep Extrusion
[2271, 2315, 6]"] + 70["Sweep Extrusion
[2271, 2315, 6]"] + 71["Sweep Extrusion
[2271, 2315, 6]"] + 72["Sweep Extrusion
[2271, 2315, 6]"] + 73["Sweep Extrusion
[2271, 2315, 6]"] + 74["Sweep Extrusion
[2271, 2315, 6]"] + 75["Sweep Extrusion
[2271, 2315, 6]"] + 76["Sweep Extrusion
[2271, 2315, 6]"] + 77["Sweep Extrusion
[2271, 2315, 6]"] + 78["Sweep Extrusion
[2271, 2315, 6]"] + 79["Sweep Extrusion
[2271, 2315, 6]"] + 80["Sweep Extrusion
[2271, 2315, 6]"] + 88["Sweep Extrusion
[2724, 2792, 6]"] 89[Wall] 90[Wall] 91[Wall] @@ -272,11 +272,11 @@ flowchart LR 99["SweepEdge Adjacent"] 100["SweepEdge Opposite"] 101["SweepEdge Adjacent"] - 102["Sweep Extrusion
[2724, 2792, 5]"] - 103["Sweep Extrusion
[2724, 2792, 5]"] - 104["Sweep Extrusion
[2724, 2792, 5]"] - 105["Sweep Extrusion
[2724, 2792, 5]"] - 113["Sweep Extrusion
[3198, 3272, 5]"] + 102["Sweep Extrusion
[2724, 2792, 6]"] + 103["Sweep Extrusion
[2724, 2792, 6]"] + 104["Sweep Extrusion
[2724, 2792, 6]"] + 105["Sweep Extrusion
[2724, 2792, 6]"] + 113["Sweep Extrusion
[3198, 3272, 6]"] 114[Wall] 115[Wall] 116[Wall] @@ -290,41 +290,41 @@ flowchart LR 124["SweepEdge Adjacent"] 125["SweepEdge Opposite"] 126["SweepEdge Adjacent"] - 127["Sweep Extrusion
[3198, 3272, 5]"] - 128["Sweep Extrusion
[3198, 3272, 5]"] - 129["Sweep Extrusion
[3198, 3272, 5]"] - 130["Sweep Extrusion
[3198, 3272, 5]"] - 131["Plane
[327, 344, 4]"] - 138["Sweep Extrusion
[483, 516, 4]"] + 127["Sweep Extrusion
[3198, 3272, 6]"] + 128["Sweep Extrusion
[3198, 3272, 6]"] + 129["Sweep Extrusion
[3198, 3272, 6]"] + 130["Sweep Extrusion
[3198, 3272, 6]"] + 131["Plane
[327, 344, 5]"] + 138["Sweep Extrusion
[483, 516, 5]"] 139[Wall] 140["Cap Start"] 141["Cap End"] 142["SweepEdge Opposite"] 143["SweepEdge Adjacent"] - 150["Sweep Extrusion
[771, 804, 4]"] + 150["Sweep Extrusion
[771, 804, 5]"] 151[Wall] 152["Cap Start"] 153["Cap End"] 154["SweepEdge Opposite"] 155["SweepEdge Adjacent"] - 159["Sweep Extrusion
[1106, 1140, 4]"] + 159["Sweep Extrusion
[1106, 1140, 5]"] 160[Wall] 161["SweepEdge Opposite"] 162["SweepEdge Adjacent"] - 163["Sweep Extrusion
[1106, 1140, 4]"] - 164["Sweep Extrusion
[1106, 1140, 4]"] - 165["Sweep Extrusion
[1106, 1140, 4]"] - 166["Sweep Extrusion
[1106, 1140, 4]"] - 170["Sweep Extrusion
[1444, 1478, 4]"] + 163["Sweep Extrusion
[1106, 1140, 5]"] + 164["Sweep Extrusion
[1106, 1140, 5]"] + 165["Sweep Extrusion
[1106, 1140, 5]"] + 166["Sweep Extrusion
[1106, 1140, 5]"] + 170["Sweep Extrusion
[1444, 1478, 5]"] 171[Wall] 172["SweepEdge Opposite"] 173["SweepEdge Adjacent"] - 174["Sweep Extrusion
[1444, 1478, 4]"] - 175["Sweep Extrusion
[1444, 1478, 4]"] - 176["Sweep Extrusion
[1444, 1478, 4]"] - 177["Sweep Extrusion
[1444, 1478, 4]"] - 178["Plane
[1632, 1649, 4]"] - 186["Sweep Revolve
[1979, 1998, 4]"] + 174["Sweep Extrusion
[1444, 1478, 5]"] + 175["Sweep Extrusion
[1444, 1478, 5]"] + 176["Sweep Extrusion
[1444, 1478, 5]"] + 177["Sweep Extrusion
[1444, 1478, 5]"] + 178["Plane
[1632, 1649, 5]"] + 186["Sweep Revolve
[1979, 1998, 5]"] 187[Wall] 188[Wall] 189[Wall] @@ -332,8 +332,8 @@ flowchart LR 191["SweepEdge Adjacent"] 192["SweepEdge Adjacent"] 193["SweepEdge Adjacent"] - 194["Plane
[2084, 2101, 4]"] - 202["Sweep Revolve
[2448, 2467, 4]"] + 194["Plane
[2084, 2101, 5]"] + 202["Sweep Revolve
[2448, 2467, 5]"] 203[Wall] 204[Wall] 205[Wall] @@ -342,8 +342,8 @@ flowchart LR 208["SweepEdge Adjacent"] 209["SweepEdge Adjacent"] 210["SweepEdge Adjacent"] - 211["Plane
[2922, 2945, 4]"] - 219["Sweep Extrusion
[3867, 3913, 4]"] + 211["Plane
[2922, 2945, 5]"] + 219["Sweep Extrusion
[3867, 3913, 5]"] 220[Wall] 221[Wall] 222[Wall] @@ -358,8 +358,8 @@ flowchart LR 231["SweepEdge Adjacent"] 232["SweepEdge Opposite"] 233["SweepEdge Adjacent"] - 234["Plane
[2922, 2945, 4]"] - 242["Sweep Extrusion
[3867, 3913, 4]"] + 234["Plane
[2922, 2945, 5]"] + 242["Sweep Extrusion
[3867, 3913, 5]"] 243[Wall] 244[Wall] 245[Wall] @@ -374,8 +374,8 @@ flowchart LR 254["SweepEdge Adjacent"] 255["SweepEdge Opposite"] 256["SweepEdge Adjacent"] - 257["Plane
[4324, 4341, 4]"] - 284["Sweep Revolve
[5634, 5653, 4]"] + 257["Plane
[4324, 4341, 5]"] + 284["Sweep Revolve
[5634, 5653, 5]"] 285[Wall] 286[Wall] 287[Wall] @@ -424,8 +424,8 @@ flowchart LR 330["SweepEdge Adjacent"] 331["SweepEdge Adjacent"] 332["SweepEdge Adjacent"] - 333["Plane
[706, 732, 7]"] - 345["Sweep Revolve
[1182, 1201, 7]"] + 333["Plane
[706, 732, 8]"] + 345["Sweep Revolve
[1182, 1201, 8]"] 346[Wall] 347[Wall] 348[Wall] @@ -444,8 +444,8 @@ flowchart LR 361["SweepEdge Adjacent"] 362["SweepEdge Adjacent"] 363["SweepEdge Adjacent"] - 364["Plane
[484, 501, 6]"] - 384["Sweep Revolve
[2243, 2295, 6]"] + 364["Plane
[484, 501, 7]"] + 384["Sweep Revolve
[2243, 2295, 7]"] 385[Wall] 386[Wall] 387[Wall] @@ -499,8 +499,8 @@ flowchart LR 435["SweepEdge Adjacent"] 436["SweepEdge Opposite"] 437["SweepEdge Adjacent"] - 438["Plane
[460, 477, 8]"] - 455["Sweep Revolve
[1486, 1517, 8]"] + 438["Plane
[460, 477, 9]"] + 455["Sweep Revolve
[1486, 1517, 9]"] 456[Wall] 457[Wall] 458[Wall] @@ -529,17 +529,17 @@ flowchart LR 481["SweepEdge Adjacent"] 482["SweepEdge Adjacent"] 483["SweepEdge Adjacent"] - 484["StartSketchOnFace
[770, 797, 5]"] - 485["StartSketchOnFace
[947, 978, 5]"] - 486["StartSketchOnFace
[1385, 1414, 5]"] - 487["StartSketchOnFace
[1524, 1558, 5]"] - 488["StartSketchOnFace
[1709, 1742, 5]"] - 489["StartSketchOnFace
[2009, 2038, 5]"] - 490["StartSketchOnFace
[2338, 2367, 5]"] - 491["StartSketchOnFace
[2821, 2854, 5]"] - 492["StartSketchOnFace
[603, 632, 4]"] - 493["StartSketchOnFace
[865, 899, 4]"] - 494["StartSketchOnFace
[1202, 1231, 4]"] + 484["StartSketchOnFace
[770, 797, 6]"] + 485["StartSketchOnFace
[947, 978, 6]"] + 486["StartSketchOnFace
[1385, 1414, 6]"] + 487["StartSketchOnFace
[1524, 1558, 6]"] + 488["StartSketchOnFace
[1709, 1742, 6]"] + 489["StartSketchOnFace
[2009, 2038, 6]"] + 490["StartSketchOnFace
[2338, 2367, 6]"] + 491["StartSketchOnFace
[2821, 2854, 6]"] + 492["StartSketchOnFace
[603, 632, 5]"] + 493["StartSketchOnFace
[865, 899, 5]"] + 494["StartSketchOnFace
[1202, 1231, 5]"] 1 --- 2 2 --- 3 2 ---- 5 diff --git a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ast.snap b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ast.snap index 6430c7a36..83024f310 100644 --- a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ast.snap @@ -168,54 +168,65 @@ description: Result of parsing car-wheel-assembly.kcl "label": { "commentStart": 366, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 378, - "elements": [ - { - "commentStart": 379, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 382, - "end": 0, - "raw": "0.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" - } - }, - { - "commentStart": 387, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], + "commentStart": 370, "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 373, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 377, + "end": 0, + "raw": "0.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 382, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 386, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } } ], @@ -253,14 +264,14 @@ description: Result of parsing car-wheel-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 391, + "commentStart": 389, "end": 0, "expression": { "abs_path": false, - "commentStart": 391, + "commentStart": 389, "end": 0, "name": { - "commentStart": 391, + "commentStart": 389, "end": 0, "name": "carWheel", "start": 0, @@ -276,16 +287,16 @@ description: Result of parsing car-wheel-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 400, + "commentStart": 398, "end": 0, "expression": { "body": [ { "abs_path": false, - "commentStart": 400, + "commentStart": 398, "end": 0, "name": { - "commentStart": 400, + "commentStart": 398, "end": 0, "name": "lugNut", "start": 0, @@ -301,14 +312,14 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 438, + "commentStart": 436, "end": 0, "name": "arcDegrees", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 451, + "commentStart": 449, "end": 0, "raw": "360", "start": 0, @@ -323,17 +334,17 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 463, + "commentStart": 461, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 470, + "commentStart": 468, "elements": [ { - "commentStart": 471, + "commentStart": 469, "end": 0, "raw": "0", "start": 0, @@ -345,7 +356,7 @@ description: Result of parsing car-wheel-assembly.kcl } }, { - "commentStart": 474, + "commentStart": 472, "end": 0, "raw": "1", "start": 0, @@ -357,7 +368,7 @@ description: Result of parsing car-wheel-assembly.kcl } }, { - "commentStart": 477, + "commentStart": 475, "end": 0, "raw": "0", "start": 0, @@ -378,17 +389,17 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 488, + "commentStart": 486, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 497, + "commentStart": 495, "elements": [ { - "commentStart": 498, + "commentStart": 496, "end": 0, "raw": "0", "start": 0, @@ -400,7 +411,7 @@ description: Result of parsing car-wheel-assembly.kcl } }, { - "commentStart": 501, + "commentStart": 499, "end": 0, "raw": "0", "start": 0, @@ -412,7 +423,7 @@ description: Result of parsing car-wheel-assembly.kcl } }, { - "commentStart": 504, + "commentStart": 502, "end": 0, "raw": "0", "start": 0, @@ -433,7 +444,7 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 515, + "commentStart": 513, "end": 0, "name": "instances", "start": 0, @@ -441,10 +452,10 @@ description: Result of parsing car-wheel-assembly.kcl }, "arg": { "abs_path": false, - "commentStart": 527, + "commentStart": 525, "end": 0, "name": { - "commentStart": 527, + "commentStart": 525, "end": 0, "name": "lugCount", "start": 0, @@ -459,14 +470,14 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 544, + "commentStart": 542, "end": 0, "name": "rotateDuplicates", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 563, + "commentStart": 561, "end": 0, "raw": "false", "start": 0, @@ -478,10 +489,10 @@ description: Result of parsing car-wheel-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 412, + "commentStart": 410, "end": 0, "name": { - "commentStart": 412, + "commentStart": 410, "end": 0, "name": "patternCircular3d", "start": 0, @@ -491,7 +502,7 @@ description: Result of parsing car-wheel-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 412, + "commentStart": 410, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -499,7 +510,7 @@ description: Result of parsing car-wheel-assembly.kcl "unlabeled": null } ], - "commentStart": 400, + "commentStart": 398, "end": 0, "start": 0, "type": "PipeExpression", @@ -510,16 +521,16 @@ description: Result of parsing car-wheel-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 577, + "commentStart": 575, "end": 0, "expression": { "body": [ { "abs_path": false, - "commentStart": 577, + "commentStart": 575, "end": 0, "name": { - "commentStart": 577, + "commentStart": 575, "end": 0, "name": "brakeCaliper", "start": 0, @@ -535,65 +546,76 @@ description: Result of parsing car-wheel-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 605, + "commentStart": 603, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 617, - "elements": [ - { - "commentStart": 618, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 621, - "end": 0, - "raw": "0.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" - } - }, - { - "commentStart": 626, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], + "commentStart": 607, "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 610, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 614, + "end": 0, + "raw": "0.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 619, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 623, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } } ], "callee": { "abs_path": false, - "commentStart": 595, + "commentStart": 593, "end": 0, "name": { - "commentStart": 595, + "commentStart": 593, "end": 0, "name": "translate", "start": 0, @@ -603,7 +625,7 @@ description: Result of parsing car-wheel-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 595, + "commentStart": 593, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -611,7 +633,7 @@ description: Result of parsing car-wheel-assembly.kcl "unlabeled": null } ], - "commentStart": 577, + "commentStart": 575, "end": 0, "start": 0, "type": "PipeExpression", @@ -622,14 +644,14 @@ description: Result of parsing car-wheel-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 630, + "commentStart": 626, "end": 0, "expression": { "abs_path": false, - "commentStart": 630, + "commentStart": 626, "end": 0, "name": { - "commentStart": 630, + "commentStart": 626, "end": 0, "name": "carTire", "start": 0, diff --git a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ops.snap b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ops.snap index f198d3e0c..c29de27c9 100644 --- a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/ops.snap @@ -1848,7 +1848,7 @@ description: Operations executed car-wheel-assembly.kcl "functionSourceRange": [ 2620, 4193, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2235,7 +2235,7 @@ description: Operations executed car-wheel-assembly.kcl "functionSourceRange": [ 2620, 4193, - 4 + 5 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2660,7 +2660,7 @@ description: Operations executed car-wheel-assembly.kcl "functionSourceRange": [ 664, 1291, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, diff --git a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/program_memory.snap index 611ac68c3..2cbd95c37 100644 --- a/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/car-wheel-assembly/program_memory.snap @@ -5,7 +5,7 @@ description: Variables in memory after executing car-wheel-assembly.kcl { "brakeCaliper": { "type": "Module", - "value": 6 + "value": 7 }, "c1": { "type": "TagIdentifier", @@ -14,15 +14,15 @@ description: Variables in memory after executing car-wheel-assembly.kcl }, "carRotor": { "type": "Module", - "value": 5 + "value": 6 }, "carTire": { "type": "Module", - "value": 8 + "value": 9 }, "carWheel": { "type": "Module", - "value": 4 + "value": 5 }, "lugCount": { "type": "Number", @@ -39,6 +39,6 @@ description: Variables in memory after executing car-wheel-assembly.kcl }, "lugNut": { "type": "Module", - "value": 7 + "value": 8 } } diff --git a/rust/kcl-lib/tests/kcl_samples/color-cube/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/color-cube/artifact_commands.snap index 7bcc0c8dc..5495016cb 100644 --- a/rust/kcl-lib/tests/kcl_samples/color-cube/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/color-cube/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands color-cube.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/artifact_commands.snap index b9f4e7e82..520e6ca80 100644 --- a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands cycloidal-gear.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/dodecahedron/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/dodecahedron/artifact_commands.snap index f63b70153..53558e1ab 100644 --- a/rust/kcl-lib/tests/kcl_samples/dodecahedron/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/dodecahedron/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands dodecahedron.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_commands.snap index c3240e555..507f89a8f 100644 --- a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands dual-basin-utility-sink.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_graph_flowchart.snap.md index 41fb8abe0..9c4e67619 100644 --- a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/artifact_graph_flowchart.snap.md @@ -1,119 +1,119 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[647, 681, 0]"] - 3["Segment
[687, 717, 0]"] - 4["Segment
[723, 753, 0]"] - 5["Segment
[759, 790, 0]"] - 6["Segment
[796, 852, 0]"] - 7["Segment
[858, 865, 0]"] + 2["Path
[662, 696, 0]"] + 3["Segment
[702, 734, 0]"] + 4["Segment
[740, 772, 0]"] + 5["Segment
[778, 811, 0]"] + 6["Segment
[817, 873, 0]"] + 7["Segment
[879, 886, 0]"] 8[Solid2d] end subgraph path32 [Path] - 32["Path
[1258, 1311, 0]"] - 33["Segment
[1317, 1347, 0]"] - 34["Segment
[1353, 1383, 0]"] - 35["Segment
[1389, 1420, 0]"] - 36["Segment
[1426, 1482, 0]"] - 37["Segment
[1488, 1495, 0]"] + 32["Path
[1279, 1332, 0]"] + 33["Segment
[1338, 1370, 0]"] + 34["Segment
[1376, 1408, 0]"] + 35["Segment
[1414, 1447, 0]"] + 36["Segment
[1453, 1509, 0]"] + 37["Segment
[1515, 1522, 0]"] 38[Solid2d] end subgraph path59 [Path] - 59["Path
[1760, 1813, 0]"] - 60["Segment
[1819, 1849, 0]"] - 61["Segment
[1855, 1885, 0]"] - 62["Segment
[1891, 1922, 0]"] - 63["Segment
[1928, 1984, 0]"] - 64["Segment
[1990, 1997, 0]"] + 59["Path
[1787, 1840, 0]"] + 60["Segment
[1846, 1878, 0]"] + 61["Segment
[1884, 1916, 0]"] + 62["Segment
[1922, 1955, 0]"] + 63["Segment
[1961, 2017, 0]"] + 64["Segment
[2023, 2030, 0]"] 65[Solid2d] end subgraph path83 [Path] - 83["Path
[2391, 2446, 0]"] - 84["Segment
[2452, 2482, 0]"] - 85["Segment
[2488, 2518, 0]"] - 86["Segment
[2524, 2555, 0]"] - 87["Segment
[2561, 2617, 0]"] - 88["Segment
[2623, 2630, 0]"] + 83["Path
[2426, 2481, 0]"] + 84["Segment
[2487, 2519, 0]"] + 85["Segment
[2525, 2557, 0]"] + 86["Segment
[2563, 2596, 0]"] + 87["Segment
[2602, 2658, 0]"] + 88["Segment
[2664, 2671, 0]"] 89[Solid2d] end subgraph path111 [Path] - 111["Path
[2932, 2970, 0]"] - 112["Segment
[2976, 3006, 0]"] - 113["Segment
[3012, 3036, 0]"] - 114["Segment
[3042, 3073, 0]"] - 115["Segment
[3079, 3135, 0]"] - 116["Segment
[3141, 3148, 0]"] + 111["Path
[2973, 3011, 0]"] + 112["Segment
[3017, 3049, 0]"] + 113["Segment
[3055, 3081, 0]"] + 114["Segment
[3087, 3120, 0]"] + 115["Segment
[3126, 3182, 0]"] + 116["Segment
[3188, 3195, 0]"] 117[Solid2d] end subgraph path134 [Path] - 134["Path
[3331, 3384, 0]"] - 135["Segment
[3390, 3420, 0]"] - 136["Segment
[3426, 3456, 0]"] - 137["Segment
[3462, 3493, 0]"] - 138["Segment
[3499, 3555, 0]"] - 139["Segment
[3561, 3568, 0]"] + 134["Path
[3378, 3431, 0]"] + 135["Segment
[3437, 3469, 0]"] + 136["Segment
[3475, 3507, 0]"] + 137["Segment
[3513, 3546, 0]"] + 138["Segment
[3552, 3608, 0]"] + 139["Segment
[3614, 3621, 0]"] 140[Solid2d] end subgraph path158 [Path] - 158["Path
[3794, 3831, 0]"] - 159["Segment
[3837, 3861, 0]"] - 160["Segment
[3867, 3891, 0]"] - 161["Segment
[3897, 3922, 0]"] - 162["Segment
[3928, 3984, 0]"] - 163["Segment
[3990, 3997, 0]"] + 158["Path
[3849, 3886, 0]"] + 159["Segment
[3892, 3918, 0]"] + 160["Segment
[3924, 3950, 0]"] + 161["Segment
[3956, 3983, 0]"] + 162["Segment
[3989, 4045, 0]"] + 163["Segment
[4051, 4058, 0]"] 164[Solid2d] end subgraph path180 [Path] - 180["Path
[4275, 4343, 0]"] - 181["Segment
[4349, 4373, 0]"] - 182["Segment
[4379, 4403, 0]"] - 183["Segment
[4409, 4434, 0]"] - 184["Segment
[4440, 4496, 0]"] - 185["Segment
[4502, 4509, 0]"] + 180["Path
[4340, 4408, 0]"] + 181["Segment
[4414, 4440, 0]"] + 182["Segment
[4446, 4472, 0]"] + 183["Segment
[4478, 4505, 0]"] + 184["Segment
[4511, 4567, 0]"] + 185["Segment
[4573, 4580, 0]"] 186[Solid2d] end subgraph path202 [Path] - 202["Path
[4698, 4794, 0]"] - 203["Segment
[4800, 4841, 0]"] - 204["Segment
[4847, 4887, 0]"] - 205["Segment
[4893, 4935, 0]"] - 206["Segment
[4941, 4997, 0]"] - 207["Segment
[5003, 5010, 0]"] + 202["Path
[4769, 4890, 0]"] + 203["Segment
[4896, 4945, 0]"] + 204["Segment
[4951, 4999, 0]"] + 205["Segment
[5005, 5053, 0]"] + 206["Segment
[5059, 5115, 0]"] + 207["Segment
[5121, 5128, 0]"] 208[Solid2d] end subgraph path225 [Path] - 225["Path
[5538, 5579, 0]"] - 226["Segment
[5585, 5615, 0]"] - 227["Segment
[5621, 5644, 0]"] - 228["Segment
[5650, 5681, 0]"] - 229["Segment
[5687, 5743, 0]"] - 230["Segment
[5749, 5756, 0]"] + 225["Path
[5660, 5701, 0]"] + 226["Segment
[5707, 5739, 0]"] + 227["Segment
[5745, 5770, 0]"] + 228["Segment
[5776, 5809, 0]"] + 229["Segment
[5815, 5871, 0]"] + 230["Segment
[5877, 5884, 0]"] 231[Solid2d] end subgraph path252 [Path] - 252["Path
[6039, 6080, 0]"] - 253["Segment
[6086, 6110, 0]"] - 254["Segment
[6116, 6146, 0]"] - 255["Segment
[6152, 6177, 0]"] - 256["Segment
[6183, 6239, 0]"] - 257["Segment
[6245, 6252, 0]"] + 252["Path
[6171, 6212, 0]"] + 253["Segment
[6218, 6244, 0]"] + 254["Segment
[6250, 6282, 0]"] + 255["Segment
[6288, 6315, 0]"] + 256["Segment
[6321, 6377, 0]"] + 257["Segment
[6383, 6390, 0]"] 258[Solid2d] end subgraph path276 [Path] - 276["Path
[6731, 6781, 0]"] - 277["Segment
[6787, 6822, 0]"] - 278["Segment
[6828, 6912, 0]"] - 279["Segment
[6918, 6952, 0]"] - 280["Segment
[6958, 7050, 0]"] - 281["Segment
[7056, 7090, 0]"] + 276["Path
[6867, 6917, 0]"] + 277["Segment
[6923, 6960, 0]"] + 278["Segment
[6966, 7050, 0]"] + 279["Segment
[7056, 7092, 0]"] + 280["Segment
[7098, 7190, 0]"] + 281["Segment
[7196, 7232, 0]"] end subgraph path283 [Path] - 283["Path
[7153, 7250, 0]"] - 284["Segment
[7153, 7250, 0]"] + 283["Path
[7295, 7406, 0]"] + 284["Segment
[7295, 7406, 0]"] 285[Solid2d] end - 1["Plane
[540, 557, 0]"] - 9["Sweep Extrusion
[1026, 1053, 0]"] + 1["Plane
[555, 572, 0]"] + 9["Sweep Extrusion
[1047, 1074, 0]"] 10[Wall] 11[Wall] 12[Wall] @@ -128,15 +128,15 @@ flowchart LR 21["SweepEdge Adjacent"] 22["SweepEdge Opposite"] 23["SweepEdge Adjacent"] - 24["Sweep Extrusion
[1026, 1053, 0]"] - 25["Sweep Extrusion
[1026, 1053, 0]"] - 26["Sweep Extrusion
[1026, 1053, 0]"] - 27["Sweep Extrusion
[1026, 1053, 0]"] - 28["Sweep Extrusion
[1026, 1053, 0]"] - 29["Sweep Extrusion
[1026, 1053, 0]"] - 30["Sweep Extrusion
[1026, 1053, 0]"] - 31["Plane
[1185, 1239, 0]"] - 39["Sweep Extrusion
[1658, 1692, 0]"] + 24["Sweep Extrusion
[1047, 1074, 0]"] + 25["Sweep Extrusion
[1047, 1074, 0]"] + 26["Sweep Extrusion
[1047, 1074, 0]"] + 27["Sweep Extrusion
[1047, 1074, 0]"] + 28["Sweep Extrusion
[1047, 1074, 0]"] + 29["Sweep Extrusion
[1047, 1074, 0]"] + 30["Sweep Extrusion
[1047, 1074, 0]"] + 31["Plane
[1206, 1260, 0]"] + 39["Sweep Extrusion
[1685, 1719, 0]"] 40[Wall] 41[Wall] 42[Wall] @@ -151,12 +151,12 @@ flowchart LR 51["SweepEdge Adjacent"] 52["SweepEdge Opposite"] 53["SweepEdge Adjacent"] - 54["Sweep Extrusion
[1658, 1692, 0]"] - 55["Sweep Extrusion
[1658, 1692, 0]"] - 56["Sweep Extrusion
[1658, 1692, 0]"] - 57["Sweep Extrusion
[1658, 1692, 0]"] - 58["Sweep Extrusion
[1658, 1692, 0]"] - 66["Sweep Extrusion
[2094, 2128, 0]"] + 54["Sweep Extrusion
[1685, 1719, 0]"] + 55["Sweep Extrusion
[1685, 1719, 0]"] + 56["Sweep Extrusion
[1685, 1719, 0]"] + 57["Sweep Extrusion
[1685, 1719, 0]"] + 58["Sweep Extrusion
[1685, 1719, 0]"] + 66["Sweep Extrusion
[2129, 2163, 0]"] 67[Wall] 68[Wall] 69[Wall] @@ -171,9 +171,9 @@ flowchart LR 78["SweepEdge Adjacent"] 79["SweepEdge Opposite"] 80["SweepEdge Adjacent"] - 81["Sweep Extrusion
[2094, 2128, 0]"] - 82["Plane
[2245, 2296, 0]"] - 90["Sweep Extrusion
[2793, 2828, 0]"] + 81["Sweep Extrusion
[2129, 2163, 0]"] + 82["Plane
[2280, 2331, 0]"] + 90["Sweep Extrusion
[2834, 2869, 0]"] 91[Wall] 92[Wall] 93[Wall] @@ -188,13 +188,13 @@ flowchart LR 102["SweepEdge Adjacent"] 103["SweepEdge Opposite"] 104["SweepEdge Adjacent"] - 105["Sweep Extrusion
[2793, 2828, 0]"] - 106["Sweep Extrusion
[2793, 2828, 0]"] - 107["Sweep Extrusion
[2793, 2828, 0]"] - 108["Sweep Extrusion
[2793, 2828, 0]"] - 109["Sweep Extrusion
[2793, 2828, 0]"] - 110["Plane
[2875, 2912, 0]"] - 118["Sweep Extrusion
[3228, 3263, 0]"] + 105["Sweep Extrusion
[2834, 2869, 0]"] + 106["Sweep Extrusion
[2834, 2869, 0]"] + 107["Sweep Extrusion
[2834, 2869, 0]"] + 108["Sweep Extrusion
[2834, 2869, 0]"] + 109["Sweep Extrusion
[2834, 2869, 0]"] + 110["Plane
[2916, 2953, 0]"] + 118["Sweep Extrusion
[3275, 3310, 0]"] 119[Wall] 120[Wall] 121[Wall] @@ -209,8 +209,8 @@ flowchart LR 130["SweepEdge Adjacent"] 131["SweepEdge Opposite"] 132["SweepEdge Adjacent"] - 133["Sweep Extrusion
[3228, 3263, 0]"] - 141["Sweep Extrusion
[3665, 3700, 0]"] + 133["Sweep Extrusion
[3275, 3310, 0]"] + 141["Sweep Extrusion
[3720, 3755, 0]"] 142[Wall] 143[Wall] 144[Wall] @@ -225,9 +225,9 @@ flowchart LR 153["SweepEdge Adjacent"] 154["SweepEdge Opposite"] 155["SweepEdge Adjacent"] - 156["Sweep Extrusion
[3665, 3700, 0]"] - 157["Plane
[3740, 3777, 0]"] - 165["Sweep Extrusion
[4003, 4036, 0]"] + 156["Sweep Extrusion
[3720, 3755, 0]"] + 157["Plane
[3795, 3832, 0]"] + 165["Sweep Extrusion
[4064, 4097, 0]"] 166[Wall] 167[Wall] 168[Wall] @@ -242,7 +242,7 @@ flowchart LR 177["SweepEdge Adjacent"] 178["SweepEdge Opposite"] 179["SweepEdge Adjacent"] - 187["Sweep Extrusion
[4599, 4626, 0]"] + 187["Sweep Extrusion
[4670, 4697, 0]"] 188[Wall] 189[Wall] 190[Wall] @@ -256,8 +256,8 @@ flowchart LR 198["SweepEdge Adjacent"] 199["SweepEdge Opposite"] 200["SweepEdge Adjacent"] - 201["Sweep Extrusion
[4599, 4626, 0]"] - 209["Sweep Extrusion
[5099, 5127, 0]"] + 201["Sweep Extrusion
[4670, 4697, 0]"] + 209["Sweep Extrusion
[5217, 5245, 0]"] 210[Wall] 211[Wall] 212[Wall] @@ -271,9 +271,9 @@ flowchart LR 220["SweepEdge Adjacent"] 221["SweepEdge Opposite"] 222["SweepEdge Adjacent"] - 223["Sweep Extrusion
[5099, 5127, 0]"] - 224["Plane
[5476, 5525, 0]"] - 232["Sweep Extrusion
[5855, 5883, 0]"] + 223["Sweep Extrusion
[5217, 5245, 0]"] + 224["Plane
[5598, 5647, 0]"] + 232["Sweep Extrusion
[5983, 6011, 0]"] 233[Wall] 234[Wall] 235[Wall] @@ -288,12 +288,12 @@ flowchart LR 244["SweepEdge Adjacent"] 245["SweepEdge Opposite"] 246["SweepEdge Adjacent"] - 247["Sweep Extrusion
[5855, 5883, 0]"] - 248["Sweep Extrusion
[5855, 5883, 0]"] - 249["Sweep Extrusion
[5855, 5883, 0]"] - 250["Sweep Extrusion
[5855, 5883, 0]"] - 251["Sweep Extrusion
[5855, 5883, 0]"] - 259["Sweep Extrusion
[6334, 6362, 0]"] + 247["Sweep Extrusion
[5983, 6011, 0]"] + 248["Sweep Extrusion
[5983, 6011, 0]"] + 249["Sweep Extrusion
[5983, 6011, 0]"] + 250["Sweep Extrusion
[5983, 6011, 0]"] + 251["Sweep Extrusion
[5983, 6011, 0]"] + 259["Sweep Extrusion
[6472, 6500, 0]"] 260[Wall] 261[Wall] 262[Wall] @@ -308,23 +308,23 @@ flowchart LR 271["SweepEdge Adjacent"] 272["SweepEdge Opposite"] 273["SweepEdge Adjacent"] - 274["Sweep Extrusion
[6334, 6362, 0]"] - 275["Plane
[6657, 6708, 0]"] - 282["Plane
[7112, 7129, 0]"] - 286["Sweep Sweep
[7267, 7320, 0]"] + 274["Sweep Extrusion
[6472, 6500, 0]"] + 275["Plane
[6793, 6844, 0]"] + 282["Plane
[7254, 7271, 0]"] + 286["Sweep Sweep
[7420, 7473, 0]"] 287[Wall] 288["Cap Start"] 289["Cap Start"] 290["SweepEdge Opposite"] 291["SweepEdge Adjacent"] - 292["StartSketchOnPlane
[1171, 1240, 0]"] - 293["StartSketchOnPlane
[2231, 2297, 0]"] - 294["StartSketchOnPlane
[2861, 2913, 0]"] - 295["StartSketchOnPlane
[3726, 3778, 0]"] - 296["StartSketchOnFace
[4220, 4256, 0]"] - 297["StartSketchOnFace
[4646, 4680, 0]"] - 298["StartSketchOnPlane
[5462, 5526, 0]"] - 299["StartSketchOnPlane
[6643, 6709, 0]"] + 292["StartSketchOnPlane
[1192, 1261, 0]"] + 293["StartSketchOnPlane
[2266, 2332, 0]"] + 294["StartSketchOnPlane
[2902, 2954, 0]"] + 295["StartSketchOnPlane
[3781, 3833, 0]"] + 296["StartSketchOnFace
[4285, 4321, 0]"] + 297["StartSketchOnFace
[4717, 4751, 0]"] + 298["StartSketchOnPlane
[5584, 5648, 0]"] + 299["StartSketchOnPlane
[6779, 6845, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/ast.snap b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/ast.snap index 0c1fb94fe..fa981352c 100644 --- a/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/dual-basin-utility-sink/ast.snap @@ -6,19 +6,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "Ok": { "body": [ { - "commentStart": 165, + "commentStart": 178, "declaration": { - "commentStart": 178, + "commentStart": 191, "end": 0, "id": { - "commentStart": 178, + "commentStart": 191, "end": 0, "name": "tableHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 192, + "commentStart": 205, "end": 0, "raw": "850", "start": 0, @@ -42,19 +42,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 196, + "commentStart": 209, "declaration": { - "commentStart": 196, + "commentStart": 209, "end": 0, "id": { - "commentStart": 196, + "commentStart": 209, "end": 0, "name": "tableWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 209, + "commentStart": 222, "end": 0, "raw": "3400", "start": 0, @@ -75,19 +75,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 214, + "commentStart": 227, "declaration": { - "commentStart": 214, + "commentStart": 227, "end": 0, "id": { - "commentStart": 214, + "commentStart": 227, "end": 0, "name": "tableDepth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 227, + "commentStart": 240, "end": 0, "raw": "400", "start": 0, @@ -108,19 +108,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 230, + "commentStart": 243, "declaration": { - "commentStart": 232, + "commentStart": 245, "end": 0, "id": { - "commentStart": 232, + "commentStart": 245, "end": 0, "name": "profileThickness", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 251, + "commentStart": 264, "end": 0, "raw": "13", "start": 0, @@ -141,19 +141,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 254, + "commentStart": 267, "declaration": { - "commentStart": 254, + "commentStart": 267, "end": 0, "id": { - "commentStart": 254, + "commentStart": 267, "end": 0, "name": "metalThickness", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 271, + "commentStart": 284, "end": 0, "raw": "2", "start": 0, @@ -174,19 +174,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 272, + "commentStart": 285, "declaration": { - "commentStart": 274, + "commentStart": 287, "end": 0, "id": { - "commentStart": 274, + "commentStart": 287, "end": 0, "name": "blockCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 287, + "commentStart": 300, "end": 0, "raw": "3", "start": 0, @@ -207,29 +207,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 289, + "commentStart": 302, "declaration": { - "commentStart": 289, + "commentStart": 302, "end": 0, "id": { - "commentStart": 289, + "commentStart": 302, "end": 0, "name": "blockWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 303, + "commentStart": 316, "end": 0, "left": { - "commentStart": 303, + "commentStart": 316, "end": 0, "left": { "abs_path": false, - "commentStart": 303, + "commentStart": 316, "end": 0, "name": { - "commentStart": 303, + "commentStart": 316, "end": 0, "name": "tableWidth", "start": 0, @@ -243,10 +243,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 314, + "commentStart": 329, "end": 0, "name": { - "commentStart": 314, + "commentStart": 329, "end": 0, "name": "profileThickness", "start": 0, @@ -263,7 +263,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "/", "right": { - "commentStart": 334, + "commentStart": 349, "end": 0, "raw": "3", "start": 0, @@ -288,29 +288,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 336, + "commentStart": 351, "declaration": { - "commentStart": 336, + "commentStart": 351, "end": 0, "id": { - "commentStart": 336, + "commentStart": 351, "end": 0, "name": "blockHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 350, + "commentStart": 365, "end": 0, "left": { - "commentStart": 350, + "commentStart": 365, "end": 0, "left": { "abs_path": false, - "commentStart": 350, + "commentStart": 365, "end": 0, "name": { - "commentStart": 350, + "commentStart": 365, "end": 0, "name": "tableHeight", "start": 0, @@ -324,10 +324,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 364, + "commentStart": 379, "end": 0, "name": { - "commentStart": 364, + "commentStart": 379, "end": 0, "name": "metalThickness", "start": 0, @@ -344,7 +344,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 381, + "commentStart": 396, "end": 0, "raw": "0.5", "start": 0, @@ -369,26 +369,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 385, + "commentStart": 400, "declaration": { - "commentStart": 385, + "commentStart": 400, "end": 0, "id": { - "commentStart": 385, + "commentStart": 400, "end": 0, "name": "blockDepth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 398, + "commentStart": 413, "end": 0, "left": { "abs_path": false, - "commentStart": 398, + "commentStart": 413, "end": 0, "name": { - "commentStart": 398, + "commentStart": 413, "end": 0, "name": "tableDepth", "start": 0, @@ -402,10 +402,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 411, + "commentStart": 426, "end": 0, "name": { - "commentStart": 411, + "commentStart": 426, "end": 0, "name": "profileThickness", "start": 0, @@ -430,19 +430,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 427, + "commentStart": 442, "declaration": { - "commentStart": 429, + "commentStart": 444, "end": 0, "id": { - "commentStart": 429, + "commentStart": 444, "end": 0, "name": "blockSubdivisionCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 453, + "commentStart": 468, "end": 0, "raw": "2", "start": 0, @@ -463,26 +463,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 455, + "commentStart": 470, "declaration": { - "commentStart": 455, + "commentStart": 470, "end": 0, "id": { - "commentStart": 455, + "commentStart": 470, "end": 0, "name": "blockSubdivisionWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 479, + "commentStart": 494, "end": 0, "left": { "abs_path": false, - "commentStart": 479, + "commentStart": 494, "end": 0, "name": { - "commentStart": 479, + "commentStart": 494, "end": 0, "name": "blockWidth", "start": 0, @@ -496,10 +496,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "/", "right": { "abs_path": false, - "commentStart": 492, + "commentStart": 507, "end": 0, "name": { - "commentStart": 492, + "commentStart": 507, "end": 0, "name": "blockSubdivisionCount", "start": 0, @@ -524,12 +524,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 513, + "commentStart": 528, "declaration": { - "commentStart": 527, + "commentStart": 542, "end": 0, "id": { - "commentStart": 527, + "commentStart": 542, "end": 0, "name": "floorPlane", "start": 0, @@ -539,10 +539,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [ { "abs_path": false, - "commentStart": 554, + "commentStart": 569, "end": 0, "name": { - "commentStart": 554, + "commentStart": 569, "end": 0, "name": "XY", "start": 0, @@ -556,10 +556,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 540, + "commentStart": 555, "end": 0, "name": { - "commentStart": 540, + "commentStart": 555, "end": 0, "name": "startSketchOn", "start": 0, @@ -569,7 +569,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 540, + "commentStart": 555, "end": 0, "start": 0, "type": "CallExpression", @@ -590,26 +590,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 557, + "commentStart": 572, "declaration": { - "commentStart": 567, + "commentStart": 582, "end": 0, "id": { - "commentStart": 567, + "commentStart": 582, "end": 0, "name": "legHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 579, + "commentStart": 594, "end": 0, "left": { "abs_path": false, - "commentStart": 579, + "commentStart": 594, "end": 0, "name": { - "commentStart": 579, + "commentStart": 594, "end": 0, "name": "blockHeight", "start": 0, @@ -623,10 +623,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 593, + "commentStart": 608, "end": 0, "name": { - "commentStart": 593, + "commentStart": 608, "end": 0, "name": "profileThickness", "start": 0, @@ -656,26 +656,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 610, + "commentStart": 625, "declaration": { - "commentStart": 610, + "commentStart": 625, "end": 0, "id": { - "commentStart": 610, + "commentStart": 625, "end": 0, "name": "legCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 621, + "commentStart": 636, "end": 0, "left": { "abs_path": false, - "commentStart": 621, + "commentStart": 636, "end": 0, "name": { - "commentStart": 621, + "commentStart": 636, "end": 0, "name": "blockCount", "start": 0, @@ -688,7 +688,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "+", "right": { - "commentStart": 634, + "commentStart": 649, "end": 0, "raw": "1", "start": 0, @@ -713,12 +713,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 635, + "commentStart": 650, "declaration": { - "commentStart": 637, + "commentStart": 652, "end": 0, "id": { - "commentStart": 637, + "commentStart": 652, "end": 0, "name": "legBody", "start": 0, @@ -729,10 +729,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 662, + "commentStart": 677, "elements": [ { - "commentStart": 663, + "commentStart": 678, "end": 0, "raw": "0", "start": 0, @@ -744,7 +744,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 666, + "commentStart": 681, "end": 0, "raw": "0", "start": 0, @@ -763,10 +763,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 670, + "commentStart": 685, "end": 0, "name": { - "commentStart": 670, + "commentStart": 685, "end": 0, "name": "floorPlane", "start": 0, @@ -780,10 +780,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 647, + "commentStart": 662, "end": 0, "name": { - "commentStart": 647, + "commentStart": 662, "end": 0, "name": "startProfileAt", "start": 0, @@ -793,7 +793,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 647, + "commentStart": 662, "end": 0, "start": 0, "type": "CallExpression", @@ -804,7 +804,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 693, + "commentStart": 708, "end": 0, "name": "length", "start": 0, @@ -812,10 +812,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 700, + "commentStart": 717, "end": 0, "name": { - "commentStart": 700, + "commentStart": 717, "end": 0, "name": "profileThickness", "start": 0, @@ -830,10 +830,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 687, + "commentStart": 702, "end": 0, "name": { - "commentStart": 687, + "commentStart": 702, "end": 0, "name": "yLine", "start": 0, @@ -843,7 +843,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 687, + "commentStart": 702, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -855,7 +855,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 729, + "commentStart": 746, "end": 0, "name": "length", "start": 0, @@ -863,10 +863,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 736, + "commentStart": 755, "end": 0, "name": { - "commentStart": 736, + "commentStart": 755, "end": 0, "name": "profileThickness", "start": 0, @@ -881,10 +881,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 723, + "commentStart": 740, "end": 0, "name": { - "commentStart": 723, + "commentStart": 740, "end": 0, "name": "xLine", "start": 0, @@ -894,7 +894,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 723, + "commentStart": 740, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -906,7 +906,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 765, + "commentStart": 784, "end": 0, "name": "length", "start": 0, @@ -915,10 +915,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 773, + "commentStart": 794, "end": 0, "name": { - "commentStart": 773, + "commentStart": 794, "end": 0, "name": "profileThickness", "start": 0, @@ -929,7 +929,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 772, + "commentStart": 793, "end": 0, "operator": "-", "start": 0, @@ -940,10 +940,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 759, + "commentStart": 778, "end": 0, "name": { - "commentStart": 759, + "commentStart": 778, "end": 0, "name": "yLine", "start": 0, @@ -953,7 +953,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 759, + "commentStart": 778, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -965,19 +965,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 801, + "commentStart": 822, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 815, + "commentStart": 836, "elements": [ { "arguments": [ { - "commentStart": 830, + "commentStart": 851, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -986,10 +986,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 816, + "commentStart": 837, "end": 0, "name": { - "commentStart": 816, + "commentStart": 837, "end": 0, "name": "profileStartX", "start": 0, @@ -999,7 +999,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 816, + "commentStart": 837, "end": 0, "start": 0, "type": "CallExpression", @@ -1008,7 +1008,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 848, + "commentStart": 869, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1017,10 +1017,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 834, + "commentStart": 855, "end": 0, "name": { - "commentStart": 834, + "commentStart": 855, "end": 0, "name": "profileStartY", "start": 0, @@ -1030,7 +1030,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 834, + "commentStart": 855, "end": 0, "start": 0, "type": "CallExpression", @@ -1046,10 +1046,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 796, + "commentStart": 817, "end": 0, "name": { - "commentStart": 796, + "commentStart": 817, "end": 0, "name": "line", "start": 0, @@ -1059,7 +1059,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 796, + "commentStart": 817, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1070,10 +1070,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 858, + "commentStart": 879, "end": 0, "name": { - "commentStart": 858, + "commentStart": 879, "end": 0, "name": "close", "start": 0, @@ -1083,7 +1083,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 858, + "commentStart": 879, "end": 0, "start": 0, "type": "CallExpression", @@ -1094,17 +1094,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 887, + "commentStart": 908, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 894, + "commentStart": 915, "elements": [ { - "commentStart": 895, + "commentStart": 916, "end": 0, "raw": "1", "start": 0, @@ -1116,7 +1116,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 898, + "commentStart": 919, "end": 0, "raw": "0", "start": 0, @@ -1137,7 +1137,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 902, + "commentStart": 923, "end": 0, "name": "instances", "start": 0, @@ -1145,10 +1145,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 914, + "commentStart": 935, "end": 0, "name": { - "commentStart": 914, + "commentStart": 935, "end": 0, "name": "legCount", "start": 0, @@ -1163,7 +1163,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 924, + "commentStart": 945, "end": 0, "name": "distance", "start": 0, @@ -1171,10 +1171,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 935, + "commentStart": 956, "end": 0, "name": { - "commentStart": 935, + "commentStart": 956, "end": 0, "name": "blockWidth", "start": 0, @@ -1189,10 +1189,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 871, + "commentStart": 892, "end": 0, "name": { - "commentStart": 871, + "commentStart": 892, "end": 0, "name": "patternLinear2d", "start": 0, @@ -1202,7 +1202,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 871, + "commentStart": 892, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1214,17 +1214,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 968, + "commentStart": 989, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 975, + "commentStart": 996, "elements": [ { - "commentStart": 976, + "commentStart": 997, "end": 0, "raw": "0", "start": 0, @@ -1236,7 +1236,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 979, + "commentStart": 1000, "end": 0, "raw": "1", "start": 0, @@ -1257,14 +1257,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 983, + "commentStart": 1004, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 995, + "commentStart": 1016, "end": 0, "raw": "2", "start": 0, @@ -1279,7 +1279,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 998, + "commentStart": 1019, "end": 0, "name": "distance", "start": 0, @@ -1287,10 +1287,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1009, + "commentStart": 1030, "end": 0, "name": { - "commentStart": 1009, + "commentStart": 1030, "end": 0, "name": "blockDepth", "start": 0, @@ -1305,10 +1305,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 952, + "commentStart": 973, "end": 0, "name": { - "commentStart": 952, + "commentStart": 973, "end": 0, "name": "patternLinear2d", "start": 0, @@ -1318,7 +1318,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 952, + "commentStart": 973, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1330,7 +1330,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1034, + "commentStart": 1055, "end": 0, "name": "length", "start": 0, @@ -1338,10 +1338,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1043, + "commentStart": 1064, "end": 0, "name": { - "commentStart": 1043, + "commentStart": 1064, "end": 0, "name": "legHeight", "start": 0, @@ -1356,10 +1356,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1026, + "commentStart": 1047, "end": 0, "name": { - "commentStart": 1026, + "commentStart": 1047, "end": 0, "name": "extrude", "start": 0, @@ -1369,7 +1369,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1026, + "commentStart": 1047, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1377,13 +1377,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 647, + "commentStart": 662, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "8": [ { - "commentStart": 1053, + "commentStart": 1074, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1411,19 +1411,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1069, + "commentStart": 1090, "declaration": { - "commentStart": 1069, + "commentStart": 1090, "end": 0, "id": { - "commentStart": 1069, + "commentStart": 1090, "end": 0, "name": "lowerBeltHeightAboveTheFloor", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 1100, + "commentStart": 1121, "end": 0, "raw": "150", "start": 0, @@ -1444,26 +1444,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1104, + "commentStart": 1125, "declaration": { - "commentStart": 1104, + "commentStart": 1125, "end": 0, "id": { - "commentStart": 1104, + "commentStart": 1125, "end": 0, "name": "lowerBeltLengthX", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 1123, + "commentStart": 1144, "end": 0, "left": { "abs_path": false, - "commentStart": 1123, + "commentStart": 1144, "end": 0, "name": { - "commentStart": 1123, + "commentStart": 1144, "end": 0, "name": "blockWidth", "start": 0, @@ -1477,10 +1477,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1136, + "commentStart": 1157, "end": 0, "name": { - "commentStart": 1136, + "commentStart": 1157, "end": 0, "name": "profileThickness", "start": 0, @@ -1505,12 +1505,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1152, + "commentStart": 1173, "declaration": { - "commentStart": 1154, + "commentStart": 1175, "end": 0, "id": { - "commentStart": 1154, + "commentStart": 1175, "end": 0, "name": "lowerBeltPlane", "start": 0, @@ -1523,7 +1523,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1201, + "commentStart": 1222, "end": 0, "name": "offset", "start": 0, @@ -1531,10 +1531,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1210, + "commentStart": 1231, "end": 0, "name": { - "commentStart": 1210, + "commentStart": 1231, "end": 0, "name": "lowerBeltHeightAboveTheFloor", "start": 0, @@ -1549,10 +1549,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1185, + "commentStart": 1206, "end": 0, "name": { - "commentStart": 1185, + "commentStart": 1206, "end": 0, "name": "offsetPlane", "start": 0, @@ -1562,17 +1562,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1185, + "commentStart": 1206, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1197, + "commentStart": 1218, "end": 0, "name": { - "commentStart": 1197, + "commentStart": 1218, "end": 0, "name": "XY", "start": 0, @@ -1587,10 +1587,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1171, + "commentStart": 1192, "end": 0, "name": { - "commentStart": 1171, + "commentStart": 1192, "end": 0, "name": "startSketchOn", "start": 0, @@ -1600,7 +1600,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1171, + "commentStart": 1192, "end": 0, "start": 0, "type": "CallExpression", @@ -1616,12 +1616,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1241, + "commentStart": 1262, "declaration": { - "commentStart": 1241, + "commentStart": 1262, "end": 0, "id": { - "commentStart": 1241, + "commentStart": 1262, "end": 0, "name": "lowerBeltBodyX", "start": 0, @@ -1632,14 +1632,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 1273, + "commentStart": 1294, "elements": [ { "abs_path": false, - "commentStart": 1274, + "commentStart": 1295, "end": 0, "name": { - "commentStart": 1274, + "commentStart": 1295, "end": 0, "name": "profileThickness", "start": 0, @@ -1651,7 +1651,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name" }, { - "commentStart": 1292, + "commentStart": 1313, "end": 0, "raw": "0", "start": 0, @@ -1670,10 +1670,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 1296, + "commentStart": 1317, "end": 0, "name": { - "commentStart": 1296, + "commentStart": 1317, "end": 0, "name": "lowerBeltPlane", "start": 0, @@ -1687,10 +1687,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1258, + "commentStart": 1279, "end": 0, "name": { - "commentStart": 1258, + "commentStart": 1279, "end": 0, "name": "startProfileAt", "start": 0, @@ -1700,7 +1700,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1258, + "commentStart": 1279, "end": 0, "start": 0, "type": "CallExpression", @@ -1711,7 +1711,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1323, + "commentStart": 1344, "end": 0, "name": "length", "start": 0, @@ -1719,10 +1719,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1330, + "commentStart": 1353, "end": 0, "name": { - "commentStart": 1330, + "commentStart": 1353, "end": 0, "name": "profileThickness", "start": 0, @@ -1737,10 +1737,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1317, + "commentStart": 1338, "end": 0, "name": { - "commentStart": 1317, + "commentStart": 1338, "end": 0, "name": "yLine", "start": 0, @@ -1750,7 +1750,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1317, + "commentStart": 1338, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1762,7 +1762,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1359, + "commentStart": 1382, "end": 0, "name": "length", "start": 0, @@ -1770,10 +1770,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1366, + "commentStart": 1391, "end": 0, "name": { - "commentStart": 1366, + "commentStart": 1391, "end": 0, "name": "lowerBeltLengthX", "start": 0, @@ -1788,10 +1788,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1353, + "commentStart": 1376, "end": 0, "name": { - "commentStart": 1353, + "commentStart": 1376, "end": 0, "name": "xLine", "start": 0, @@ -1801,7 +1801,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1353, + "commentStart": 1376, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1813,7 +1813,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1395, + "commentStart": 1420, "end": 0, "name": "length", "start": 0, @@ -1822,10 +1822,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 1403, + "commentStart": 1430, "end": 0, "name": { - "commentStart": 1403, + "commentStart": 1430, "end": 0, "name": "profileThickness", "start": 0, @@ -1836,7 +1836,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 1402, + "commentStart": 1429, "end": 0, "operator": "-", "start": 0, @@ -1847,10 +1847,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1389, + "commentStart": 1414, "end": 0, "name": { - "commentStart": 1389, + "commentStart": 1414, "end": 0, "name": "yLine", "start": 0, @@ -1860,7 +1860,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1389, + "commentStart": 1414, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1872,19 +1872,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1431, + "commentStart": 1458, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1445, + "commentStart": 1472, "elements": [ { "arguments": [ { - "commentStart": 1460, + "commentStart": 1487, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1893,10 +1893,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1446, + "commentStart": 1473, "end": 0, "name": { - "commentStart": 1446, + "commentStart": 1473, "end": 0, "name": "profileStartX", "start": 0, @@ -1906,7 +1906,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1446, + "commentStart": 1473, "end": 0, "start": 0, "type": "CallExpression", @@ -1915,7 +1915,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 1478, + "commentStart": 1505, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1924,10 +1924,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1464, + "commentStart": 1491, "end": 0, "name": { - "commentStart": 1464, + "commentStart": 1491, "end": 0, "name": "profileStartY", "start": 0, @@ -1937,7 +1937,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1464, + "commentStart": 1491, "end": 0, "start": 0, "type": "CallExpression", @@ -1953,10 +1953,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1426, + "commentStart": 1453, "end": 0, "name": { - "commentStart": 1426, + "commentStart": 1453, "end": 0, "name": "line", "start": 0, @@ -1966,7 +1966,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1426, + "commentStart": 1453, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1977,10 +1977,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1488, + "commentStart": 1515, "end": 0, "name": { - "commentStart": 1488, + "commentStart": 1515, "end": 0, "name": "close", "start": 0, @@ -1990,7 +1990,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1488, + "commentStart": 1515, "end": 0, "start": 0, "type": "CallExpression", @@ -2001,17 +2001,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1517, + "commentStart": 1544, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1524, + "commentStart": 1551, "elements": [ { - "commentStart": 1525, + "commentStart": 1552, "end": 0, "raw": "1", "start": 0, @@ -2023,7 +2023,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 1528, + "commentStart": 1555, "end": 0, "raw": "0", "start": 0, @@ -2044,7 +2044,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1532, + "commentStart": 1559, "end": 0, "name": "instances", "start": 0, @@ -2052,10 +2052,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1544, + "commentStart": 1571, "end": 0, "name": { - "commentStart": 1544, + "commentStart": 1571, "end": 0, "name": "blockCount", "start": 0, @@ -2070,7 +2070,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1556, + "commentStart": 1583, "end": 0, "name": "distance", "start": 0, @@ -2078,10 +2078,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1567, + "commentStart": 1594, "end": 0, "name": { - "commentStart": 1567, + "commentStart": 1594, "end": 0, "name": "blockWidth", "start": 0, @@ -2096,10 +2096,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1501, + "commentStart": 1528, "end": 0, "name": { - "commentStart": 1501, + "commentStart": 1528, "end": 0, "name": "patternLinear2d", "start": 0, @@ -2109,7 +2109,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1501, + "commentStart": 1528, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2121,17 +2121,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1600, + "commentStart": 1627, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1607, + "commentStart": 1634, "elements": [ { - "commentStart": 1608, + "commentStart": 1635, "end": 0, "raw": "0", "start": 0, @@ -2143,7 +2143,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 1611, + "commentStart": 1638, "end": 0, "raw": "1", "start": 0, @@ -2164,14 +2164,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1615, + "commentStart": 1642, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1627, + "commentStart": 1654, "end": 0, "raw": "2", "start": 0, @@ -2186,7 +2186,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1630, + "commentStart": 1657, "end": 0, "name": "distance", "start": 0, @@ -2194,10 +2194,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1641, + "commentStart": 1668, "end": 0, "name": { - "commentStart": 1641, + "commentStart": 1668, "end": 0, "name": "blockDepth", "start": 0, @@ -2212,10 +2212,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1584, + "commentStart": 1611, "end": 0, "name": { - "commentStart": 1584, + "commentStart": 1611, "end": 0, "name": "patternLinear2d", "start": 0, @@ -2225,7 +2225,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1584, + "commentStart": 1611, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2237,7 +2237,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1666, + "commentStart": 1693, "end": 0, "name": "length", "start": 0, @@ -2245,10 +2245,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1675, + "commentStart": 1702, "end": 0, "name": { - "commentStart": 1675, + "commentStart": 1702, "end": 0, "name": "profileThickness", "start": 0, @@ -2263,10 +2263,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1658, + "commentStart": 1685, "end": 0, "name": { - "commentStart": 1658, + "commentStart": 1685, "end": 0, "name": "extrude", "start": 0, @@ -2276,7 +2276,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1658, + "commentStart": 1685, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2284,7 +2284,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 1258, + "commentStart": 1279, "end": 0, "start": 0, "type": "PipeExpression", @@ -2300,26 +2300,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1692, + "commentStart": 1719, "declaration": { - "commentStart": 1694, + "commentStart": 1721, "end": 0, "id": { - "commentStart": 1694, + "commentStart": 1721, "end": 0, "name": "lowerBeltLengthY", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 1713, + "commentStart": 1740, "end": 0, "left": { "abs_path": false, - "commentStart": 1713, + "commentStart": 1740, "end": 0, "name": { - "commentStart": 1713, + "commentStart": 1740, "end": 0, "name": "blockDepth", "start": 0, @@ -2333,10 +2333,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1726, + "commentStart": 1753, "end": 0, "name": { - "commentStart": 1726, + "commentStart": 1753, "end": 0, "name": "profileThickness", "start": 0, @@ -2361,12 +2361,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 1743, + "commentStart": 1770, "declaration": { - "commentStart": 1743, + "commentStart": 1770, "end": 0, "id": { - "commentStart": 1743, + "commentStart": 1770, "end": 0, "name": "lowerBeltBodyY", "start": 0, @@ -2377,10 +2377,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 1775, + "commentStart": 1802, "elements": [ { - "commentStart": 1776, + "commentStart": 1803, "end": 0, "raw": "0", "start": 0, @@ -2393,10 +2393,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 1779, + "commentStart": 1806, "end": 0, "name": { - "commentStart": 1779, + "commentStart": 1806, "end": 0, "name": "profileThickness", "start": 0, @@ -2415,10 +2415,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 1798, + "commentStart": 1825, "end": 0, "name": { - "commentStart": 1798, + "commentStart": 1825, "end": 0, "name": "lowerBeltPlane", "start": 0, @@ -2432,10 +2432,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1760, + "commentStart": 1787, "end": 0, "name": { - "commentStart": 1760, + "commentStart": 1787, "end": 0, "name": "startProfileAt", "start": 0, @@ -2445,7 +2445,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1760, + "commentStart": 1787, "end": 0, "start": 0, "type": "CallExpression", @@ -2456,7 +2456,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1825, + "commentStart": 1852, "end": 0, "name": "length", "start": 0, @@ -2464,10 +2464,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1832, + "commentStart": 1861, "end": 0, "name": { - "commentStart": 1832, + "commentStart": 1861, "end": 0, "name": "lowerBeltLengthY", "start": 0, @@ -2482,10 +2482,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1819, + "commentStart": 1846, "end": 0, "name": { - "commentStart": 1819, + "commentStart": 1846, "end": 0, "name": "yLine", "start": 0, @@ -2495,7 +2495,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1819, + "commentStart": 1846, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2507,7 +2507,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1861, + "commentStart": 1890, "end": 0, "name": "length", "start": 0, @@ -2515,10 +2515,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 1868, + "commentStart": 1899, "end": 0, "name": { - "commentStart": 1868, + "commentStart": 1899, "end": 0, "name": "profileThickness", "start": 0, @@ -2533,10 +2533,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1855, + "commentStart": 1884, "end": 0, "name": { - "commentStart": 1855, + "commentStart": 1884, "end": 0, "name": "xLine", "start": 0, @@ -2546,7 +2546,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1855, + "commentStart": 1884, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2558,7 +2558,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1897, + "commentStart": 1928, "end": 0, "name": "length", "start": 0, @@ -2567,10 +2567,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 1905, + "commentStart": 1938, "end": 0, "name": { - "commentStart": 1905, + "commentStart": 1938, "end": 0, "name": "lowerBeltLengthY", "start": 0, @@ -2581,7 +2581,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 1904, + "commentStart": 1937, "end": 0, "operator": "-", "start": 0, @@ -2592,10 +2592,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1891, + "commentStart": 1922, "end": 0, "name": { - "commentStart": 1891, + "commentStart": 1922, "end": 0, "name": "yLine", "start": 0, @@ -2605,7 +2605,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1891, + "commentStart": 1922, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2617,19 +2617,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 1933, + "commentStart": 1966, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1947, + "commentStart": 1980, "elements": [ { "arguments": [ { - "commentStart": 1962, + "commentStart": 1995, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2638,10 +2638,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1948, + "commentStart": 1981, "end": 0, "name": { - "commentStart": 1948, + "commentStart": 1981, "end": 0, "name": "profileStartX", "start": 0, @@ -2651,7 +2651,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1948, + "commentStart": 1981, "end": 0, "start": 0, "type": "CallExpression", @@ -2660,7 +2660,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 1980, + "commentStart": 2013, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2669,10 +2669,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1966, + "commentStart": 1999, "end": 0, "name": { - "commentStart": 1966, + "commentStart": 1999, "end": 0, "name": "profileStartY", "start": 0, @@ -2682,7 +2682,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1966, + "commentStart": 1999, "end": 0, "start": 0, "type": "CallExpression", @@ -2698,10 +2698,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 1928, + "commentStart": 1961, "end": 0, "name": { - "commentStart": 1928, + "commentStart": 1961, "end": 0, "name": "line", "start": 0, @@ -2711,7 +2711,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1928, + "commentStart": 1961, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2722,10 +2722,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1990, + "commentStart": 2023, "end": 0, "name": { - "commentStart": 1990, + "commentStart": 2023, "end": 0, "name": "close", "start": 0, @@ -2735,7 +2735,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 1990, + "commentStart": 2023, "end": 0, "start": 0, "type": "CallExpression", @@ -2746,17 +2746,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2019, + "commentStart": 2052, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2026, + "commentStart": 2059, "elements": [ { - "commentStart": 2027, + "commentStart": 2060, "end": 0, "raw": "1", "start": 0, @@ -2768,7 +2768,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 2030, + "commentStart": 2063, "end": 0, "raw": "0", "start": 0, @@ -2789,14 +2789,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2034, + "commentStart": 2067, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2046, + "commentStart": 2079, "end": 0, "raw": "2", "start": 0, @@ -2811,21 +2811,21 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2049, + "commentStart": 2082, "end": 0, "name": "distance", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2060, + "commentStart": 2093, "end": 0, "left": { "abs_path": false, - "commentStart": 2060, + "commentStart": 2093, "end": 0, "name": { - "commentStart": 2060, + "commentStart": 2093, "end": 0, "name": "tableWidth", "start": 0, @@ -2839,10 +2839,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 2071, + "commentStart": 2106, "end": 0, "name": { - "commentStart": 2071, + "commentStart": 2106, "end": 0, "name": "profileThickness", "start": 0, @@ -2861,10 +2861,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2003, + "commentStart": 2036, "end": 0, "name": { - "commentStart": 2003, + "commentStart": 2036, "end": 0, "name": "patternLinear2d", "start": 0, @@ -2874,7 +2874,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2003, + "commentStart": 2036, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2886,7 +2886,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2102, + "commentStart": 2137, "end": 0, "name": "length", "start": 0, @@ -2894,10 +2894,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2111, + "commentStart": 2146, "end": 0, "name": { - "commentStart": 2111, + "commentStart": 2146, "end": 0, "name": "profileThickness", "start": 0, @@ -2912,10 +2912,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2094, + "commentStart": 2129, "end": 0, "name": { - "commentStart": 2094, + "commentStart": 2129, "end": 0, "name": "extrude", "start": 0, @@ -2925,7 +2925,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2094, + "commentStart": 2129, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2933,13 +2933,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 1760, + "commentStart": 1787, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "7": [ { - "commentStart": 2128, + "commentStart": 2163, "end": 0, "start": 0, "type": "NonCodeNode", @@ -2967,26 +2967,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2141, + "commentStart": 2176, "declaration": { - "commentStart": 2141, + "commentStart": 2176, "end": 0, "id": { - "commentStart": 2141, + "commentStart": 2176, "end": 0, "name": "pillarHeightAboveTheFloor", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 2169, + "commentStart": 2204, "end": 0, "left": { "abs_path": false, - "commentStart": 2169, + "commentStart": 2204, "end": 0, "name": { - "commentStart": 2169, + "commentStart": 2204, "end": 0, "name": "lowerBeltHeightAboveTheFloor", "start": 0, @@ -3000,10 +3000,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2200, + "commentStart": 2235, "end": 0, "name": { - "commentStart": 2200, + "commentStart": 2235, "end": 0, "name": "profileThickness", "start": 0, @@ -3028,12 +3028,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2217, + "commentStart": 2252, "declaration": { - "commentStart": 2217, + "commentStart": 2252, "end": 0, "id": { - "commentStart": 2217, + "commentStart": 2252, "end": 0, "name": "pillarPlane", "start": 0, @@ -3046,7 +3046,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2261, + "commentStart": 2296, "end": 0, "name": "offset", "start": 0, @@ -3054,10 +3054,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2270, + "commentStart": 2305, "end": 0, "name": { - "commentStart": 2270, + "commentStart": 2305, "end": 0, "name": "pillarHeightAboveTheFloor", "start": 0, @@ -3072,10 +3072,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2245, + "commentStart": 2280, "end": 0, "name": { - "commentStart": 2245, + "commentStart": 2280, "end": 0, "name": "offsetPlane", "start": 0, @@ -3085,17 +3085,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2245, + "commentStart": 2280, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 2257, + "commentStart": 2292, "end": 0, "name": { - "commentStart": 2257, + "commentStart": 2292, "end": 0, "name": "XY", "start": 0, @@ -3110,10 +3110,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2231, + "commentStart": 2266, "end": 0, "name": { - "commentStart": 2231, + "commentStart": 2266, "end": 0, "name": "startSketchOn", "start": 0, @@ -3123,7 +3123,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2231, + "commentStart": 2266, "end": 0, "start": 0, "type": "CallExpression", @@ -3139,29 +3139,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2298, + "commentStart": 2333, "declaration": { - "commentStart": 2298, + "commentStart": 2333, "end": 0, "id": { - "commentStart": 2298, + "commentStart": 2333, "end": 0, "name": "pillarTotalHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 2318, + "commentStart": 2353, "end": 0, "left": { - "commentStart": 2318, + "commentStart": 2353, "end": 0, "left": { "abs_path": false, - "commentStart": 2318, + "commentStart": 2353, "end": 0, "name": { - "commentStart": 2318, + "commentStart": 2353, "end": 0, "name": "blockHeight", "start": 0, @@ -3175,10 +3175,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 2332, + "commentStart": 2367, "end": 0, "name": { - "commentStart": 2332, + "commentStart": 2367, "end": 0, "name": "profileThickness", "start": 0, @@ -3196,10 +3196,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 2351, + "commentStart": 2386, "end": 0, "name": { - "commentStart": 2351, + "commentStart": 2386, "end": 0, "name": "pillarHeightAboveTheFloor", "start": 0, @@ -3224,12 +3224,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2376, + "commentStart": 2411, "declaration": { - "commentStart": 2378, + "commentStart": 2413, "end": 0, "id": { - "commentStart": 2378, + "commentStart": 2413, "end": 0, "name": "pillarBody", "start": 0, @@ -3240,14 +3240,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 2406, + "commentStart": 2441, "elements": [ { "abs_path": false, - "commentStart": 2407, + "commentStart": 2442, "end": 0, "name": { - "commentStart": 2407, + "commentStart": 2442, "end": 0, "name": "blockSubdivisionWidth", "start": 0, @@ -3259,7 +3259,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name" }, { - "commentStart": 2430, + "commentStart": 2465, "end": 0, "raw": "0", "start": 0, @@ -3278,10 +3278,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 2434, + "commentStart": 2469, "end": 0, "name": { - "commentStart": 2434, + "commentStart": 2469, "end": 0, "name": "pillarPlane", "start": 0, @@ -3295,10 +3295,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2391, + "commentStart": 2426, "end": 0, "name": { - "commentStart": 2391, + "commentStart": 2426, "end": 0, "name": "startProfileAt", "start": 0, @@ -3308,7 +3308,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2391, + "commentStart": 2426, "end": 0, "start": 0, "type": "CallExpression", @@ -3319,7 +3319,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2458, + "commentStart": 2493, "end": 0, "name": "length", "start": 0, @@ -3327,10 +3327,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2465, + "commentStart": 2502, "end": 0, "name": { - "commentStart": 2465, + "commentStart": 2502, "end": 0, "name": "profileThickness", "start": 0, @@ -3345,10 +3345,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2452, + "commentStart": 2487, "end": 0, "name": { - "commentStart": 2452, + "commentStart": 2487, "end": 0, "name": "yLine", "start": 0, @@ -3358,7 +3358,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2452, + "commentStart": 2487, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3370,7 +3370,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2494, + "commentStart": 2531, "end": 0, "name": "length", "start": 0, @@ -3378,10 +3378,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2501, + "commentStart": 2540, "end": 0, "name": { - "commentStart": 2501, + "commentStart": 2540, "end": 0, "name": "profileThickness", "start": 0, @@ -3396,10 +3396,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2488, + "commentStart": 2525, "end": 0, "name": { - "commentStart": 2488, + "commentStart": 2525, "end": 0, "name": "xLine", "start": 0, @@ -3409,7 +3409,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2488, + "commentStart": 2525, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3421,7 +3421,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2530, + "commentStart": 2569, "end": 0, "name": "length", "start": 0, @@ -3430,10 +3430,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 2538, + "commentStart": 2579, "end": 0, "name": { - "commentStart": 2538, + "commentStart": 2579, "end": 0, "name": "profileThickness", "start": 0, @@ -3444,7 +3444,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 2537, + "commentStart": 2578, "end": 0, "operator": "-", "start": 0, @@ -3455,10 +3455,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2524, + "commentStart": 2563, "end": 0, "name": { - "commentStart": 2524, + "commentStart": 2563, "end": 0, "name": "yLine", "start": 0, @@ -3468,7 +3468,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2524, + "commentStart": 2563, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3480,19 +3480,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2566, + "commentStart": 2607, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2580, + "commentStart": 2621, "elements": [ { "arguments": [ { - "commentStart": 2595, + "commentStart": 2636, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3501,10 +3501,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2581, + "commentStart": 2622, "end": 0, "name": { - "commentStart": 2581, + "commentStart": 2622, "end": 0, "name": "profileStartX", "start": 0, @@ -3514,7 +3514,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2581, + "commentStart": 2622, "end": 0, "start": 0, "type": "CallExpression", @@ -3523,7 +3523,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 2613, + "commentStart": 2654, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3532,10 +3532,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2599, + "commentStart": 2640, "end": 0, "name": { - "commentStart": 2599, + "commentStart": 2640, "end": 0, "name": "profileStartY", "start": 0, @@ -3545,7 +3545,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2599, + "commentStart": 2640, "end": 0, "start": 0, "type": "CallExpression", @@ -3561,10 +3561,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2561, + "commentStart": 2602, "end": 0, "name": { - "commentStart": 2561, + "commentStart": 2602, "end": 0, "name": "line", "start": 0, @@ -3574,7 +3574,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2561, + "commentStart": 2602, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3585,10 +3585,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2623, + "commentStart": 2664, "end": 0, "name": { - "commentStart": 2623, + "commentStart": 2664, "end": 0, "name": "close", "start": 0, @@ -3598,7 +3598,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2623, + "commentStart": 2664, "end": 0, "start": 0, "type": "CallExpression", @@ -3609,17 +3609,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2652, + "commentStart": 2693, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2659, + "commentStart": 2700, "elements": [ { - "commentStart": 2660, + "commentStart": 2701, "end": 0, "raw": "1", "start": 0, @@ -3631,7 +3631,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 2663, + "commentStart": 2704, "end": 0, "raw": "0", "start": 0, @@ -3652,7 +3652,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2667, + "commentStart": 2708, "end": 0, "name": "instances", "start": 0, @@ -3660,10 +3660,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2679, + "commentStart": 2720, "end": 0, "name": { - "commentStart": 2679, + "commentStart": 2720, "end": 0, "name": "blockCount", "start": 0, @@ -3678,7 +3678,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2691, + "commentStart": 2732, "end": 0, "name": "distance", "start": 0, @@ -3686,10 +3686,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2702, + "commentStart": 2743, "end": 0, "name": { - "commentStart": 2702, + "commentStart": 2743, "end": 0, "name": "blockWidth", "start": 0, @@ -3704,10 +3704,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2636, + "commentStart": 2677, "end": 0, "name": { - "commentStart": 2636, + "commentStart": 2677, "end": 0, "name": "patternLinear2d", "start": 0, @@ -3717,7 +3717,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2636, + "commentStart": 2677, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3729,17 +3729,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2735, + "commentStart": 2776, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2742, + "commentStart": 2783, "elements": [ { - "commentStart": 2743, + "commentStart": 2784, "end": 0, "raw": "0", "start": 0, @@ -3751,7 +3751,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 2746, + "commentStart": 2787, "end": 0, "raw": "1", "start": 0, @@ -3772,14 +3772,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2750, + "commentStart": 2791, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2762, + "commentStart": 2803, "end": 0, "raw": "2", "start": 0, @@ -3794,7 +3794,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2765, + "commentStart": 2806, "end": 0, "name": "distance", "start": 0, @@ -3802,10 +3802,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2776, + "commentStart": 2817, "end": 0, "name": { - "commentStart": 2776, + "commentStart": 2817, "end": 0, "name": "blockDepth", "start": 0, @@ -3820,10 +3820,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2719, + "commentStart": 2760, "end": 0, "name": { - "commentStart": 2719, + "commentStart": 2760, "end": 0, "name": "patternLinear2d", "start": 0, @@ -3833,7 +3833,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2719, + "commentStart": 2760, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3845,7 +3845,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2801, + "commentStart": 2842, "end": 0, "name": "length", "start": 0, @@ -3853,10 +3853,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2810, + "commentStart": 2851, "end": 0, "name": { - "commentStart": 2810, + "commentStart": 2851, "end": 0, "name": "pillarTotalHeight", "start": 0, @@ -3871,10 +3871,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2793, + "commentStart": 2834, "end": 0, "name": { - "commentStart": 2793, + "commentStart": 2834, "end": 0, "name": "extrude", "start": 0, @@ -3884,7 +3884,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2793, + "commentStart": 2834, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3892,13 +3892,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 2391, + "commentStart": 2426, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "8": [ { - "commentStart": 2828, + "commentStart": 2869, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3926,12 +3926,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2844, + "commentStart": 2885, "declaration": { - "commentStart": 2844, + "commentStart": 2885, "end": 0, "id": { - "commentStart": 2844, + "commentStart": 2885, "end": 0, "name": "upperBeltPlane", "start": 0, @@ -3944,7 +3944,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2891, + "commentStart": 2932, "end": 0, "name": "offset", "start": 0, @@ -3952,10 +3952,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2900, + "commentStart": 2941, "end": 0, "name": { - "commentStart": 2900, + "commentStart": 2941, "end": 0, "name": "blockHeight", "start": 0, @@ -3970,10 +3970,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2875, + "commentStart": 2916, "end": 0, "name": { - "commentStart": 2875, + "commentStart": 2916, "end": 0, "name": "offsetPlane", "start": 0, @@ -3983,17 +3983,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2875, + "commentStart": 2916, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 2887, + "commentStart": 2928, "end": 0, "name": { - "commentStart": 2887, + "commentStart": 2928, "end": 0, "name": "XY", "start": 0, @@ -4008,10 +4008,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2861, + "commentStart": 2902, "end": 0, "name": { - "commentStart": 2861, + "commentStart": 2902, "end": 0, "name": "startSketchOn", "start": 0, @@ -4021,7 +4021,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2861, + "commentStart": 2902, "end": 0, "start": 0, "type": "CallExpression", @@ -4037,12 +4037,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 2913, + "commentStart": 2954, "declaration": { - "commentStart": 2915, + "commentStart": 2956, "end": 0, "id": { - "commentStart": 2915, + "commentStart": 2956, "end": 0, "name": "upperBeltBodyX", "start": 0, @@ -4053,10 +4053,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 2947, + "commentStart": 2988, "elements": [ { - "commentStart": 2948, + "commentStart": 2989, "end": 0, "raw": "0", "start": 0, @@ -4068,7 +4068,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 2951, + "commentStart": 2992, "end": 0, "raw": "0", "start": 0, @@ -4087,10 +4087,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 2955, + "commentStart": 2996, "end": 0, "name": { - "commentStart": 2955, + "commentStart": 2996, "end": 0, "name": "upperBeltPlane", "start": 0, @@ -4104,10 +4104,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2932, + "commentStart": 2973, "end": 0, "name": { - "commentStart": 2932, + "commentStart": 2973, "end": 0, "name": "startProfileAt", "start": 0, @@ -4117,7 +4117,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2932, + "commentStart": 2973, "end": 0, "start": 0, "type": "CallExpression", @@ -4128,7 +4128,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 2982, + "commentStart": 3023, "end": 0, "name": "length", "start": 0, @@ -4136,10 +4136,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 2989, + "commentStart": 3032, "end": 0, "name": { - "commentStart": 2989, + "commentStart": 3032, "end": 0, "name": "profileThickness", "start": 0, @@ -4154,10 +4154,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 2976, + "commentStart": 3017, "end": 0, "name": { - "commentStart": 2976, + "commentStart": 3017, "end": 0, "name": "yLine", "start": 0, @@ -4167,7 +4167,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 2976, + "commentStart": 3017, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4179,7 +4179,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3018, + "commentStart": 3061, "end": 0, "name": "length", "start": 0, @@ -4187,10 +4187,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3025, + "commentStart": 3070, "end": 0, "name": { - "commentStart": 3025, + "commentStart": 3070, "end": 0, "name": "tableWidth", "start": 0, @@ -4205,10 +4205,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3012, + "commentStart": 3055, "end": 0, "name": { - "commentStart": 3012, + "commentStart": 3055, "end": 0, "name": "xLine", "start": 0, @@ -4218,7 +4218,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3012, + "commentStart": 3055, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4230,7 +4230,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3048, + "commentStart": 3093, "end": 0, "name": "length", "start": 0, @@ -4239,10 +4239,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 3056, + "commentStart": 3103, "end": 0, "name": { - "commentStart": 3056, + "commentStart": 3103, "end": 0, "name": "profileThickness", "start": 0, @@ -4253,7 +4253,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 3055, + "commentStart": 3102, "end": 0, "operator": "-", "start": 0, @@ -4264,10 +4264,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3042, + "commentStart": 3087, "end": 0, "name": { - "commentStart": 3042, + "commentStart": 3087, "end": 0, "name": "yLine", "start": 0, @@ -4277,7 +4277,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3042, + "commentStart": 3087, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4289,19 +4289,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3084, + "commentStart": 3131, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3098, + "commentStart": 3145, "elements": [ { "arguments": [ { - "commentStart": 3113, + "commentStart": 3160, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4310,10 +4310,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3099, + "commentStart": 3146, "end": 0, "name": { - "commentStart": 3099, + "commentStart": 3146, "end": 0, "name": "profileStartX", "start": 0, @@ -4323,7 +4323,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3099, + "commentStart": 3146, "end": 0, "start": 0, "type": "CallExpression", @@ -4332,7 +4332,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 3131, + "commentStart": 3178, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4341,10 +4341,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3117, + "commentStart": 3164, "end": 0, "name": { - "commentStart": 3117, + "commentStart": 3164, "end": 0, "name": "profileStartY", "start": 0, @@ -4354,7 +4354,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3117, + "commentStart": 3164, "end": 0, "start": 0, "type": "CallExpression", @@ -4370,10 +4370,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3079, + "commentStart": 3126, "end": 0, "name": { - "commentStart": 3079, + "commentStart": 3126, "end": 0, "name": "line", "start": 0, @@ -4383,7 +4383,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3079, + "commentStart": 3126, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4394,10 +4394,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 3141, + "commentStart": 3188, "end": 0, "name": { - "commentStart": 3141, + "commentStart": 3188, "end": 0, "name": "close", "start": 0, @@ -4407,7 +4407,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3141, + "commentStart": 3188, "end": 0, "start": 0, "type": "CallExpression", @@ -4418,17 +4418,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3170, + "commentStart": 3217, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3177, + "commentStart": 3224, "elements": [ { - "commentStart": 3178, + "commentStart": 3225, "end": 0, "raw": "0", "start": 0, @@ -4440,7 +4440,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 3181, + "commentStart": 3228, "end": 0, "raw": "1", "start": 0, @@ -4461,14 +4461,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3185, + "commentStart": 3232, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3197, + "commentStart": 3244, "end": 0, "raw": "2", "start": 0, @@ -4483,7 +4483,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3200, + "commentStart": 3247, "end": 0, "name": "distance", "start": 0, @@ -4491,10 +4491,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3211, + "commentStart": 3258, "end": 0, "name": { - "commentStart": 3211, + "commentStart": 3258, "end": 0, "name": "blockDepth", "start": 0, @@ -4509,10 +4509,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3154, + "commentStart": 3201, "end": 0, "name": { - "commentStart": 3154, + "commentStart": 3201, "end": 0, "name": "patternLinear2d", "start": 0, @@ -4522,7 +4522,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3154, + "commentStart": 3201, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4534,7 +4534,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3236, + "commentStart": 3283, "end": 0, "name": "length", "start": 0, @@ -4543,10 +4543,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 3246, + "commentStart": 3293, "end": 0, "name": { - "commentStart": 3246, + "commentStart": 3293, "end": 0, "name": "profileThickness", "start": 0, @@ -4557,7 +4557,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 3245, + "commentStart": 3292, "end": 0, "operator": "-", "start": 0, @@ -4568,10 +4568,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3228, + "commentStart": 3275, "end": 0, "name": { - "commentStart": 3228, + "commentStart": 3275, "end": 0, "name": "extrude", "start": 0, @@ -4581,7 +4581,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3228, + "commentStart": 3275, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4589,7 +4589,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 2932, + "commentStart": 2973, "end": 0, "start": 0, "type": "PipeExpression", @@ -4605,26 +4605,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 3263, + "commentStart": 3310, "declaration": { - "commentStart": 3265, + "commentStart": 3312, "end": 0, "id": { - "commentStart": 3265, + "commentStart": 3312, "end": 0, "name": "upperBeltLengthY", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 3284, + "commentStart": 3331, "end": 0, "left": { "abs_path": false, - "commentStart": 3284, + "commentStart": 3331, "end": 0, "name": { - "commentStart": 3284, + "commentStart": 3331, "end": 0, "name": "blockDepth", "start": 0, @@ -4638,10 +4638,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 3297, + "commentStart": 3344, "end": 0, "name": { - "commentStart": 3297, + "commentStart": 3344, "end": 0, "name": "profileThickness", "start": 0, @@ -4666,12 +4666,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 3314, + "commentStart": 3361, "declaration": { - "commentStart": 3314, + "commentStart": 3361, "end": 0, "id": { - "commentStart": 3314, + "commentStart": 3361, "end": 0, "name": "upperBeltBodyY", "start": 0, @@ -4682,10 +4682,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 3346, + "commentStart": 3393, "elements": [ { - "commentStart": 3347, + "commentStart": 3394, "end": 0, "raw": "0", "start": 0, @@ -4698,10 +4698,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 3350, + "commentStart": 3397, "end": 0, "name": { - "commentStart": 3350, + "commentStart": 3397, "end": 0, "name": "profileThickness", "start": 0, @@ -4720,10 +4720,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 3369, + "commentStart": 3416, "end": 0, "name": { - "commentStart": 3369, + "commentStart": 3416, "end": 0, "name": "upperBeltPlane", "start": 0, @@ -4737,10 +4737,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3331, + "commentStart": 3378, "end": 0, "name": { - "commentStart": 3331, + "commentStart": 3378, "end": 0, "name": "startProfileAt", "start": 0, @@ -4750,7 +4750,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3331, + "commentStart": 3378, "end": 0, "start": 0, "type": "CallExpression", @@ -4761,7 +4761,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3396, + "commentStart": 3443, "end": 0, "name": "length", "start": 0, @@ -4769,10 +4769,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3403, + "commentStart": 3452, "end": 0, "name": { - "commentStart": 3403, + "commentStart": 3452, "end": 0, "name": "upperBeltLengthY", "start": 0, @@ -4787,10 +4787,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3390, + "commentStart": 3437, "end": 0, "name": { - "commentStart": 3390, + "commentStart": 3437, "end": 0, "name": "yLine", "start": 0, @@ -4800,7 +4800,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3390, + "commentStart": 3437, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4812,7 +4812,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3432, + "commentStart": 3481, "end": 0, "name": "length", "start": 0, @@ -4820,10 +4820,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3439, + "commentStart": 3490, "end": 0, "name": { - "commentStart": 3439, + "commentStart": 3490, "end": 0, "name": "profileThickness", "start": 0, @@ -4838,10 +4838,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3426, + "commentStart": 3475, "end": 0, "name": { - "commentStart": 3426, + "commentStart": 3475, "end": 0, "name": "xLine", "start": 0, @@ -4851,7 +4851,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3426, + "commentStart": 3475, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4863,7 +4863,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3468, + "commentStart": 3519, "end": 0, "name": "length", "start": 0, @@ -4872,10 +4872,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 3476, + "commentStart": 3529, "end": 0, "name": { - "commentStart": 3476, + "commentStart": 3529, "end": 0, "name": "upperBeltLengthY", "start": 0, @@ -4886,7 +4886,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 3475, + "commentStart": 3528, "end": 0, "operator": "-", "start": 0, @@ -4897,10 +4897,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3462, + "commentStart": 3513, "end": 0, "name": { - "commentStart": 3462, + "commentStart": 3513, "end": 0, "name": "yLine", "start": 0, @@ -4910,7 +4910,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3462, + "commentStart": 3513, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4922,19 +4922,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3504, + "commentStart": 3557, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3518, + "commentStart": 3571, "elements": [ { "arguments": [ { - "commentStart": 3533, + "commentStart": 3586, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4943,10 +4943,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3519, + "commentStart": 3572, "end": 0, "name": { - "commentStart": 3519, + "commentStart": 3572, "end": 0, "name": "profileStartX", "start": 0, @@ -4956,7 +4956,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3519, + "commentStart": 3572, "end": 0, "start": 0, "type": "CallExpression", @@ -4965,7 +4965,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 3551, + "commentStart": 3604, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4974,10 +4974,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3537, + "commentStart": 3590, "end": 0, "name": { - "commentStart": 3537, + "commentStart": 3590, "end": 0, "name": "profileStartY", "start": 0, @@ -4987,7 +4987,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3537, + "commentStart": 3590, "end": 0, "start": 0, "type": "CallExpression", @@ -5003,10 +5003,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3499, + "commentStart": 3552, "end": 0, "name": { - "commentStart": 3499, + "commentStart": 3552, "end": 0, "name": "line", "start": 0, @@ -5016,7 +5016,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3499, + "commentStart": 3552, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5027,10 +5027,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 3561, + "commentStart": 3614, "end": 0, "name": { - "commentStart": 3561, + "commentStart": 3614, "end": 0, "name": "close", "start": 0, @@ -5040,7 +5040,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3561, + "commentStart": 3614, "end": 0, "start": 0, "type": "CallExpression", @@ -5051,17 +5051,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3590, + "commentStart": 3643, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3597, + "commentStart": 3650, "elements": [ { - "commentStart": 3598, + "commentStart": 3651, "end": 0, "raw": "1", "start": 0, @@ -5073,7 +5073,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 3601, + "commentStart": 3654, "end": 0, "raw": "0", "start": 0, @@ -5094,14 +5094,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3605, + "commentStart": 3658, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3617, + "commentStart": 3670, "end": 0, "raw": "2", "start": 0, @@ -5116,21 +5116,21 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3620, + "commentStart": 3673, "end": 0, "name": "distance", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3631, + "commentStart": 3684, "end": 0, "left": { "abs_path": false, - "commentStart": 3631, + "commentStart": 3684, "end": 0, "name": { - "commentStart": 3631, + "commentStart": 3684, "end": 0, "name": "tableWidth", "start": 0, @@ -5144,10 +5144,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 3642, + "commentStart": 3697, "end": 0, "name": { - "commentStart": 3642, + "commentStart": 3697, "end": 0, "name": "profileThickness", "start": 0, @@ -5166,10 +5166,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3574, + "commentStart": 3627, "end": 0, "name": { - "commentStart": 3574, + "commentStart": 3627, "end": 0, "name": "patternLinear2d", "start": 0, @@ -5179,7 +5179,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3574, + "commentStart": 3627, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5191,7 +5191,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3673, + "commentStart": 3728, "end": 0, "name": "length", "start": 0, @@ -5200,10 +5200,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 3683, + "commentStart": 3738, "end": 0, "name": { - "commentStart": 3683, + "commentStart": 3738, "end": 0, "name": "profileThickness", "start": 0, @@ -5214,7 +5214,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 3682, + "commentStart": 3737, "end": 0, "operator": "-", "start": 0, @@ -5225,10 +5225,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3665, + "commentStart": 3720, "end": 0, "name": { - "commentStart": 3665, + "commentStart": 3720, "end": 0, "name": "extrude", "start": 0, @@ -5238,7 +5238,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3665, + "commentStart": 3720, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5246,13 +5246,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 3331, + "commentStart": 3378, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "7": [ { - "commentStart": 3700, + "commentStart": 3755, "end": 0, "start": 0, "type": "NonCodeNode", @@ -5280,12 +5280,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 3710, + "commentStart": 3765, "declaration": { - "commentStart": 3710, + "commentStart": 3765, "end": 0, "id": { - "commentStart": 3710, + "commentStart": 3765, "end": 0, "name": "tableTopPlane", "start": 0, @@ -5298,7 +5298,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3756, + "commentStart": 3811, "end": 0, "name": "offset", "start": 0, @@ -5306,10 +5306,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3765, + "commentStart": 3820, "end": 0, "name": { - "commentStart": 3765, + "commentStart": 3820, "end": 0, "name": "tableHeight", "start": 0, @@ -5324,10 +5324,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3740, + "commentStart": 3795, "end": 0, "name": { - "commentStart": 3740, + "commentStart": 3795, "end": 0, "name": "offsetPlane", "start": 0, @@ -5337,17 +5337,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3740, + "commentStart": 3795, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 3752, + "commentStart": 3807, "end": 0, "name": { - "commentStart": 3752, + "commentStart": 3807, "end": 0, "name": "XY", "start": 0, @@ -5362,10 +5362,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3726, + "commentStart": 3781, "end": 0, "name": { - "commentStart": 3726, + "commentStart": 3781, "end": 0, "name": "startSketchOn", "start": 0, @@ -5375,7 +5375,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3726, + "commentStart": 3781, "end": 0, "start": 0, "type": "CallExpression", @@ -5391,12 +5391,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 3779, + "commentStart": 3834, "declaration": { - "commentStart": 3779, + "commentStart": 3834, "end": 0, "id": { - "commentStart": 3779, + "commentStart": 3834, "end": 0, "name": "tableTopBody", "start": 0, @@ -5407,10 +5407,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 3809, + "commentStart": 3864, "elements": [ { - "commentStart": 3810, + "commentStart": 3865, "end": 0, "raw": "0", "start": 0, @@ -5422,7 +5422,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 3813, + "commentStart": 3868, "end": 0, "raw": "0", "start": 0, @@ -5441,10 +5441,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 3817, + "commentStart": 3872, "end": 0, "name": { - "commentStart": 3817, + "commentStart": 3872, "end": 0, "name": "tableTopPlane", "start": 0, @@ -5458,10 +5458,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3794, + "commentStart": 3849, "end": 0, "name": { - "commentStart": 3794, + "commentStart": 3849, "end": 0, "name": "startProfileAt", "start": 0, @@ -5471,7 +5471,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3794, + "commentStart": 3849, "end": 0, "start": 0, "type": "CallExpression", @@ -5482,7 +5482,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3843, + "commentStart": 3898, "end": 0, "name": "length", "start": 0, @@ -5490,10 +5490,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3850, + "commentStart": 3907, "end": 0, "name": { - "commentStart": 3850, + "commentStart": 3907, "end": 0, "name": "tableDepth", "start": 0, @@ -5508,10 +5508,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3837, + "commentStart": 3892, "end": 0, "name": { - "commentStart": 3837, + "commentStart": 3892, "end": 0, "name": "yLine", "start": 0, @@ -5521,7 +5521,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3837, + "commentStart": 3892, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5533,7 +5533,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3873, + "commentStart": 3930, "end": 0, "name": "length", "start": 0, @@ -5541,10 +5541,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 3880, + "commentStart": 3939, "end": 0, "name": { - "commentStart": 3880, + "commentStart": 3939, "end": 0, "name": "tableWidth", "start": 0, @@ -5559,10 +5559,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3867, + "commentStart": 3924, "end": 0, "name": { - "commentStart": 3867, + "commentStart": 3924, "end": 0, "name": "xLine", "start": 0, @@ -5572,7 +5572,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3867, + "commentStart": 3924, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5584,7 +5584,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3903, + "commentStart": 3962, "end": 0, "name": "length", "start": 0, @@ -5593,10 +5593,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 3911, + "commentStart": 3972, "end": 0, "name": { - "commentStart": 3911, + "commentStart": 3972, "end": 0, "name": "tableDepth", "start": 0, @@ -5607,7 +5607,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 3910, + "commentStart": 3971, "end": 0, "operator": "-", "start": 0, @@ -5618,10 +5618,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3897, + "commentStart": 3956, "end": 0, "name": { - "commentStart": 3897, + "commentStart": 3956, "end": 0, "name": "yLine", "start": 0, @@ -5631,7 +5631,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3897, + "commentStart": 3956, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5643,19 +5643,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 3933, + "commentStart": 3994, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3947, + "commentStart": 4008, "elements": [ { "arguments": [ { - "commentStart": 3962, + "commentStart": 4023, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -5664,10 +5664,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3948, + "commentStart": 4009, "end": 0, "name": { - "commentStart": 3948, + "commentStart": 4009, "end": 0, "name": "profileStartX", "start": 0, @@ -5677,7 +5677,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3948, + "commentStart": 4009, "end": 0, "start": 0, "type": "CallExpression", @@ -5686,7 +5686,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 3980, + "commentStart": 4041, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -5695,10 +5695,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3966, + "commentStart": 4027, "end": 0, "name": { - "commentStart": 3966, + "commentStart": 4027, "end": 0, "name": "profileStartY", "start": 0, @@ -5708,7 +5708,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3966, + "commentStart": 4027, "end": 0, "start": 0, "type": "CallExpression", @@ -5724,10 +5724,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 3928, + "commentStart": 3989, "end": 0, "name": { - "commentStart": 3928, + "commentStart": 3989, "end": 0, "name": "line", "start": 0, @@ -5737,7 +5737,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3928, + "commentStart": 3989, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5748,10 +5748,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 3990, + "commentStart": 4051, "end": 0, "name": { - "commentStart": 3990, + "commentStart": 4051, "end": 0, "name": "close", "start": 0, @@ -5761,7 +5761,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 3990, + "commentStart": 4051, "end": 0, "start": 0, "type": "CallExpression", @@ -5772,7 +5772,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4011, + "commentStart": 4072, "end": 0, "name": "length", "start": 0, @@ -5781,10 +5781,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 4021, + "commentStart": 4082, "end": 0, "name": { - "commentStart": 4021, + "commentStart": 4082, "end": 0, "name": "metalThickness", "start": 0, @@ -5795,7 +5795,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 4020, + "commentStart": 4081, "end": 0, "operator": "-", "start": 0, @@ -5806,10 +5806,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4003, + "commentStart": 4064, "end": 0, "name": { - "commentStart": 4003, + "commentStart": 4064, "end": 0, "name": "extrude", "start": 0, @@ -5819,7 +5819,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4003, + "commentStart": 4064, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -5827,7 +5827,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 3794, + "commentStart": 3849, "end": 0, "start": 0, "type": "PipeExpression", @@ -5843,19 +5843,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4036, + "commentStart": 4097, "declaration": { - "commentStart": 4038, + "commentStart": 4099, "end": 0, "id": { - "commentStart": 4038, + "commentStart": 4099, "end": 0, "name": "sinkCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4050, + "commentStart": 4111, "end": 0, "raw": "2", "start": 0, @@ -5876,19 +5876,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4052, + "commentStart": 4113, "declaration": { - "commentStart": 4052, + "commentStart": 4113, "end": 0, "id": { - "commentStart": 4052, + "commentStart": 4113, "end": 0, "name": "sinkWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4064, + "commentStart": 4125, "end": 0, "raw": "1000", "start": 0, @@ -5909,19 +5909,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4069, + "commentStart": 4130, "declaration": { - "commentStart": 4069, + "commentStart": 4130, "end": 0, "id": { - "commentStart": 4069, + "commentStart": 4130, "end": 0, "name": "sinkLength", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4082, + "commentStart": 4143, "end": 0, "raw": "250", "start": 0, @@ -5942,19 +5942,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4086, + "commentStart": 4147, "declaration": { - "commentStart": 4086, + "commentStart": 4147, "end": 0, "id": { - "commentStart": 4086, + "commentStart": 4147, "end": 0, "name": "sinkDepth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4098, + "commentStart": 4159, "end": 0, "raw": "200", "start": 0, @@ -5975,19 +5975,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4102, + "commentStart": 4163, "declaration": { - "commentStart": 4102, + "commentStart": 4163, "end": 0, "id": { - "commentStart": 4102, + "commentStart": 4163, "end": 0, "name": "sinkOffsetFront", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4120, + "commentStart": 4181, "end": 0, "raw": "40", "start": 0, @@ -6008,19 +6008,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4123, + "commentStart": 4184, "declaration": { - "commentStart": 4123, + "commentStart": 4184, "end": 0, "id": { - "commentStart": 4123, + "commentStart": 4184, "end": 0, "name": "sinkOffsetLeft", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4140, + "commentStart": 4201, "end": 0, "raw": "350", "start": 0, @@ -6041,29 +6041,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4144, + "commentStart": 4205, "declaration": { - "commentStart": 4144, + "commentStart": 4205, "end": 0, "id": { - "commentStart": 4144, + "commentStart": 4205, "end": 0, "name": "sinkSpacing", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 4158, + "commentStart": 4219, "end": 0, "left": { - "commentStart": 4158, + "commentStart": 4219, "end": 0, "left": { "abs_path": false, - "commentStart": 4158, + "commentStart": 4219, "end": 0, "name": { - "commentStart": 4158, + "commentStart": 4219, "end": 0, "name": "tableWidth", "start": 0, @@ -6077,10 +6077,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 4171, + "commentStart": 4232, "end": 0, "name": { - "commentStart": 4171, + "commentStart": 4232, "end": 0, "name": "sinkWidth", "start": 0, @@ -6097,14 +6097,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 4183, + "commentStart": 4245, "end": 0, "left": { "abs_path": false, - "commentStart": 4183, + "commentStart": 4245, "end": 0, "name": { - "commentStart": 4183, + "commentStart": 4245, "end": 0, "name": "sinkOffsetLeft", "start": 0, @@ -6117,7 +6117,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 4198, + "commentStart": 4262, "end": 0, "raw": "2", "start": 0, @@ -6146,12 +6146,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4199, + "commentStart": 4264, "declaration": { - "commentStart": 4201, + "commentStart": 4266, "end": 0, "id": { - "commentStart": 4201, + "commentStart": 4266, "end": 0, "name": "sinkPlaneOutside", "start": 0, @@ -6161,10 +6161,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [ { "abs_path": false, - "commentStart": 4234, + "commentStart": 4299, "end": 0, "name": { - "commentStart": 4234, + "commentStart": 4299, "end": 0, "name": "tableTopBody", "start": 0, @@ -6176,7 +6176,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name" }, { - "commentStart": 4248, + "commentStart": 4313, "end": 0, "raw": "'START'", "start": 0, @@ -6187,10 +6187,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4220, + "commentStart": 4285, "end": 0, "name": { - "commentStart": 4220, + "commentStart": 4285, "end": 0, "name": "startSketchOn", "start": 0, @@ -6200,7 +6200,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4220, + "commentStart": 4285, "end": 0, "start": 0, "type": "CallExpression", @@ -6216,12 +6216,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4257, + "commentStart": 4322, "declaration": { - "commentStart": 4257, + "commentStart": 4322, "end": 0, "id": { - "commentStart": 4257, + "commentStart": 4322, "end": 0, "name": "sinkBodyOutside", "start": 0, @@ -6232,15 +6232,15 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 4290, + "commentStart": 4355, "elements": [ { "argument": { "abs_path": false, - "commentStart": 4292, + "commentStart": 4357, "end": 0, "name": { - "commentStart": 4292, + "commentStart": 4357, "end": 0, "name": "sinkOffsetLeft", "start": 0, @@ -6251,7 +6251,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 4291, + "commentStart": 4356, "end": 0, "operator": "-", "start": 0, @@ -6260,10 +6260,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 4308, + "commentStart": 4373, "end": 0, "name": { - "commentStart": 4308, + "commentStart": 4373, "end": 0, "name": "sinkOffsetFront", "start": 0, @@ -6282,10 +6282,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 4326, + "commentStart": 4391, "end": 0, "name": { - "commentStart": 4326, + "commentStart": 4391, "end": 0, "name": "sinkPlaneOutside", "start": 0, @@ -6299,10 +6299,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4275, + "commentStart": 4340, "end": 0, "name": { - "commentStart": 4275, + "commentStart": 4340, "end": 0, "name": "startProfileAt", "start": 0, @@ -6312,7 +6312,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4275, + "commentStart": 4340, "end": 0, "start": 0, "type": "CallExpression", @@ -6323,7 +6323,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4355, + "commentStart": 4420, "end": 0, "name": "length", "start": 0, @@ -6331,10 +6331,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 4362, + "commentStart": 4429, "end": 0, "name": { - "commentStart": 4362, + "commentStart": 4429, "end": 0, "name": "sinkLength", "start": 0, @@ -6349,10 +6349,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4349, + "commentStart": 4414, "end": 0, "name": { - "commentStart": 4349, + "commentStart": 4414, "end": 0, "name": "yLine", "start": 0, @@ -6362,7 +6362,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4349, + "commentStart": 4414, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6374,7 +6374,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4385, + "commentStart": 4452, "end": 0, "name": "length", "start": 0, @@ -6383,10 +6383,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 4393, + "commentStart": 4462, "end": 0, "name": { - "commentStart": 4393, + "commentStart": 4462, "end": 0, "name": "sinkWidth", "start": 0, @@ -6397,7 +6397,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 4392, + "commentStart": 4461, "end": 0, "operator": "-", "start": 0, @@ -6408,10 +6408,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4379, + "commentStart": 4446, "end": 0, "name": { - "commentStart": 4379, + "commentStart": 4446, "end": 0, "name": "xLine", "start": 0, @@ -6421,7 +6421,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4379, + "commentStart": 4446, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6433,7 +6433,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4415, + "commentStart": 4484, "end": 0, "name": "length", "start": 0, @@ -6442,10 +6442,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 4423, + "commentStart": 4494, "end": 0, "name": { - "commentStart": 4423, + "commentStart": 4494, "end": 0, "name": "sinkLength", "start": 0, @@ -6456,7 +6456,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 4422, + "commentStart": 4493, "end": 0, "operator": "-", "start": 0, @@ -6467,10 +6467,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4409, + "commentStart": 4478, "end": 0, "name": { - "commentStart": 4409, + "commentStart": 4478, "end": 0, "name": "yLine", "start": 0, @@ -6480,7 +6480,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4409, + "commentStart": 4478, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6492,19 +6492,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4445, + "commentStart": 4516, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4459, + "commentStart": 4530, "elements": [ { "arguments": [ { - "commentStart": 4474, + "commentStart": 4545, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -6513,10 +6513,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4460, + "commentStart": 4531, "end": 0, "name": { - "commentStart": 4460, + "commentStart": 4531, "end": 0, "name": "profileStartX", "start": 0, @@ -6526,7 +6526,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4460, + "commentStart": 4531, "end": 0, "start": 0, "type": "CallExpression", @@ -6535,7 +6535,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 4492, + "commentStart": 4563, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -6544,10 +6544,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4478, + "commentStart": 4549, "end": 0, "name": { - "commentStart": 4478, + "commentStart": 4549, "end": 0, "name": "profileStartY", "start": 0, @@ -6557,7 +6557,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4478, + "commentStart": 4549, "end": 0, "start": 0, "type": "CallExpression", @@ -6573,10 +6573,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4440, + "commentStart": 4511, "end": 0, "name": { - "commentStart": 4440, + "commentStart": 4511, "end": 0, "name": "line", "start": 0, @@ -6586,7 +6586,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4440, + "commentStart": 4511, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6597,10 +6597,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 4502, + "commentStart": 4573, "end": 0, "name": { - "commentStart": 4502, + "commentStart": 4573, "end": 0, "name": "close", "start": 0, @@ -6610,7 +6610,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4502, + "commentStart": 4573, "end": 0, "start": 0, "type": "CallExpression", @@ -6621,18 +6621,18 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4531, + "commentStart": 4602, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4538, + "commentStart": 4609, "elements": [ { "argument": { - "commentStart": 4540, + "commentStart": 4611, "end": 0, "raw": "1", "start": 0, @@ -6643,7 +6643,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "suffix": "None" } }, - "commentStart": 4539, + "commentStart": 4610, "end": 0, "operator": "-", "start": 0, @@ -6651,7 +6651,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "UnaryExpression" }, { - "commentStart": 4543, + "commentStart": 4614, "end": 0, "raw": "0", "start": 0, @@ -6672,7 +6672,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4547, + "commentStart": 4618, "end": 0, "name": "instances", "start": 0, @@ -6680,10 +6680,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 4559, + "commentStart": 4630, "end": 0, "name": { - "commentStart": 4559, + "commentStart": 4630, "end": 0, "name": "sinkCount", "start": 0, @@ -6698,7 +6698,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4570, + "commentStart": 4641, "end": 0, "name": "distance", "start": 0, @@ -6706,10 +6706,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 4581, + "commentStart": 4652, "end": 0, "name": { - "commentStart": 4581, + "commentStart": 4652, "end": 0, "name": "sinkSpacing", "start": 0, @@ -6724,10 +6724,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4515, + "commentStart": 4586, "end": 0, "name": { - "commentStart": 4515, + "commentStart": 4586, "end": 0, "name": "patternLinear2d", "start": 0, @@ -6737,7 +6737,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4515, + "commentStart": 4586, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6749,7 +6749,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4607, + "commentStart": 4678, "end": 0, "name": "length", "start": 0, @@ -6757,10 +6757,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 4616, + "commentStart": 4687, "end": 0, "name": { - "commentStart": 4616, + "commentStart": 4687, "end": 0, "name": "sinkDepth", "start": 0, @@ -6775,10 +6775,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4599, + "commentStart": 4670, "end": 0, "name": { - "commentStart": 4599, + "commentStart": 4670, "end": 0, "name": "extrude", "start": 0, @@ -6788,7 +6788,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4599, + "commentStart": 4670, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -6796,7 +6796,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 4275, + "commentStart": 4340, "end": 0, "start": 0, "type": "PipeExpression", @@ -6812,12 +6812,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4626, + "commentStart": 4697, "declaration": { - "commentStart": 4628, + "commentStart": 4699, "end": 0, "id": { - "commentStart": 4628, + "commentStart": 4699, "end": 0, "name": "sinkPlaneInside", "start": 0, @@ -6827,10 +6827,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [ { "abs_path": false, - "commentStart": 4660, + "commentStart": 4731, "end": 0, "name": { - "commentStart": 4660, + "commentStart": 4731, "end": 0, "name": "tableTopBody", "start": 0, @@ -6842,7 +6842,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name" }, { - "commentStart": 4674, + "commentStart": 4745, "end": 0, "raw": "'END'", "start": 0, @@ -6853,10 +6853,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4646, + "commentStart": 4717, "end": 0, "name": { - "commentStart": 4646, + "commentStart": 4717, "end": 0, "name": "startSketchOn", "start": 0, @@ -6866,7 +6866,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4646, + "commentStart": 4717, "end": 0, "start": 0, "type": "CallExpression", @@ -6882,12 +6882,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 4681, + "commentStart": 4752, "declaration": { - "commentStart": 4681, + "commentStart": 4752, "end": 0, "id": { - "commentStart": 4681, + "commentStart": 4752, "end": 0, "name": "sinkBodyInside", "start": 0, @@ -6898,17 +6898,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 4713, + "commentStart": 4784, "elements": [ { - "commentStart": 4714, + "commentStart": 4793, "end": 0, "left": { "abs_path": false, - "commentStart": 4714, + "commentStart": 4793, "end": 0, "name": { - "commentStart": 4714, + "commentStart": 4793, "end": 0, "name": "sinkOffsetLeft", "start": 0, @@ -6922,10 +6922,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 4729, + "commentStart": 4810, "end": 0, "name": { - "commentStart": 4729, + "commentStart": 4810, "end": 0, "name": "metalThickness", "start": 0, @@ -6941,14 +6941,14 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "BinaryExpression" }, { - "commentStart": 4745, + "commentStart": 4833, "end": 0, "left": { "abs_path": false, - "commentStart": 4745, + "commentStart": 4833, "end": 0, "name": { - "commentStart": 4745, + "commentStart": 4833, "end": 0, "name": "sinkOffsetFront", "start": 0, @@ -6962,10 +6962,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 4761, + "commentStart": 4851, "end": 0, "name": { - "commentStart": 4761, + "commentStart": 4851, "end": 0, "name": "metalThickness", "start": 0, @@ -6988,10 +6988,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 4778, + "commentStart": 4874, "end": 0, "name": { - "commentStart": 4778, + "commentStart": 4874, "end": 0, "name": "sinkPlaneInside", "start": 0, @@ -7005,10 +7005,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4698, + "commentStart": 4769, "end": 0, "name": { - "commentStart": 4698, + "commentStart": 4769, "end": 0, "name": "startProfileAt", "start": 0, @@ -7018,7 +7018,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4698, + "commentStart": 4769, "end": 0, "start": 0, "type": "CallExpression", @@ -7029,21 +7029,21 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4806, + "commentStart": 4902, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4813, + "commentStart": 4911, "end": 0, "left": { "abs_path": false, - "commentStart": 4813, + "commentStart": 4911, "end": 0, "name": { - "commentStart": 4813, + "commentStart": 4911, "end": 0, "name": "sinkLength", "start": 0, @@ -7056,14 +7056,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 4824, + "commentStart": 4925, "end": 0, "left": { "abs_path": false, - "commentStart": 4824, + "commentStart": 4925, "end": 0, "name": { - "commentStart": 4824, + "commentStart": 4925, "end": 0, "name": "metalThickness", "start": 0, @@ -7076,7 +7076,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 4839, + "commentStart": 4942, "end": 0, "raw": "2", "start": 0, @@ -7099,10 +7099,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4800, + "commentStart": 4896, "end": 0, "name": { - "commentStart": 4800, + "commentStart": 4896, "end": 0, "name": "yLine", "start": 0, @@ -7112,7 +7112,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4800, + "commentStart": 4896, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7124,21 +7124,21 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4853, + "commentStart": 4957, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4860, + "commentStart": 4966, "end": 0, "left": { "abs_path": false, - "commentStart": 4860, + "commentStart": 4966, "end": 0, "name": { - "commentStart": 4860, + "commentStart": 4966, "end": 0, "name": "sinkWidth", "start": 0, @@ -7151,14 +7151,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 4870, + "commentStart": 4979, "end": 0, "left": { "abs_path": false, - "commentStart": 4870, + "commentStart": 4979, "end": 0, "name": { - "commentStart": 4870, + "commentStart": 4979, "end": 0, "name": "metalThickness", "start": 0, @@ -7171,7 +7171,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 4885, + "commentStart": 4996, "end": 0, "raw": "2", "start": 0, @@ -7194,10 +7194,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4847, + "commentStart": 4951, "end": 0, "name": { - "commentStart": 4847, + "commentStart": 4951, "end": 0, "name": "xLine", "start": 0, @@ -7207,7 +7207,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4847, + "commentStart": 4951, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7219,22 +7219,22 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4899, + "commentStart": 5011, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4906, + "commentStart": 5020, "end": 0, "left": { "argument": { "abs_path": false, - "commentStart": 4907, + "commentStart": 5021, "end": 0, "name": { - "commentStart": 4907, + "commentStart": 5021, "end": 0, "name": "sinkLength", "start": 0, @@ -7245,7 +7245,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 4906, + "commentStart": 5020, "end": 0, "operator": "-", "start": 0, @@ -7254,14 +7254,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "+", "right": { - "commentStart": 4918, + "commentStart": 5034, "end": 0, "left": { "abs_path": false, - "commentStart": 4918, + "commentStart": 5034, "end": 0, "name": { - "commentStart": 4918, + "commentStart": 5034, "end": 0, "name": "metalThickness", "start": 0, @@ -7274,7 +7274,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 4933, + "commentStart": 5051, "end": 0, "raw": "2", "start": 0, @@ -7297,10 +7297,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4893, + "commentStart": 5005, "end": 0, "name": { - "commentStart": 4893, + "commentStart": 5005, "end": 0, "name": "yLine", "start": 0, @@ -7310,7 +7310,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4893, + "commentStart": 5005, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7322,19 +7322,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 4946, + "commentStart": 5064, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 4960, + "commentStart": 5078, "elements": [ { "arguments": [ { - "commentStart": 4975, + "commentStart": 5093, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -7343,10 +7343,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4961, + "commentStart": 5079, "end": 0, "name": { - "commentStart": 4961, + "commentStart": 5079, "end": 0, "name": "profileStartX", "start": 0, @@ -7356,7 +7356,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4961, + "commentStart": 5079, "end": 0, "start": 0, "type": "CallExpression", @@ -7365,7 +7365,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 4993, + "commentStart": 5111, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -7374,10 +7374,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4979, + "commentStart": 5097, "end": 0, "name": { - "commentStart": 4979, + "commentStart": 5097, "end": 0, "name": "profileStartY", "start": 0, @@ -7387,7 +7387,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4979, + "commentStart": 5097, "end": 0, "start": 0, "type": "CallExpression", @@ -7403,10 +7403,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 4941, + "commentStart": 5059, "end": 0, "name": { - "commentStart": 4941, + "commentStart": 5059, "end": 0, "name": "line", "start": 0, @@ -7416,7 +7416,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 4941, + "commentStart": 5059, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7427,10 +7427,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 5003, + "commentStart": 5121, "end": 0, "name": { - "commentStart": 5003, + "commentStart": 5121, "end": 0, "name": "close", "start": 0, @@ -7440,7 +7440,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5003, + "commentStart": 5121, "end": 0, "start": 0, "type": "CallExpression", @@ -7451,17 +7451,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5032, + "commentStart": 5150, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 5039, + "commentStart": 5157, "elements": [ { - "commentStart": 5040, + "commentStart": 5158, "end": 0, "raw": "1", "start": 0, @@ -7473,7 +7473,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 5043, + "commentStart": 5161, "end": 0, "raw": "0", "start": 0, @@ -7494,7 +7494,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5047, + "commentStart": 5165, "end": 0, "name": "instances", "start": 0, @@ -7502,10 +7502,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5059, + "commentStart": 5177, "end": 0, "name": { - "commentStart": 5059, + "commentStart": 5177, "end": 0, "name": "sinkCount", "start": 0, @@ -7520,7 +7520,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5070, + "commentStart": 5188, "end": 0, "name": "distance", "start": 0, @@ -7528,10 +7528,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5081, + "commentStart": 5199, "end": 0, "name": { - "commentStart": 5081, + "commentStart": 5199, "end": 0, "name": "sinkSpacing", "start": 0, @@ -7546,10 +7546,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5016, + "commentStart": 5134, "end": 0, "name": { - "commentStart": 5016, + "commentStart": 5134, "end": 0, "name": "patternLinear2d", "start": 0, @@ -7559,7 +7559,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5016, + "commentStart": 5134, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7571,7 +7571,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5107, + "commentStart": 5225, "end": 0, "name": "length", "start": 0, @@ -7580,10 +7580,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 5117, + "commentStart": 5235, "end": 0, "name": { - "commentStart": 5117, + "commentStart": 5235, "end": 0, "name": "sinkDepth", "start": 0, @@ -7594,7 +7594,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 5116, + "commentStart": 5234, "end": 0, "operator": "-", "start": 0, @@ -7605,10 +7605,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5099, + "commentStart": 5217, "end": 0, "name": { - "commentStart": 5099, + "commentStart": 5217, "end": 0, "name": "extrude", "start": 0, @@ -7618,7 +7618,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5099, + "commentStart": 5217, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -7626,13 +7626,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 4698, + "commentStart": 4769, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "7": [ { - "commentStart": 5129, + "commentStart": 5245, "end": 0, "start": 0, "type": "NonCodeNode", @@ -7660,19 +7660,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5146, + "commentStart": 5262, "declaration": { - "commentStart": 5146, + "commentStart": 5262, "end": 0, "id": { - "commentStart": 5146, + "commentStart": 5262, "end": 0, "name": "doorGap", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5156, + "commentStart": 5272, "end": 0, "raw": "2", "start": 0, @@ -7693,29 +7693,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5158, + "commentStart": 5274, "declaration": { - "commentStart": 5158, + "commentStart": 5274, "end": 0, "id": { - "commentStart": 5158, + "commentStart": 5274, "end": 0, "name": "doorWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5170, + "commentStart": 5286, "end": 0, "left": { - "commentStart": 5170, + "commentStart": 5286, "end": 0, "left": { "abs_path": false, - "commentStart": 5170, + "commentStart": 5286, "end": 0, "name": { - "commentStart": 5170, + "commentStart": 5286, "end": 0, "name": "blockSubdivisionWidth", "start": 0, @@ -7729,10 +7729,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 5194, + "commentStart": 5310, "end": 0, "name": { - "commentStart": 5194, + "commentStart": 5310, "end": 0, "name": "profileThickness", "start": 0, @@ -7749,14 +7749,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 5213, + "commentStart": 5330, "end": 0, "left": { "abs_path": false, - "commentStart": 5213, + "commentStart": 5330, "end": 0, "name": { - "commentStart": 5213, + "commentStart": 5330, "end": 0, "name": "doorGap", "start": 0, @@ -7769,7 +7769,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 5221, + "commentStart": 5340, "end": 0, "raw": "2", "start": 0, @@ -7798,26 +7798,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5223, + "commentStart": 5343, "declaration": { - "commentStart": 5223, + "commentStart": 5343, "end": 0, "id": { - "commentStart": 5223, + "commentStart": 5343, "end": 0, "name": "doorStart", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5235, + "commentStart": 5355, "end": 0, "left": { "abs_path": false, - "commentStart": 5235, + "commentStart": 5355, "end": 0, "name": { - "commentStart": 5235, + "commentStart": 5355, "end": 0, "name": "profileThickness", "start": 0, @@ -7831,10 +7831,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 5252, + "commentStart": 5374, "end": 0, "name": { - "commentStart": 5252, + "commentStart": 5374, "end": 0, "name": "doorGap", "start": 0, @@ -7859,26 +7859,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5260, + "commentStart": 5382, "declaration": { - "commentStart": 5260, + "commentStart": 5382, "end": 0, "id": { - "commentStart": 5260, + "commentStart": 5382, "end": 0, "name": "doorHeightAboveTheFloor", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5286, + "commentStart": 5408, "end": 0, "left": { "abs_path": false, - "commentStart": 5286, + "commentStart": 5408, "end": 0, "name": { - "commentStart": 5286, + "commentStart": 5408, "end": 0, "name": "pillarHeightAboveTheFloor", "start": 0, @@ -7892,10 +7892,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 5314, + "commentStart": 5436, "end": 0, "name": { - "commentStart": 5314, + "commentStart": 5436, "end": 0, "name": "doorGap", "start": 0, @@ -7920,32 +7920,32 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5322, + "commentStart": 5444, "declaration": { - "commentStart": 5322, + "commentStart": 5444, "end": 0, "id": { - "commentStart": 5322, + "commentStart": 5444, "end": 0, "name": "doorHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5335, + "commentStart": 5457, "end": 0, "left": { - "commentStart": 5335, + "commentStart": 5457, "end": 0, "left": { - "commentStart": 5335, + "commentStart": 5457, "end": 0, "left": { "abs_path": false, - "commentStart": 5335, + "commentStart": 5457, "end": 0, "name": { - "commentStart": 5335, + "commentStart": 5457, "end": 0, "name": "blockHeight", "start": 0, @@ -7959,10 +7959,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 5349, + "commentStart": 5471, "end": 0, "name": { - "commentStart": 5349, + "commentStart": 5471, "end": 0, "name": "doorHeightAboveTheFloor", "start": 0, @@ -7980,10 +7980,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 5375, + "commentStart": 5497, "end": 0, "name": { - "commentStart": 5375, + "commentStart": 5497, "end": 0, "name": "profileThickness", "start": 0, @@ -8001,10 +8001,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 5394, + "commentStart": 5516, "end": 0, "name": { - "commentStart": 5394, + "commentStart": 5516, "end": 0, "name": "doorGap", "start": 0, @@ -8029,26 +8029,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5402, + "commentStart": 5524, "declaration": { - "commentStart": 5402, + "commentStart": 5524, "end": 0, "id": { - "commentStart": 5402, + "commentStart": 5524, "end": 0, "name": "doorCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5414, + "commentStart": 5536, "end": 0, "left": { "abs_path": false, - "commentStart": 5414, + "commentStart": 5536, "end": 0, "name": { - "commentStart": 5414, + "commentStart": 5536, "end": 0, "name": "blockCount", "start": 0, @@ -8062,10 +8062,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "*", "right": { "abs_path": false, - "commentStart": 5427, + "commentStart": 5549, "end": 0, "name": { - "commentStart": 5427, + "commentStart": 5549, "end": 0, "name": "blockSubdivisionCount", "start": 0, @@ -8090,12 +8090,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5448, + "commentStart": 5570, "declaration": { - "commentStart": 5450, + "commentStart": 5572, "end": 0, "id": { - "commentStart": 5450, + "commentStart": 5572, "end": 0, "name": "doorPlane", "start": 0, @@ -8108,7 +8108,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5492, + "commentStart": 5614, "end": 0, "name": "offset", "start": 0, @@ -8116,10 +8116,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5501, + "commentStart": 5623, "end": 0, "name": { - "commentStart": 5501, + "commentStart": 5623, "end": 0, "name": "doorHeightAboveTheFloor", "start": 0, @@ -8134,10 +8134,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5476, + "commentStart": 5598, "end": 0, "name": { - "commentStart": 5476, + "commentStart": 5598, "end": 0, "name": "offsetPlane", "start": 0, @@ -8147,17 +8147,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5476, + "commentStart": 5598, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 5488, + "commentStart": 5610, "end": 0, "name": { - "commentStart": 5488, + "commentStart": 5610, "end": 0, "name": "XY", "start": 0, @@ -8172,10 +8172,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5462, + "commentStart": 5584, "end": 0, "name": { - "commentStart": 5462, + "commentStart": 5584, "end": 0, "name": "startSketchOn", "start": 0, @@ -8185,7 +8185,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5462, + "commentStart": 5584, "end": 0, "start": 0, "type": "CallExpression", @@ -8201,12 +8201,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5527, + "commentStart": 5649, "declaration": { - "commentStart": 5527, + "commentStart": 5649, "end": 0, "id": { - "commentStart": 5527, + "commentStart": 5649, "end": 0, "name": "doorBody", "start": 0, @@ -8217,14 +8217,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 5553, + "commentStart": 5675, "elements": [ { "abs_path": false, - "commentStart": 5554, + "commentStart": 5676, "end": 0, "name": { - "commentStart": 5554, + "commentStart": 5676, "end": 0, "name": "doorStart", "start": 0, @@ -8236,7 +8236,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name" }, { - "commentStart": 5565, + "commentStart": 5687, "end": 0, "raw": "0", "start": 0, @@ -8255,10 +8255,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 5569, + "commentStart": 5691, "end": 0, "name": { - "commentStart": 5569, + "commentStart": 5691, "end": 0, "name": "doorPlane", "start": 0, @@ -8272,10 +8272,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5538, + "commentStart": 5660, "end": 0, "name": { - "commentStart": 5538, + "commentStart": 5660, "end": 0, "name": "startProfileAt", "start": 0, @@ -8285,7 +8285,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5538, + "commentStart": 5660, "end": 0, "start": 0, "type": "CallExpression", @@ -8296,7 +8296,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5591, + "commentStart": 5713, "end": 0, "name": "length", "start": 0, @@ -8304,10 +8304,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5598, + "commentStart": 5722, "end": 0, "name": { - "commentStart": 5598, + "commentStart": 5722, "end": 0, "name": "profileThickness", "start": 0, @@ -8322,10 +8322,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5585, + "commentStart": 5707, "end": 0, "name": { - "commentStart": 5585, + "commentStart": 5707, "end": 0, "name": "yLine", "start": 0, @@ -8335,7 +8335,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5585, + "commentStart": 5707, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8347,7 +8347,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5627, + "commentStart": 5751, "end": 0, "name": "length", "start": 0, @@ -8355,10 +8355,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5634, + "commentStart": 5760, "end": 0, "name": { - "commentStart": 5634, + "commentStart": 5760, "end": 0, "name": "doorWidth", "start": 0, @@ -8373,10 +8373,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5621, + "commentStart": 5745, "end": 0, "name": { - "commentStart": 5621, + "commentStart": 5745, "end": 0, "name": "xLine", "start": 0, @@ -8386,7 +8386,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5621, + "commentStart": 5745, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8398,7 +8398,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5656, + "commentStart": 5782, "end": 0, "name": "length", "start": 0, @@ -8407,10 +8407,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 5664, + "commentStart": 5792, "end": 0, "name": { - "commentStart": 5664, + "commentStart": 5792, "end": 0, "name": "profileThickness", "start": 0, @@ -8421,7 +8421,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 5663, + "commentStart": 5791, "end": 0, "operator": "-", "start": 0, @@ -8432,10 +8432,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5650, + "commentStart": 5776, "end": 0, "name": { - "commentStart": 5650, + "commentStart": 5776, "end": 0, "name": "yLine", "start": 0, @@ -8445,7 +8445,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5650, + "commentStart": 5776, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8457,19 +8457,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5692, + "commentStart": 5820, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 5706, + "commentStart": 5834, "elements": [ { "arguments": [ { - "commentStart": 5721, + "commentStart": 5849, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -8478,10 +8478,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5707, + "commentStart": 5835, "end": 0, "name": { - "commentStart": 5707, + "commentStart": 5835, "end": 0, "name": "profileStartX", "start": 0, @@ -8491,7 +8491,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5707, + "commentStart": 5835, "end": 0, "start": 0, "type": "CallExpression", @@ -8500,7 +8500,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 5739, + "commentStart": 5867, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -8509,10 +8509,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5725, + "commentStart": 5853, "end": 0, "name": { - "commentStart": 5725, + "commentStart": 5853, "end": 0, "name": "profileStartY", "start": 0, @@ -8522,7 +8522,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5725, + "commentStart": 5853, "end": 0, "start": 0, "type": "CallExpression", @@ -8538,10 +8538,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5687, + "commentStart": 5815, "end": 0, "name": { - "commentStart": 5687, + "commentStart": 5815, "end": 0, "name": "line", "start": 0, @@ -8551,7 +8551,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5687, + "commentStart": 5815, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8562,10 +8562,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 5749, + "commentStart": 5877, "end": 0, "name": { - "commentStart": 5749, + "commentStart": 5877, "end": 0, "name": "close", "start": 0, @@ -8575,7 +8575,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5749, + "commentStart": 5877, "end": 0, "start": 0, "type": "CallExpression", @@ -8586,17 +8586,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5778, + "commentStart": 5906, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 5785, + "commentStart": 5913, "elements": [ { - "commentStart": 5786, + "commentStart": 5914, "end": 0, "raw": "1", "start": 0, @@ -8608,7 +8608,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 5789, + "commentStart": 5917, "end": 0, "raw": "0", "start": 0, @@ -8629,7 +8629,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5793, + "commentStart": 5921, "end": 0, "name": "instances", "start": 0, @@ -8637,10 +8637,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5805, + "commentStart": 5933, "end": 0, "name": { - "commentStart": 5805, + "commentStart": 5933, "end": 0, "name": "doorCount", "start": 0, @@ -8655,7 +8655,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5816, + "commentStart": 5944, "end": 0, "name": "distance", "start": 0, @@ -8663,10 +8663,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5827, + "commentStart": 5955, "end": 0, "name": { - "commentStart": 5827, + "commentStart": 5955, "end": 0, "name": "blockSubdivisionWidth", "start": 0, @@ -8681,10 +8681,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5762, + "commentStart": 5890, "end": 0, "name": { - "commentStart": 5762, + "commentStart": 5890, "end": 0, "name": "patternLinear2d", "start": 0, @@ -8694,7 +8694,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5762, + "commentStart": 5890, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8706,7 +8706,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 5863, + "commentStart": 5991, "end": 0, "name": "length", "start": 0, @@ -8714,10 +8714,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 5872, + "commentStart": 6000, "end": 0, "name": { - "commentStart": 5872, + "commentStart": 6000, "end": 0, "name": "doorHeight", "start": 0, @@ -8732,10 +8732,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 5855, + "commentStart": 5983, "end": 0, "name": { - "commentStart": 5855, + "commentStart": 5983, "end": 0, "name": "extrude", "start": 0, @@ -8745,7 +8745,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 5855, + "commentStart": 5983, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -8753,13 +8753,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 5538, + "commentStart": 5660, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "7": [ { - "commentStart": 5883, + "commentStart": 6011, "end": 0, "start": 0, "type": "NonCodeNode", @@ -8787,29 +8787,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5900, + "commentStart": 6028, "declaration": { - "commentStart": 5900, + "commentStart": 6028, "end": 0, "id": { - "commentStart": 5900, + "commentStart": 6028, "end": 0, "name": "panelWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5913, + "commentStart": 6041, "end": 0, "left": { - "commentStart": 5913, + "commentStart": 6041, "end": 0, "left": { "abs_path": false, - "commentStart": 5913, + "commentStart": 6041, "end": 0, "name": { - "commentStart": 5913, + "commentStart": 6041, "end": 0, "name": "blockDepth", "start": 0, @@ -8823,10 +8823,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 5926, + "commentStart": 6054, "end": 0, "name": { - "commentStart": 5926, + "commentStart": 6054, "end": 0, "name": "profileThickness", "start": 0, @@ -8843,14 +8843,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 5945, + "commentStart": 6074, "end": 0, "left": { "abs_path": false, - "commentStart": 5945, + "commentStart": 6074, "end": 0, "name": { - "commentStart": 5945, + "commentStart": 6074, "end": 0, "name": "doorGap", "start": 0, @@ -8863,7 +8863,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 5953, + "commentStart": 6084, "end": 0, "raw": "2", "start": 0, @@ -8892,26 +8892,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5955, + "commentStart": 6087, "declaration": { - "commentStart": 5955, + "commentStart": 6087, "end": 0, "id": { - "commentStart": 5955, + "commentStart": 6087, "end": 0, "name": "panelCount", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5968, + "commentStart": 6100, "end": 0, "left": { "abs_path": false, - "commentStart": 5968, + "commentStart": 6100, "end": 0, "name": { - "commentStart": 5968, + "commentStart": 6100, "end": 0, "name": "doorCount", "start": 0, @@ -8924,7 +8924,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "+", "right": { - "commentStart": 5980, + "commentStart": 6112, "end": 0, "raw": "1", "start": 0, @@ -8949,26 +8949,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 5982, + "commentStart": 6114, "declaration": { - "commentStart": 5982, + "commentStart": 6114, "end": 0, "id": { - "commentStart": 5982, + "commentStart": 6114, "end": 0, "name": "panelSpacing", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 5997, + "commentStart": 6129, "end": 0, "left": { "abs_path": false, - "commentStart": 5997, + "commentStart": 6129, "end": 0, "name": { - "commentStart": 5997, + "commentStart": 6129, "end": 0, "name": "tableWidth", "start": 0, @@ -8982,10 +8982,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 6010, + "commentStart": 6142, "end": 0, "name": { - "commentStart": 6010, + "commentStart": 6142, "end": 0, "name": "profileThickness", "start": 0, @@ -9010,12 +9010,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6027, + "commentStart": 6159, "declaration": { - "commentStart": 6027, + "commentStart": 6159, "end": 0, "id": { - "commentStart": 6027, + "commentStart": 6159, "end": 0, "name": "panelBody", "start": 0, @@ -9026,10 +9026,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 6054, + "commentStart": 6186, "elements": [ { - "commentStart": 6055, + "commentStart": 6187, "end": 0, "raw": "0", "start": 0, @@ -9042,10 +9042,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 6058, + "commentStart": 6190, "end": 0, "name": { - "commentStart": 6058, + "commentStart": 6190, "end": 0, "name": "doorStart", "start": 0, @@ -9064,10 +9064,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 6070, + "commentStart": 6202, "end": 0, "name": { - "commentStart": 6070, + "commentStart": 6202, "end": 0, "name": "doorPlane", "start": 0, @@ -9081,10 +9081,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6039, + "commentStart": 6171, "end": 0, "name": { - "commentStart": 6039, + "commentStart": 6171, "end": 0, "name": "startProfileAt", "start": 0, @@ -9094,7 +9094,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6039, + "commentStart": 6171, "end": 0, "start": 0, "type": "CallExpression", @@ -9105,7 +9105,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6092, + "commentStart": 6224, "end": 0, "name": "length", "start": 0, @@ -9113,10 +9113,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 6099, + "commentStart": 6233, "end": 0, "name": { - "commentStart": 6099, + "commentStart": 6233, "end": 0, "name": "panelWidth", "start": 0, @@ -9131,10 +9131,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6086, + "commentStart": 6218, "end": 0, "name": { - "commentStart": 6086, + "commentStart": 6218, "end": 0, "name": "yLine", "start": 0, @@ -9144,7 +9144,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6086, + "commentStart": 6218, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9156,7 +9156,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6122, + "commentStart": 6256, "end": 0, "name": "length", "start": 0, @@ -9164,10 +9164,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 6129, + "commentStart": 6265, "end": 0, "name": { - "commentStart": 6129, + "commentStart": 6265, "end": 0, "name": "profileThickness", "start": 0, @@ -9182,10 +9182,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6116, + "commentStart": 6250, "end": 0, "name": { - "commentStart": 6116, + "commentStart": 6250, "end": 0, "name": "xLine", "start": 0, @@ -9195,7 +9195,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6116, + "commentStart": 6250, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9207,7 +9207,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6158, + "commentStart": 6294, "end": 0, "name": "length", "start": 0, @@ -9216,10 +9216,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 6166, + "commentStart": 6304, "end": 0, "name": { - "commentStart": 6166, + "commentStart": 6304, "end": 0, "name": "panelWidth", "start": 0, @@ -9230,7 +9230,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 6165, + "commentStart": 6303, "end": 0, "operator": "-", "start": 0, @@ -9241,10 +9241,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6152, + "commentStart": 6288, "end": 0, "name": { - "commentStart": 6152, + "commentStart": 6288, "end": 0, "name": "yLine", "start": 0, @@ -9254,7 +9254,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6152, + "commentStart": 6288, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9266,19 +9266,19 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6188, + "commentStart": 6326, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 6202, + "commentStart": 6340, "elements": [ { "arguments": [ { - "commentStart": 6217, + "commentStart": 6355, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -9287,10 +9287,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6203, + "commentStart": 6341, "end": 0, "name": { - "commentStart": 6203, + "commentStart": 6341, "end": 0, "name": "profileStartX", "start": 0, @@ -9300,7 +9300,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6203, + "commentStart": 6341, "end": 0, "start": 0, "type": "CallExpression", @@ -9309,7 +9309,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 6235, + "commentStart": 6373, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -9318,10 +9318,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6221, + "commentStart": 6359, "end": 0, "name": { - "commentStart": 6221, + "commentStart": 6359, "end": 0, "name": "profileStartY", "start": 0, @@ -9331,7 +9331,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6221, + "commentStart": 6359, "end": 0, "start": 0, "type": "CallExpression", @@ -9347,10 +9347,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6183, + "commentStart": 6321, "end": 0, "name": { - "commentStart": 6183, + "commentStart": 6321, "end": 0, "name": "line", "start": 0, @@ -9360,7 +9360,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6183, + "commentStart": 6321, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9371,10 +9371,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 6245, + "commentStart": 6383, "end": 0, "name": { - "commentStart": 6245, + "commentStart": 6383, "end": 0, "name": "close", "start": 0, @@ -9384,7 +9384,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6245, + "commentStart": 6383, "end": 0, "start": 0, "type": "CallExpression", @@ -9395,17 +9395,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6274, + "commentStart": 6412, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 6281, + "commentStart": 6419, "elements": [ { - "commentStart": 6282, + "commentStart": 6420, "end": 0, "raw": "1", "start": 0, @@ -9417,7 +9417,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 6285, + "commentStart": 6423, "end": 0, "raw": "0", "start": 0, @@ -9438,14 +9438,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6289, + "commentStart": 6427, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 6301, + "commentStart": 6439, "end": 0, "raw": "2", "start": 0, @@ -9460,7 +9460,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6304, + "commentStart": 6442, "end": 0, "name": "distance", "start": 0, @@ -9468,10 +9468,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 6315, + "commentStart": 6453, "end": 0, "name": { - "commentStart": 6315, + "commentStart": 6453, "end": 0, "name": "panelSpacing", "start": 0, @@ -9486,10 +9486,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6258, + "commentStart": 6396, "end": 0, "name": { - "commentStart": 6258, + "commentStart": 6396, "end": 0, "name": "patternLinear2d", "start": 0, @@ -9499,7 +9499,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6258, + "commentStart": 6396, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9511,7 +9511,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6342, + "commentStart": 6480, "end": 0, "name": "length", "start": 0, @@ -9519,10 +9519,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 6351, + "commentStart": 6489, "end": 0, "name": { - "commentStart": 6351, + "commentStart": 6489, "end": 0, "name": "doorHeight", "start": 0, @@ -9537,10 +9537,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6334, + "commentStart": 6472, "end": 0, "name": { - "commentStart": 6334, + "commentStart": 6472, "end": 0, "name": "extrude", "start": 0, @@ -9550,7 +9550,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6334, + "commentStart": 6472, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -9558,13 +9558,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 6039, + "commentStart": 6171, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "7": [ { - "commentStart": 6364, + "commentStart": 6500, "end": 0, "start": 0, "type": "NonCodeNode", @@ -9592,19 +9592,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6376, + "commentStart": 6512, "declaration": { - "commentStart": 6376, + "commentStart": 6512, "end": 0, "id": { - "commentStart": 6376, + "commentStart": 6512, "end": 0, "name": "handleDepth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6390, + "commentStart": 6526, "end": 0, "raw": "40", "start": 0, @@ -9625,19 +9625,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6393, + "commentStart": 6529, "declaration": { - "commentStart": 6393, + "commentStart": 6529, "end": 0, "id": { - "commentStart": 6393, + "commentStart": 6529, "end": 0, "name": "handleWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6407, + "commentStart": 6543, "end": 0, "raw": "120", "start": 0, @@ -9658,19 +9658,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6411, + "commentStart": 6547, "declaration": { - "commentStart": 6411, + "commentStart": 6547, "end": 0, "id": { - "commentStart": 6411, + "commentStart": 6547, "end": 0, "name": "handleFillet", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6426, + "commentStart": 6562, "end": 0, "raw": "20", "start": 0, @@ -9691,19 +9691,19 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6429, + "commentStart": 6565, "declaration": { - "commentStart": 6429, + "commentStart": 6565, "end": 0, "id": { - "commentStart": 6429, + "commentStart": 6565, "end": 0, "name": "handleHeightAboveTheFloor", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6457, + "commentStart": 6593, "end": 0, "raw": "780", "start": 0, @@ -9724,29 +9724,29 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6461, + "commentStart": 6597, "declaration": { - "commentStart": 6461, + "commentStart": 6597, "end": 0, "id": { - "commentStart": 6461, + "commentStart": 6597, "end": 0, "name": "handleOffset", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6476, + "commentStart": 6612, "end": 0, "left": { - "commentStart": 6476, + "commentStart": 6612, "end": 0, "left": { "abs_path": false, - "commentStart": 6476, + "commentStart": 6612, "end": 0, "name": { - "commentStart": 6476, + "commentStart": 6612, "end": 0, "name": "doorStart", "start": 0, @@ -9759,14 +9759,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "+", "right": { - "commentStart": 6488, + "commentStart": 6624, "end": 0, "left": { "abs_path": false, - "commentStart": 6488, + "commentStart": 6624, "end": 0, "name": { - "commentStart": 6488, + "commentStart": 6624, "end": 0, "name": "doorWidth", "start": 0, @@ -9779,7 +9779,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "/", "right": { - "commentStart": 6500, + "commentStart": 6636, "end": 0, "raw": "2", "start": 0, @@ -9800,14 +9800,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 6505, + "commentStart": 6641, "end": 0, "left": { "abs_path": false, - "commentStart": 6505, + "commentStart": 6641, "end": 0, "name": { - "commentStart": 6505, + "commentStart": 6641, "end": 0, "name": "handleWidth", "start": 0, @@ -9820,7 +9820,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "/", "right": { - "commentStart": 6519, + "commentStart": 6655, "end": 0, "raw": "2", "start": 0, @@ -9849,26 +9849,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6522, + "commentStart": 6658, "declaration": { - "commentStart": 6522, + "commentStart": 6658, "end": 0, "id": { - "commentStart": 6522, + "commentStart": 6658, "end": 0, "name": "handleLengthSegmentA", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6545, + "commentStart": 6681, "end": 0, "left": { "abs_path": false, - "commentStart": 6545, + "commentStart": 6681, "end": 0, "name": { - "commentStart": 6545, + "commentStart": 6681, "end": 0, "name": "handleDepth", "start": 0, @@ -9882,10 +9882,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 6559, + "commentStart": 6695, "end": 0, "name": { - "commentStart": 6559, + "commentStart": 6695, "end": 0, "name": "handleFillet", "start": 0, @@ -9910,26 +9910,26 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6572, + "commentStart": 6708, "declaration": { - "commentStart": 6572, + "commentStart": 6708, "end": 0, "id": { - "commentStart": 6572, + "commentStart": 6708, "end": 0, "name": "handleLengthSegmentB", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 6595, + "commentStart": 6731, "end": 0, "left": { "abs_path": false, - "commentStart": 6595, + "commentStart": 6731, "end": 0, "name": { - "commentStart": 6595, + "commentStart": 6731, "end": 0, "name": "handleWidth", "start": 0, @@ -9942,14 +9942,14 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "-", "right": { - "commentStart": 6610, + "commentStart": 6746, "end": 0, "left": { "abs_path": false, - "commentStart": 6610, + "commentStart": 6746, "end": 0, "name": { - "commentStart": 6610, + "commentStart": 6746, "end": 0, "name": "handleFillet", "start": 0, @@ -9962,7 +9962,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "operator": "*", "right": { - "commentStart": 6625, + "commentStart": 6761, "end": 0, "raw": "2", "start": 0, @@ -9991,12 +9991,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6627, + "commentStart": 6763, "declaration": { - "commentStart": 6629, + "commentStart": 6765, "end": 0, "id": { - "commentStart": 6629, + "commentStart": 6765, "end": 0, "name": "handlePlane", "start": 0, @@ -10009,7 +10009,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6673, + "commentStart": 6809, "end": 0, "name": "offset", "start": 0, @@ -10017,10 +10017,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 6682, + "commentStart": 6818, "end": 0, "name": { - "commentStart": 6682, + "commentStart": 6818, "end": 0, "name": "handleHeightAboveTheFloor", "start": 0, @@ -10035,10 +10035,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6657, + "commentStart": 6793, "end": 0, "name": { - "commentStart": 6657, + "commentStart": 6793, "end": 0, "name": "offsetPlane", "start": 0, @@ -10048,17 +10048,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6657, + "commentStart": 6793, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 6669, + "commentStart": 6805, "end": 0, "name": { - "commentStart": 6669, + "commentStart": 6805, "end": 0, "name": "XY", "start": 0, @@ -10073,10 +10073,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6643, + "commentStart": 6779, "end": 0, "name": { - "commentStart": 6643, + "commentStart": 6779, "end": 0, "name": "startSketchOn", "start": 0, @@ -10086,7 +10086,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6643, + "commentStart": 6779, "end": 0, "start": 0, "type": "CallExpression", @@ -10102,12 +10102,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 6709, + "commentStart": 6845, "declaration": { - "commentStart": 6711, + "commentStart": 6847, "end": 0, "id": { - "commentStart": 6711, + "commentStart": 6847, "end": 0, "name": "handleProfilePath", "start": 0, @@ -10118,13 +10118,13 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 6746, + "commentStart": 6882, "elements": [ { - "commentStart": 6747, + "commentStart": 6883, "end": 0, "left": { - "commentStart": 6747, + "commentStart": 6883, "end": 0, "raw": "0", "start": 0, @@ -10138,10 +10138,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 6751, + "commentStart": 6887, "end": 0, "name": { - "commentStart": 6751, + "commentStart": 6887, "end": 0, "name": "handleOffset", "start": 0, @@ -10157,7 +10157,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "BinaryExpression" }, { - "commentStart": 6765, + "commentStart": 6901, "end": 0, "raw": "0", "start": 0, @@ -10176,10 +10176,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 6769, + "commentStart": 6905, "end": 0, "name": { - "commentStart": 6769, + "commentStart": 6905, "end": 0, "name": "handlePlane", "start": 0, @@ -10193,10 +10193,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6731, + "commentStart": 6867, "end": 0, "name": { - "commentStart": 6731, + "commentStart": 6867, "end": 0, "name": "startProfileAt", "start": 0, @@ -10206,7 +10206,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6731, + "commentStart": 6867, "end": 0, "start": 0, "type": "CallExpression", @@ -10217,7 +10217,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 6793, + "commentStart": 6929, "end": 0, "name": "length", "start": 0, @@ -10226,10 +10226,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 6801, + "commentStart": 6939, "end": 0, "name": { - "commentStart": 6801, + "commentStart": 6939, "end": 0, "name": "handleLengthSegmentA", "start": 0, @@ -10240,7 +10240,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 6800, + "commentStart": 6938, "end": 0, "operator": "-", "start": 0, @@ -10251,10 +10251,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6787, + "commentStart": 6923, "end": 0, "name": { - "commentStart": 6787, + "commentStart": 6923, "end": 0, "name": "yLine", "start": 0, @@ -10264,7 +10264,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6787, + "commentStart": 6923, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -10274,17 +10274,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 6844, + "commentStart": 6982, "elements": [ { - "commentStart": 6853, + "commentStart": 6991, "end": 0, "left": { "abs_path": false, - "commentStart": 6853, + "commentStart": 6991, "end": 0, "name": { - "commentStart": 6853, + "commentStart": 6991, "end": 0, "name": "handleFillet", "start": 0, @@ -10298,10 +10298,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 6868, + "commentStart": 7006, "end": 0, "name": { - "commentStart": 6868, + "commentStart": 7006, "end": 0, "name": "handleOffset", "start": 0, @@ -10319,10 +10319,10 @@ description: Result of parsing dual-basin-utility-sink.kcl { "argument": { "abs_path": false, - "commentStart": 6890, + "commentStart": 7028, "end": 0, "name": { - "commentStart": 6890, + "commentStart": 7028, "end": 0, "name": "handleDepth", "start": 0, @@ -10333,162 +10333,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "Name", "type": "Name" }, - "commentStart": 6889, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 6910, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" - } - ], - "callee": { - "abs_path": false, - "commentStart": 6828, - "end": 0, - "name": { - "commentStart": 6828, - "end": 0, - "name": "tangentialArcTo", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 6828, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - { - "arguments": [ - { - "type": "LabeledArg", - "label": { - "commentStart": 6924, - "end": 0, - "name": "length", - "start": 0, - "type": "Identifier" - }, - "arg": { - "abs_path": false, - "commentStart": 6931, - "end": 0, - "name": { - "commentStart": 6931, - "end": 0, - "name": "handleLengthSegmentB", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - } - ], - "callee": { - "abs_path": false, - "commentStart": 6918, - "end": 0, - "name": { - "commentStart": 6918, - "end": 0, - "name": "xLine", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 6918, - "end": 0, - "start": 0, - "type": "CallExpressionKw", - "type": "CallExpressionKw", - "unlabeled": null - }, - { - "arguments": [ - { - "commentStart": 6974, - "elements": [ - { - "commentStart": 6983, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 6983, - "end": 0, - "name": { - "commentStart": 6983, - "end": 0, - "name": "handleOffset", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 6998, - "end": 0, - "name": { - "commentStart": 6998, - "end": 0, - "name": "handleWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "argument": { - "abs_path": false, - "commentStart": 7019, - "end": 0, - "name": { - "commentStart": 7019, - "end": 0, - "name": "handleLengthSegmentA", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 7018, + "commentStart": 7027, "end": 0, "operator": "-", "start": 0, @@ -10511,10 +10356,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 6958, + "commentStart": 6966, "end": 0, "name": { - "commentStart": 6958, + "commentStart": 6966, "end": 0, "name": "tangentialArcTo", "start": 0, @@ -10524,7 +10369,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 6958, + "commentStart": 6966, "end": 0, "start": 0, "type": "CallExpression", @@ -10543,12 +10388,12 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 7069, + "commentStart": 7071, "end": 0, "name": { - "commentStart": 7069, + "commentStart": 7071, "end": 0, - "name": "handleLengthSegmentA", + "name": "handleLengthSegmentB", "start": 0, "type": "Identifier" }, @@ -10566,7 +10411,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 7056, "end": 0, - "name": "yLine", + "name": "xLine", "start": 0, "type": "Identifier" }, @@ -10580,9 +10425,164 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": null + }, + { + "arguments": [ + { + "commentStart": 7114, + "elements": [ + { + "commentStart": 7123, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 7123, + "end": 0, + "name": { + "commentStart": 7123, + "end": 0, + "name": "handleOffset", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 7138, + "end": 0, + "name": { + "commentStart": 7138, + "end": 0, + "name": "handleWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "argument": { + "abs_path": false, + "commentStart": 7159, + "end": 0, + "name": { + "commentStart": 7159, + "end": 0, + "name": "handleLengthSegmentA", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 7158, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + }, + { + "commentStart": 7188, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + ], + "callee": { + "abs_path": false, + "commentStart": 7098, + "end": 0, + "name": { + "commentStart": 7098, + "end": 0, + "name": "tangentialArcTo", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 7098, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 7202, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "arg": { + "abs_path": false, + "commentStart": 7211, + "end": 0, + "name": { + "commentStart": 7211, + "end": 0, + "name": "handleLengthSegmentA", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 7196, + "end": 0, + "name": { + "commentStart": 7196, + "end": 0, + "name": "yLine", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 7196, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null } ], - "commentStart": 6731, + "commentStart": 6867, "end": 0, "start": 0, "type": "PipeExpression", @@ -10598,12 +10598,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 7091, + "commentStart": 7233, "declaration": { - "commentStart": 7091, + "commentStart": 7233, "end": 0, "id": { - "commentStart": 7091, + "commentStart": 7233, "end": 0, "name": "handleSectionPlane", "start": 0, @@ -10613,10 +10613,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "arguments": [ { "abs_path": false, - "commentStart": 7126, + "commentStart": 7268, "end": 0, "name": { - "commentStart": 7126, + "commentStart": 7268, "end": 0, "name": "XZ", "start": 0, @@ -10630,10 +10630,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 7112, + "commentStart": 7254, "end": 0, "name": { - "commentStart": 7112, + "commentStart": 7254, "end": 0, "name": "startSketchOn", "start": 0, @@ -10643,7 +10643,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 7112, + "commentStart": 7254, "end": 0, "start": 0, "type": "CallExpression", @@ -10659,12 +10659,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 7130, + "commentStart": 7272, "declaration": { - "commentStart": 7130, + "commentStart": 7272, "end": 0, "id": { - "commentStart": 7130, + "commentStart": 7272, "end": 0, "name": "handleProfileSection", "start": 0, @@ -10675,21 +10675,21 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7185, + "commentStart": 7327, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 7194, + "commentStart": 7336, "elements": [ { "abs_path": false, - "commentStart": 7195, + "commentStart": 7342, "end": 0, "name": { - "commentStart": 7195, + "commentStart": 7342, "end": 0, "name": "handleOffset", "start": 0, @@ -10702,10 +10702,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, { "abs_path": false, - "commentStart": 7209, + "commentStart": 7360, "end": 0, "name": { - "commentStart": 7209, + "commentStart": 7360, "end": 0, "name": "handleHeightAboveTheFloor", "start": 0, @@ -10726,14 +10726,14 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7239, + "commentStart": 7393, "end": 0, "name": "radius", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 7248, + "commentStart": 7402, "end": 0, "raw": "2", "start": 0, @@ -10748,10 +10748,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 7153, + "commentStart": 7295, "end": 0, "name": { - "commentStart": 7153, + "commentStart": 7295, "end": 0, "name": "circle", "start": 0, @@ -10761,17 +10761,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 7153, + "commentStart": 7295, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 7163, + "commentStart": 7305, "end": 0, "name": { - "commentStart": 7163, + "commentStart": 7305, "end": 0, "name": "handleSectionPlane", "start": 0, @@ -10793,12 +10793,12 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "VariableDeclaration" }, { - "commentStart": 7254, + "commentStart": 7407, "declaration": { - "commentStart": 7254, + "commentStart": 7407, "end": 0, "id": { - "commentStart": 7254, + "commentStart": 7407, "end": 0, "name": "handleBody", "start": 0, @@ -10811,7 +10811,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7295, + "commentStart": 7448, "end": 0, "name": "path", "start": 0, @@ -10819,10 +10819,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 7302, + "commentStart": 7455, "end": 0, "name": { - "commentStart": 7302, + "commentStart": 7455, "end": 0, "name": "handleProfilePath", "start": 0, @@ -10837,10 +10837,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 7267, + "commentStart": 7420, "end": 0, "name": { - "commentStart": 7267, + "commentStart": 7420, "end": 0, "name": "sweep", "start": 0, @@ -10850,17 +10850,17 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 7267, + "commentStart": 7420, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 7273, + "commentStart": 7426, "end": 0, "name": { - "commentStart": 7273, + "commentStart": 7426, "end": 0, "name": "handleProfileSection", "start": 0, @@ -10877,17 +10877,17 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7342, + "commentStart": 7495, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 7349, + "commentStart": 7502, "elements": [ { - "commentStart": 7350, + "commentStart": 7503, "end": 0, "raw": "1", "start": 0, @@ -10899,7 +10899,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 7353, + "commentStart": 7506, "end": 0, "raw": "0", "start": 0, @@ -10911,7 +10911,7 @@ description: Result of parsing dual-basin-utility-sink.kcl } }, { - "commentStart": 7356, + "commentStart": 7509, "end": 0, "raw": "0", "start": 0, @@ -10932,7 +10932,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7360, + "commentStart": 7513, "end": 0, "name": "instances", "start": 0, @@ -10940,10 +10940,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 7372, + "commentStart": 7525, "end": 0, "name": { - "commentStart": 7372, + "commentStart": 7525, "end": 0, "name": "doorCount", "start": 0, @@ -10958,7 +10958,7 @@ description: Result of parsing dual-basin-utility-sink.kcl { "type": "LabeledArg", "label": { - "commentStart": 7383, + "commentStart": 7536, "end": 0, "name": "distance", "start": 0, @@ -10966,10 +10966,10 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "arg": { "abs_path": false, - "commentStart": 7394, + "commentStart": 7547, "end": 0, "name": { - "commentStart": 7394, + "commentStart": 7547, "end": 0, "name": "blockSubdivisionWidth", "start": 0, @@ -10984,10 +10984,10 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "callee": { "abs_path": false, - "commentStart": 7326, + "commentStart": 7479, "end": 0, "name": { - "commentStart": 7326, + "commentStart": 7479, "end": 0, "name": "patternLinear3d", "start": 0, @@ -10997,7 +10997,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name" }, - "commentStart": 7326, + "commentStart": 7479, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -11005,7 +11005,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "unlabeled": null } ], - "commentStart": 7267, + "commentStart": 7420, "end": 0, "start": 0, "type": "PipeExpression", @@ -11028,18 +11028,25 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "name": { - "commentStart": 133, + "commentStart": 146, "end": 0, "name": "settings", "start": 0, "type": "Identifier" }, + "preComments": [ + "// Dual-Basin Utility Sink", + "// A stainless steel sink unit with dual rectangular basins and six under-counter storage compartments.", + "", + "", + "// set units" + ], "properties": [ { - "commentStart": 142, + "commentStart": 155, "end": 0, "key": { - "commentStart": 142, + "commentStart": 155, "end": 0, "name": "defaultLengthUnit", "start": 0, @@ -11049,10 +11056,10 @@ description: Result of parsing dual-basin-utility-sink.kcl "type": "ObjectProperty", "value": { "abs_path": false, - "commentStart": 162, + "commentStart": 175, "end": 0, "name": { - "commentStart": 162, + "commentStart": 175, "end": 0, "name": "mm", "start": 0, @@ -11073,7 +11080,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "nonCodeNodes": { "2": [ { - "commentStart": 230, + "commentStart": 243, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11084,7 +11091,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "4": [ { - "commentStart": 272, + "commentStart": 285, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11095,7 +11102,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "8": [ { - "commentStart": 427, + "commentStart": 442, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11106,7 +11113,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "13": [ { - "commentStart": 635, + "commentStart": 650, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11117,7 +11124,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "16": [ { - "commentStart": 1152, + "commentStart": 1173, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11128,7 +11135,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "18": [ { - "commentStart": 1692, + "commentStart": 1719, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11139,7 +11146,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "23": [ { - "commentStart": 2376, + "commentStart": 2411, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11150,7 +11157,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "25": [ { - "commentStart": 2913, + "commentStart": 2954, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11161,7 +11168,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "26": [ { - "commentStart": 3263, + "commentStart": 3310, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11172,7 +11179,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "30": [ { - "commentStart": 4036, + "commentStart": 4097, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11183,7 +11190,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "37": [ { - "commentStart": 4199, + "commentStart": 4264, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11194,7 +11201,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "39": [ { - "commentStart": 4626, + "commentStart": 4697, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11205,7 +11212,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "47": [ { - "commentStart": 5448, + "commentStart": 5570, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11216,7 +11223,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "60": [ { - "commentStart": 6627, + "commentStart": 6763, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11227,7 +11234,7 @@ description: Result of parsing dual-basin-utility-sink.kcl ], "61": [ { - "commentStart": 6709, + "commentStart": 6845, "end": 0, "start": 0, "type": "NonCodeNode", @@ -11239,38 +11246,7 @@ description: Result of parsing dual-basin-utility-sink.kcl }, "startNodes": [ { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "NonCodeNode", - "value": { - "type": "blockComment", - "value": "Dual-Basin Utility Sink", - "style": "line" - } - }, - { - "commentStart": 27, - "end": 0, - "start": 0, - "type": "NonCodeNode", - "value": { - "type": "blockComment", - "value": "A stainless steel sink unit with dual rectangular basins and six under-counter storage compartments.", - "style": "line" - } - }, - { - "commentStart": 130, - "end": 0, - "start": 0, - "type": "NonCodeNode", - "value": { - "type": "newLine" - } - }, - { - "commentStart": 165, + "commentStart": 178, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/kcl_samples/enclosure/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/enclosure/artifact_commands.snap index 11a7529ad..334e24779 100644 --- a/rust/kcl-lib/tests/kcl_samples/enclosure/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/enclosure/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands enclosure.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/artifact_commands.snap index e7fea3b8a..4968f640a 100644 --- a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands exhaust-manifold.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/flange/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/flange/artifact_commands.snap index 835610aa2..c13d2870a 100644 --- a/rust/kcl-lib/tests/kcl_samples/flange/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/flange/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands flange.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/artifact_commands.snap index bc02edbea..44bcedd6c 100644 --- a/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands focusrite-scarlett-mounting-bracket.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_commands.snap index 1538a9aa0..c20d6b22b 100644 --- a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands food-service-spatula.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/french-press/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/french-press/artifact_commands.snap index 5508e13f0..3182990a1 100644 --- a/rust/kcl-lib/tests/kcl_samples/french-press/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/french-press/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands french-press.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gear-rack/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gear-rack/artifact_commands.snap index faf4d0f4c..f789357f8 100644 --- a/rust/kcl-lib/tests/kcl_samples/gear-rack/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gear-rack/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gear-rack.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gear/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gear/artifact_commands.snap index 70d533196..0097d3c9b 100644 --- a/rust/kcl-lib/tests/kcl_samples/gear/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gear/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gear.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/artifact_commands.snap index 44c76df75..7f7b50489 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gridfinity-baseplate-magnets.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/artifact_commands.snap index 84bf27b5a..2d73345a0 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gridfinity-baseplate.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/artifact_commands.snap index abaa5ce87..d0566743f 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gridfinity-bins-stacking-lip.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/artifact_commands.snap index d03ddbd80..1698809ec 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands gridfinity-bins.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/hex-nut/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/hex-nut/artifact_commands.snap index 27e46fe6a..906fc6cf7 100644 --- a/rust/kcl-lib/tests/kcl_samples/hex-nut/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/hex-nut/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands hex-nut.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap index 3f41ea273..82ddc2934 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands i-beam.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_graph_flowchart.snap.md index 2364b74d4..26a9cf10f 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_graph_flowchart.snap.md @@ -1,15 +1,15 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[469, 507, 0]"] - 3["Segment
[513, 544, 0]"] - 4["Segment
[550, 582, 0]"] - 5["Segment
[588, 638, 0]"] - 6["Segment
[644, 698, 0]"] - 7["Segment
[704, 726, 0]"] + 2["Path
[471, 509, 0]"] + 3["Segment
[515, 546, 0]"] + 4["Segment
[552, 584, 0]"] + 5["Segment
[590, 640, 0]"] + 6["Segment
[646, 700, 0]"] + 7["Segment
[706, 728, 0]"] end - 1["Plane
[445, 463, 0]"] - 8["Sweep Extrusion
[798, 826, 0]"] + 1["Plane
[447, 465, 0]"] + 8["Sweep Extrusion
[800, 828, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap b/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap index 5a8c3cd0a..81bcd767c 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap @@ -37,10 +37,10 @@ description: Result of parsing i-beam.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 203, + "commentStart": 205, "end": 0, "name": { - "commentStart": 203, + "commentStart": 205, "end": 0, "name": "ft", "start": 0, @@ -50,7 +50,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 203, + "commentStart": 205, "end": 0, "start": 0, "type": "CallExpression", @@ -73,19 +73,19 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 208, + "commentStart": 210, "declaration": { - "commentStart": 208, + "commentStart": 210, "end": 0, "id": { - "commentStart": 208, + "commentStart": 210, "end": 0, "name": "beamHeight", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 221, + "commentStart": 223, "end": 0, "raw": "4", "start": 0, @@ -106,19 +106,19 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 223, + "commentStart": 225, "declaration": { - "commentStart": 223, + "commentStart": 225, "end": 0, "id": { - "commentStart": 223, + "commentStart": 225, "end": 0, "name": "flangeWidth", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 237, + "commentStart": 239, "end": 0, "raw": "2.663", "start": 0, @@ -139,19 +139,19 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 243, + "commentStart": 245, "declaration": { - "commentStart": 243, + "commentStart": 245, "end": 0, "id": { - "commentStart": 243, + "commentStart": 245, "end": 0, "name": "flangeThickness", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 261, + "commentStart": 263, "end": 0, "raw": "0.293", "start": 0, @@ -172,19 +172,19 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 267, + "commentStart": 269, "declaration": { - "commentStart": 267, + "commentStart": 269, "end": 0, "id": { - "commentStart": 267, + "commentStart": 269, "end": 0, "name": "webThickness", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 282, + "commentStart": 284, "end": 0, "raw": "0.193", "start": 0, @@ -205,19 +205,19 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 288, + "commentStart": 290, "declaration": { - "commentStart": 288, + "commentStart": 290, "end": 0, "id": { - "commentStart": 288, + "commentStart": 290, "end": 0, "name": "rootRadius", "start": 0, "type": "Identifier" }, "init": { - "commentStart": 301, + "commentStart": 303, "end": 0, "raw": "0.457", "start": 0, @@ -238,12 +238,12 @@ description: Result of parsing i-beam.kcl "type": "VariableDeclaration" }, { - "commentStart": 306, + "commentStart": 308, "declaration": { - "commentStart": 433, + "commentStart": 435, "end": 0, "id": { - "commentStart": 433, + "commentStart": 435, "end": 0, "name": "sketch001", "start": 0, @@ -256,10 +256,10 @@ description: Result of parsing i-beam.kcl { "argument": { "abs_path": false, - "commentStart": 460, + "commentStart": 462, "end": 0, "name": { - "commentStart": 460, + "commentStart": 462, "end": 0, "name": "XZ", "start": 0, @@ -270,7 +270,7 @@ description: Result of parsing i-beam.kcl "type": "Name", "type": "Name" }, - "commentStart": 459, + "commentStart": 461, "end": 0, "operator": "-", "start": 0, @@ -280,10 +280,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 445, + "commentStart": 447, "end": 0, "name": { - "commentStart": 445, + "commentStart": 447, "end": 0, "name": "startSketchOn", "start": 0, @@ -293,7 +293,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 445, + "commentStart": 447, "end": 0, "start": 0, "type": "CallExpression", @@ -302,10 +302,10 @@ description: Result of parsing i-beam.kcl { "arguments": [ { - "commentStart": 484, + "commentStart": 486, "elements": [ { - "commentStart": 485, + "commentStart": 487, "end": 0, "raw": "0", "start": 0, @@ -317,14 +317,14 @@ description: Result of parsing i-beam.kcl } }, { - "commentStart": 488, + "commentStart": 490, "end": 0, "left": { "abs_path": false, - "commentStart": 488, + "commentStart": 490, "end": 0, "name": { - "commentStart": 488, + "commentStart": 490, "end": 0, "name": "beamHeight", "start": 0, @@ -337,7 +337,7 @@ description: Result of parsing i-beam.kcl }, "operator": "/", "right": { - "commentStart": 501, + "commentStart": 503, "end": 0, "raw": "2", "start": 0, @@ -359,7 +359,7 @@ description: Result of parsing i-beam.kcl "type": "ArrayExpression" }, { - "commentStart": 505, + "commentStart": 507, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -368,10 +368,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 469, + "commentStart": 471, "end": 0, "name": { - "commentStart": 469, + "commentStart": 471, "end": 0, "name": "startProfileAt", "start": 0, @@ -381,7 +381,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 469, + "commentStart": 471, "end": 0, "start": 0, "type": "CallExpression", @@ -392,21 +392,21 @@ description: Result of parsing i-beam.kcl { "type": "LabeledArg", "label": { - "commentStart": 519, + "commentStart": 521, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 528, + "commentStart": 530, "end": 0, "left": { "abs_path": false, - "commentStart": 528, + "commentStart": 530, "end": 0, "name": { - "commentStart": 528, + "commentStart": 530, "end": 0, "name": "flangeWidth", "start": 0, @@ -419,7 +419,7 @@ description: Result of parsing i-beam.kcl }, "operator": "/", "right": { - "commentStart": 542, + "commentStart": 544, "end": 0, "raw": "2", "start": 0, @@ -438,10 +438,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 513, + "commentStart": 515, "end": 0, "name": { - "commentStart": 513, + "commentStart": 515, "end": 0, "name": "xLine", "start": 0, @@ -451,7 +451,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 513, + "commentStart": 515, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -463,7 +463,7 @@ description: Result of parsing i-beam.kcl { "type": "LabeledArg", "label": { - "commentStart": 556, + "commentStart": 558, "end": 0, "name": "length", "start": 0, @@ -472,10 +472,10 @@ description: Result of parsing i-beam.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 566, + "commentStart": 568, "end": 0, "name": { - "commentStart": 566, + "commentStart": 568, "end": 0, "name": "flangeThickness", "start": 0, @@ -486,7 +486,7 @@ description: Result of parsing i-beam.kcl "type": "Name", "type": "Name" }, - "commentStart": 565, + "commentStart": 567, "end": 0, "operator": "-", "start": 0, @@ -497,10 +497,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 550, + "commentStart": 552, "end": 0, "name": { - "commentStart": 550, + "commentStart": 552, "end": 0, "name": "yLine", "start": 0, @@ -510,7 +510,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 550, + "commentStart": 552, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -522,24 +522,24 @@ description: Result of parsing i-beam.kcl { "type": "LabeledArg", "label": { - "commentStart": 594, + "commentStart": 596, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 608, + "commentStart": 610, "end": 0, "left": { - "commentStart": 608, + "commentStart": 610, "end": 0, "left": { "abs_path": false, - "commentStart": 608, + "commentStart": 610, "end": 0, "name": { - "commentStart": 608, + "commentStart": 610, "end": 0, "name": "webThickness", "start": 0, @@ -552,7 +552,7 @@ description: Result of parsing i-beam.kcl }, "operator": "/", "right": { - "commentStart": 623, + "commentStart": 625, "end": 0, "raw": "2", "start": 0, @@ -570,10 +570,10 @@ description: Result of parsing i-beam.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 627, + "commentStart": 629, "end": 0, "name": { - "commentStart": 627, + "commentStart": 629, "end": 0, "name": "rootRadius", "start": 0, @@ -592,10 +592,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 588, + "commentStart": 590, "end": 0, "name": { - "commentStart": 588, + "commentStart": 590, "end": 0, "name": "xLine", "start": 0, @@ -605,7 +605,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 588, + "commentStart": 590, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -615,14 +615,14 @@ description: Result of parsing i-beam.kcl { "arguments": [ { - "commentStart": 658, + "commentStart": 660, "end": 0, "properties": [ { - "commentStart": 660, + "commentStart": 662, "end": 0, "key": { - "commentStart": 660, + "commentStart": 662, "end": 0, "name": "radius", "start": 0, @@ -632,10 +632,10 @@ description: Result of parsing i-beam.kcl "type": "ObjectProperty", "value": { "abs_path": false, - "commentStart": 669, + "commentStart": 671, "end": 0, "name": { - "commentStart": 669, + "commentStart": 671, "end": 0, "name": "rootRadius", "start": 0, @@ -648,10 +648,10 @@ description: Result of parsing i-beam.kcl } }, { - "commentStart": 681, + "commentStart": 683, "end": 0, "key": { - "commentStart": 681, + "commentStart": 683, "end": 0, "name": "offset", "start": 0, @@ -660,7 +660,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 690, + "commentStart": 692, "end": 0, "raw": "90", "start": 0, @@ -678,7 +678,7 @@ description: Result of parsing i-beam.kcl "type": "ObjectExpression" }, { - "commentStart": 696, + "commentStart": 698, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -687,10 +687,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 644, + "commentStart": 646, "end": 0, "name": { - "commentStart": 644, + "commentStart": 646, "end": 0, "name": "tangentialArc", "start": 0, @@ -700,7 +700,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 644, + "commentStart": 646, "end": 0, "start": 0, "type": "CallExpression", @@ -711,14 +711,14 @@ description: Result of parsing i-beam.kcl { "type": "LabeledArg", "label": { - "commentStart": 710, + "commentStart": 712, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 724, + "commentStart": 726, "end": 0, "raw": "0", "start": 0, @@ -733,10 +733,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 704, + "commentStart": 706, "end": 0, "name": { - "commentStart": 704, + "commentStart": 706, "end": 0, "name": "yLine", "start": 0, @@ -746,7 +746,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 704, + "commentStart": 706, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -756,14 +756,14 @@ description: Result of parsing i-beam.kcl { "arguments": [ { - "commentStart": 741, + "commentStart": 743, "end": 0, "properties": [ { - "commentStart": 743, + "commentStart": 745, "end": 0, "key": { - "commentStart": 743, + "commentStart": 745, "end": 0, "name": "axis", "start": 0, @@ -772,7 +772,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 750, + "commentStart": 752, "end": 0, "raw": "'X'", "start": 0, @@ -787,7 +787,7 @@ description: Result of parsing i-beam.kcl "type": "ObjectExpression" }, { - "commentStart": 757, + "commentStart": 759, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -796,10 +796,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 732, + "commentStart": 734, "end": 0, "name": { - "commentStart": 732, + "commentStart": 734, "end": 0, "name": "mirror2d", "start": 0, @@ -809,7 +809,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 732, + "commentStart": 734, "end": 0, "start": 0, "type": "CallExpression", @@ -818,14 +818,14 @@ description: Result of parsing i-beam.kcl { "arguments": [ { - "commentStart": 774, + "commentStart": 776, "end": 0, "properties": [ { - "commentStart": 776, + "commentStart": 778, "end": 0, "key": { - "commentStart": 776, + "commentStart": 778, "end": 0, "name": "axis", "start": 0, @@ -834,7 +834,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 783, + "commentStart": 785, "end": 0, "raw": "'Y'", "start": 0, @@ -849,7 +849,7 @@ description: Result of parsing i-beam.kcl "type": "ObjectExpression" }, { - "commentStart": 790, + "commentStart": 792, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -858,10 +858,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 765, + "commentStart": 767, "end": 0, "name": { - "commentStart": 765, + "commentStart": 767, "end": 0, "name": "mirror2d", "start": 0, @@ -871,7 +871,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 765, + "commentStart": 767, "end": 0, "start": 0, "type": "CallExpression", @@ -882,7 +882,7 @@ description: Result of parsing i-beam.kcl { "type": "LabeledArg", "label": { - "commentStart": 806, + "commentStart": 808, "end": 0, "name": "length", "start": 0, @@ -890,10 +890,10 @@ description: Result of parsing i-beam.kcl }, "arg": { "abs_path": false, - "commentStart": 815, + "commentStart": 817, "end": 0, "name": { - "commentStart": 815, + "commentStart": 817, "end": 0, "name": "beamLength", "start": 0, @@ -908,10 +908,10 @@ description: Result of parsing i-beam.kcl ], "callee": { "abs_path": false, - "commentStart": 798, + "commentStart": 800, "end": 0, "name": { - "commentStart": 798, + "commentStart": 800, "end": 0, "name": "extrude", "start": 0, @@ -921,7 +921,7 @@ description: Result of parsing i-beam.kcl "start": 0, "type": "Name" }, - "commentStart": 798, + "commentStart": 800, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -929,7 +929,7 @@ description: Result of parsing i-beam.kcl "unlabeled": null } ], - "commentStart": 445, + "commentStart": 447, "end": 0, "start": 0, "type": "PipeExpression", @@ -1021,4 +1021,4 @@ description: Result of parsing i-beam.kcl }, "start": 0 } -} \ No newline at end of file +} diff --git a/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_commands.snap index 704efd8f5..b715a9bec 100644 --- a/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands keyboard.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/kitt/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/kitt/artifact_commands.snap index 31d5fbc5e..27f8b072f 100644 --- a/rust/kcl-lib/tests/kcl_samples/kitt/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/kitt/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kitt.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/lego/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/lego/artifact_commands.snap index 181d73a78..c00b95574 100644 --- a/rust/kcl-lib/tests/kcl_samples/lego/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/lego/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands lego.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_commands.snap index 714331e8b..938ecf4ba 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands makeup-mirror.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_graph_flowchart.snap.md index 563ec92d4..0c5243f57 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/artifact_graph_flowchart.snap.md @@ -46,17 +46,17 @@ flowchart LR 84[Solid2d] end subgraph path92 [Path] - 92["Path
[1553, 1616, 0]"] - 93["Segment
[1553, 1616, 0]"] + 92["Path
[1555, 1618, 0]"] + 93["Segment
[1555, 1618, 0]"] 94[Solid2d] end subgraph path101 [Path] - 101["Path
[1662, 1716, 0]"] - 102["Segment
[1724, 1748, 0]"] - 103["Segment
[1756, 1870, 0]"] - 104["Segment
[1878, 1902, 0]"] - 105["Segment
[1910, 2041, 0]"] - 106["Segment
[2049, 2056, 0]"] + 101["Path
[1664, 1720, 0]"] + 102["Segment
[1728, 1752, 0]"] + 103["Segment
[1760, 1878, 0]"] + 104["Segment
[1886, 1910, 0]"] + 105["Segment
[1918, 2086, 0]"] + 106["Segment
[2094, 2101, 0]"] 107[Solid2d] end 1["Plane
[484, 511, 0]"] @@ -122,14 +122,14 @@ flowchart LR 88["Cap End"] 89["SweepEdge Opposite"] 90["SweepEdge Adjacent"] - 91["Plane
[1489, 1539, 0]"] - 95["Sweep Extrusion
[1624, 1647, 0]"] + 91["Plane
[1491, 1541, 0]"] + 95["Sweep Extrusion
[1626, 1649, 0]"] 96[Wall] 97["Cap Start"] 98["Cap End"] 99["SweepEdge Opposite"] 100["SweepEdge Adjacent"] - 108["Sweep Extrusion
[2064, 2087, 0]"] + 108["Sweep Extrusion
[2109, 2132, 0]"] 109[Wall] 110[Wall] 111[Wall] @@ -151,7 +151,7 @@ flowchart LR 127["StartSketchOnPlane
[470, 512, 0]"] 128["StartSketchOnPlane
[470, 512, 0]"] 129["StartSketchOnPlane
[470, 512, 0]"] - 130["StartSketchOnPlane
[1475, 1540, 0]"] + 130["StartSketchOnPlane
[1475, 1542, 0]"] 1 --- 2 2 --- 3 2 ---- 5 diff --git a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap index 4c7510d45..f86ac1796 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap @@ -2366,21 +2366,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1508, + "commentStart": 1510, "end": 0, "name": "offset", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1517, + "commentStart": 1519, "end": 0, "left": { "abs_path": false, - "commentStart": 1517, + "commentStart": 1519, "end": 0, "name": { - "commentStart": 1517, + "commentStart": 1519, "end": 0, "name": "offsetY", "start": 0, @@ -2393,14 +2393,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "-", "right": { - "commentStart": 1528, + "commentStart": 1530, "end": 0, "left": { "abs_path": false, - "commentStart": 1528, + "commentStart": 1530, "end": 0, "name": { - "commentStart": 1528, + "commentStart": 1530, "end": 0, "name": "tiefe", "start": 0, @@ -2413,7 +2413,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "/", "right": { - "commentStart": 1536, + "commentStart": 1538, "end": 0, "raw": "2", "start": 0, @@ -2436,10 +2436,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1489, + "commentStart": 1491, "end": 0, "name": { - "commentStart": 1489, + "commentStart": 1491, "end": 0, "name": "offsetPlane", "start": 0, @@ -2449,17 +2449,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1489, + "commentStart": 1491, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1501, + "commentStart": 1503, "end": 0, "name": { - "commentStart": 1501, + "commentStart": 1503, "end": 0, "name": "plane", "start": 0, @@ -2503,12 +2503,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1543, + "commentStart": 1545, "declaration": { - "commentStart": 1543, + "commentStart": 1545, "end": 0, "id": { - "commentStart": 1543, + "commentStart": 1545, "end": 0, "name": "armBody", "start": 0, @@ -2521,21 +2521,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1570, + "commentStart": 1572, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1579, + "commentStart": 1581, "elements": [ { "abs_path": false, - "commentStart": 1580, + "commentStart": 1582, "end": 0, "name": { - "commentStart": 1580, + "commentStart": 1582, "end": 0, "name": "offsetX", "start": 0, @@ -2548,10 +2548,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1589, + "commentStart": 1591, "end": 0, "name": { - "commentStart": 1589, + "commentStart": 1591, "end": 0, "name": "altitude", "start": 0, @@ -2572,7 +2572,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1600, + "commentStart": 1602, "end": 0, "name": "radius", "start": 0, @@ -2580,10 +2580,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1609, + "commentStart": 1611, "end": 0, "name": { - "commentStart": 1609, + "commentStart": 1611, "end": 0, "name": "radius", "start": 0, @@ -2598,10 +2598,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1553, + "commentStart": 1555, "end": 0, "name": { - "commentStart": 1553, + "commentStart": 1555, "end": 0, "name": "circle", "start": 0, @@ -2611,17 +2611,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1553, + "commentStart": 1555, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1560, + "commentStart": 1562, "end": 0, "name": { - "commentStart": 1560, + "commentStart": 1562, "end": 0, "name": "armPlane", "start": 0, @@ -2638,7 +2638,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1632, + "commentStart": 1634, "end": 0, "name": "length", "start": 0, @@ -2646,10 +2646,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1641, + "commentStart": 1643, "end": 0, "name": { - "commentStart": 1641, + "commentStart": 1643, "end": 0, "name": "tiefe", "start": 0, @@ -2664,10 +2664,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1624, + "commentStart": 1626, "end": 0, "name": { - "commentStart": 1624, + "commentStart": 1626, "end": 0, "name": "extrude", "start": 0, @@ -2677,7 +2677,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1624, + "commentStart": 1626, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2685,7 +2685,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 1553, + "commentStart": 1555, "end": 0, "start": 0, "type": "PipeExpression", @@ -2701,12 +2701,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1647, + "commentStart": 1649, "declaration": { - "commentStart": 1651, + "commentStart": 1653, "end": 0, "id": { - "commentStart": 1651, + "commentStart": 1653, "end": 0, "name": "archBody", "start": 0, @@ -2717,17 +2717,17 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 1677, + "commentStart": 1679, "elements": [ { - "commentStart": 1678, + "commentStart": 1680, "end": 0, "left": { "abs_path": false, - "commentStart": 1678, + "commentStart": 1680, "end": 0, "name": { - "commentStart": 1678, + "commentStart": 1680, "end": 0, "name": "offsetX", "start": 0, @@ -2741,10 +2741,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1686, + "commentStart": 1690, "end": 0, "name": { - "commentStart": 1686, + "commentStart": 1690, "end": 0, "name": "gestellR", "start": 0, @@ -2761,10 +2761,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1696, + "commentStart": 1700, "end": 0, "name": { - "commentStart": 1696, + "commentStart": 1700, "end": 0, "name": "altitude", "start": 0, @@ -2783,10 +2783,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1707, + "commentStart": 1711, "end": 0, "name": { - "commentStart": 1707, + "commentStart": 1711, "end": 0, "name": "armPlane", "start": 0, @@ -2800,10 +2800,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1662, + "commentStart": 1664, "end": 0, "name": { - "commentStart": 1662, + "commentStart": 1664, "end": 0, "name": "startProfileAt", "start": 0, @@ -2813,7 +2813,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1662, + "commentStart": 1664, "end": 0, "start": 0, "type": "CallExpression", @@ -2824,7 +2824,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1730, + "commentStart": 1734, "end": 0, "name": "length", "start": 0, @@ -2832,10 +2832,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1739, + "commentStart": 1743, "end": 0, "name": { - "commentStart": 1739, + "commentStart": 1743, "end": 0, "name": "gestellD", "start": 0, @@ -2850,10 +2850,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1724, + "commentStart": 1728, "end": 0, "name": { - "commentStart": 1724, + "commentStart": 1728, "end": 0, "name": "xLine", "start": 0, @@ -2863,7 +2863,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1724, + "commentStart": 1728, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2873,14 +2873,14 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 1762, + "commentStart": 1766, "end": 0, "properties": [ { - "commentStart": 1773, + "commentStart": 1777, "end": 0, "key": { - "commentStart": 1773, + "commentStart": 1777, "end": 0, "name": "interior", "start": 0, @@ -2889,14 +2889,14 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1784, + "commentStart": 1788, "elements": [ { "abs_path": false, - "commentStart": 1785, + "commentStart": 1789, "end": 0, "name": { - "commentStart": 1785, + "commentStart": 1789, "end": 0, "name": "offsetX", "start": 0, @@ -2908,14 +2908,14 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 1794, + "commentStart": 1798, "end": 0, "left": { "abs_path": false, - "commentStart": 1794, + "commentStart": 1798, "end": 0, "name": { - "commentStart": 1794, + "commentStart": 1798, "end": 0, "name": "altitude", "start": 0, @@ -2929,10 +2929,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1803, + "commentStart": 1809, "end": 0, "name": { - "commentStart": 1803, + "commentStart": 1809, "end": 0, "name": "gestellR", "start": 0, @@ -2955,10 +2955,10 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 1823, + "commentStart": 1829, "end": 0, "key": { - "commentStart": 1823, + "commentStart": 1829, "end": 0, "name": "end", "start": 0, @@ -2967,17 +2967,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1829, + "commentStart": 1835, "elements": [ { - "commentStart": 1830, + "commentStart": 1836, "end": 0, "left": { "abs_path": false, - "commentStart": 1830, + "commentStart": 1836, "end": 0, "name": { - "commentStart": 1830, + "commentStart": 1836, "end": 0, "name": "offsetX", "start": 0, @@ -2991,10 +2991,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1838, + "commentStart": 1846, "end": 0, "name": { - "commentStart": 1838, + "commentStart": 1846, "end": 0, "name": "gestellR", "start": 0, @@ -3011,10 +3011,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1848, + "commentStart": 1856, "end": 0, "name": { - "commentStart": 1848, + "commentStart": 1856, "end": 0, "name": "altitude", "start": 0, @@ -3038,7 +3038,7 @@ description: Result of parsing makeup-mirror.kcl "type": "ObjectExpression" }, { - "commentStart": 1868, + "commentStart": 1876, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3047,10 +3047,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1756, + "commentStart": 1760, "end": 0, "name": { - "commentStart": 1756, + "commentStart": 1760, "end": 0, "name": "arcTo", "start": 0, @@ -3060,7 +3060,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1756, + "commentStart": 1760, "end": 0, "start": 0, "type": "CallExpression", @@ -3071,7 +3071,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1884, + "commentStart": 1892, "end": 0, "name": "length", "start": 0, @@ -3079,10 +3079,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1893, + "commentStart": 1901, "end": 0, "name": { - "commentStart": 1893, + "commentStart": 1901, "end": 0, "name": "gestellD", "start": 0, @@ -3097,10 +3097,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1878, + "commentStart": 1886, "end": 0, "name": { - "commentStart": 1878, + "commentStart": 1886, "end": 0, "name": "xLine", "start": 0, @@ -3110,7 +3110,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1878, + "commentStart": 1886, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3120,14 +3120,14 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 1916, + "commentStart": 1924, "end": 0, "properties": [ { - "commentStart": 1927, + "commentStart": 1935, "end": 0, "key": { - "commentStart": 1927, + "commentStart": 1935, "end": 0, "name": "interior", "start": 0, @@ -3136,14 +3136,14 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1938, + "commentStart": 1946, "elements": [ { "abs_path": false, - "commentStart": 1939, + "commentStart": 1959, "end": 0, "name": { - "commentStart": 1939, + "commentStart": 1959, "end": 0, "name": "offsetX", "start": 0, @@ -3155,17 +3155,17 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 1948, + "commentStart": 1979, "end": 0, "left": { - "commentStart": 1948, + "commentStart": 1979, "end": 0, "left": { "abs_path": false, - "commentStart": 1948, + "commentStart": 1979, "end": 0, "name": { - "commentStart": 1948, + "commentStart": 1979, "end": 0, "name": "altitude", "start": 0, @@ -3179,10 +3179,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1957, + "commentStart": 1990, "end": 0, "name": { - "commentStart": 1957, + "commentStart": 1990, "end": 0, "name": "gestellR", "start": 0, @@ -3200,10 +3200,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1966, + "commentStart": 2001, "end": 0, "name": { - "commentStart": 1966, + "commentStart": 2001, "end": 0, "name": "gestellD", "start": 0, @@ -3226,10 +3226,10 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 1986, + "commentStart": 2031, "end": 0, "key": { - "commentStart": 1986, + "commentStart": 2031, "end": 0, "name": "end", "start": 0, @@ -3238,12 +3238,12 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1992, + "commentStart": 2037, "elements": [ { "arguments": [ { - "commentStart": 2007, + "commentStart": 2052, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3252,10 +3252,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1993, + "commentStart": 2038, "end": 0, "name": { - "commentStart": 1993, + "commentStart": 2038, "end": 0, "name": "profileStartX", "start": 0, @@ -3265,7 +3265,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1993, + "commentStart": 2038, "end": 0, "start": 0, "type": "CallExpression", @@ -3274,7 +3274,7 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 2025, + "commentStart": 2070, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3283,10 +3283,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2011, + "commentStart": 2056, "end": 0, "name": { - "commentStart": 2011, + "commentStart": 2056, "end": 0, "name": "profileStartY", "start": 0, @@ -3296,7 +3296,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2011, + "commentStart": 2056, "end": 0, "start": 0, "type": "CallExpression", @@ -3315,7 +3315,7 @@ description: Result of parsing makeup-mirror.kcl "type": "ObjectExpression" }, { - "commentStart": 2039, + "commentStart": 2084, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3324,10 +3324,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1910, + "commentStart": 1918, "end": 0, "name": { - "commentStart": 1910, + "commentStart": 1918, "end": 0, "name": "arcTo", "start": 0, @@ -3337,7 +3337,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1910, + "commentStart": 1918, "end": 0, "start": 0, "type": "CallExpression", @@ -3347,10 +3347,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2049, + "commentStart": 2094, "end": 0, "name": { - "commentStart": 2049, + "commentStart": 2094, "end": 0, "name": "close", "start": 0, @@ -3360,7 +3360,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2049, + "commentStart": 2094, "end": 0, "start": 0, "type": "CallExpression", @@ -3371,7 +3371,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 2072, + "commentStart": 2117, "end": 0, "name": "length", "start": 0, @@ -3379,10 +3379,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 2081, + "commentStart": 2126, "end": 0, "name": { - "commentStart": 2081, + "commentStart": 2126, "end": 0, "name": "tiefe", "start": 0, @@ -3397,10 +3397,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2064, + "commentStart": 2109, "end": 0, "name": { - "commentStart": 2064, + "commentStart": 2109, "end": 0, "name": "extrude", "start": 0, @@ -3410,7 +3410,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2064, + "commentStart": 2109, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3418,7 +3418,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 1662, + "commentStart": 1664, "end": 0, "start": 0, "type": "PipeExpression", @@ -3436,10 +3436,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 2097, + "commentStart": 2142, "end": 0, "name": { - "commentStart": 2097, + "commentStart": 2142, "end": 0, "name": "armBody", "start": 0, @@ -3450,7 +3450,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 2090, + "commentStart": 2135, "end": 0, "start": 0, "type": "ReturnStatement", @@ -3463,7 +3463,7 @@ description: Result of parsing makeup-mirror.kcl "nonCodeNodes": { "1": [ { - "commentStart": 1647, + "commentStart": 1649, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3580,12 +3580,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 2106, + "commentStart": 2151, "declaration": { - "commentStart": 2108, + "commentStart": 2153, "end": 0, "id": { - "commentStart": 2108, + "commentStart": 2153, "end": 0, "name": "mirror", "start": 0, @@ -3595,10 +3595,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 2126, + "commentStart": 2171, "end": 0, "name": { - "commentStart": 2126, + "commentStart": 2171, "end": 0, "name": "XZ", "start": 0, @@ -3611,10 +3611,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2130, + "commentStart": 2175, "end": 0, "name": { - "commentStart": 2130, + "commentStart": 2175, "end": 0, "name": "armLength", "start": 0, @@ -3627,10 +3627,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2141, + "commentStart": 2186, "end": 0, "name": { - "commentStart": 2141, + "commentStart": 2186, "end": 0, "name": "armLength", "start": 0, @@ -3642,26 +3642,26 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "left": { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "left": { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "left": { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "left": { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "left": { "abs_path": false, - "commentStart": 2152, + "commentStart": 2197, "end": 0, "name": { - "commentStart": 2152, + "commentStart": 2197, "end": 0, "name": "hingeHeight", "start": 0, @@ -3674,7 +3674,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 2166, + "commentStart": 2211, "end": 0, "raw": "4", "start": 0, @@ -3691,14 +3691,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 2170, + "commentStart": 2215, "end": 0, "left": { "abs_path": false, - "commentStart": 2170, + "commentStart": 2215, "end": 0, "name": { - "commentStart": 2170, + "commentStart": 2215, "end": 0, "name": "hingeGap", "start": 0, @@ -3711,7 +3711,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 2181, + "commentStart": 2226, "end": 0, "raw": "3", "start": 0, @@ -3733,10 +3733,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2185, + "commentStart": 2230, "end": 0, "name": { - "commentStart": 2185, + "commentStart": 2230, "end": 0, "name": "mirrorRadius", "start": 0, @@ -3754,10 +3754,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2198, + "commentStart": 2245, "end": 0, "name": { - "commentStart": 2198, + "commentStart": 2245, "end": 0, "name": "archToMirrorGap", "start": 0, @@ -3775,10 +3775,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2214, + "commentStart": 2263, "end": 0, "name": { - "commentStart": 2214, + "commentStart": 2263, "end": 0, "name": "archThickness", "start": 0, @@ -3795,10 +3795,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2229, + "commentStart": 2278, "end": 0, "name": { - "commentStart": 2229, + "commentStart": 2278, "end": 0, "name": "mirrorRadius", "start": 0, @@ -3811,10 +3811,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2243, + "commentStart": 2292, "end": 0, "name": { - "commentStart": 2243, + "commentStart": 2292, "end": 0, "name": "mirrorThickness", "start": 0, @@ -3827,10 +3827,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2260, + "commentStart": 2309, "end": 0, "name": { - "commentStart": 2260, + "commentStart": 2309, "end": 0, "name": "archRadius", "start": 0, @@ -3843,10 +3843,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2272, + "commentStart": 2321, "end": 0, "name": { - "commentStart": 2272, + "commentStart": 2321, "end": 0, "name": "archThickness", "start": 0, @@ -3860,10 +3860,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2117, + "commentStart": 2162, "end": 0, "name": { - "commentStart": 2117, + "commentStart": 2162, "end": 0, "name": "mirrorFn", "start": 0, @@ -3873,7 +3873,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2117, + "commentStart": 2162, "end": 0, "start": 0, "type": "CallExpression", @@ -3992,7 +3992,7 @@ description: Result of parsing makeup-mirror.kcl ], "21": [ { - "commentStart": 2106, + "commentStart": 2151, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap index b9491ee07..142513c1d 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap @@ -1280,7 +1280,7 @@ description: Operations executed makeup-mirror.kcl "name": "mirrorFn", "functionSourceRange": [ 1389, - 2106, + 2151, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/mounting-plate/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/mounting-plate/artifact_commands.snap index b034772b3..327e110dc 100644 --- a/rust/kcl-lib/tests/kcl_samples/mounting-plate/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/mounting-plate/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands mounting-plate.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_commands.snap index 5770ab7b0..8ad94c113 100644 --- a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands multi-axis-robot.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_graph_flowchart.snap.md index b86bb5258..ee2173e4c 100644 --- a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/artifact_graph_flowchart.snap.md @@ -1,162 +1,162 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[224, 279, 4]"] - 3["Segment
[285, 347, 4]"] - 4["Segment
[353, 468, 4]"] - 5["Segment
[474, 594, 4]"] - 6["Segment
[600, 685, 4]"] - 7["Segment
[691, 698, 4]"] + 2["Path
[224, 279, 5]"] + 3["Segment
[285, 347, 5]"] + 4["Segment
[353, 468, 5]"] + 5["Segment
[474, 594, 5]"] + 6["Segment
[600, 685, 5]"] + 7["Segment
[691, 698, 5]"] 8[Solid2d] end subgraph path28 [Path] - 28["Path
[1134, 1191, 4]"] - 29["Segment
[1134, 1191, 4]"] + 28["Path
[1134, 1191, 5]"] + 29["Segment
[1134, 1191, 5]"] 30[Solid2d] end subgraph path36 [Path] - 36["Path
[1389, 1426, 4]"] - 37["Segment
[1389, 1426, 4]"] + 36["Path
[1389, 1426, 5]"] + 37["Segment
[1389, 1426, 5]"] 38[Solid2d] end subgraph path44 [Path] - 44["Path
[1558, 1698, 4]"] - 45["Segment
[1558, 1698, 4]"] + 44["Path
[1558, 1698, 5]"] + 45["Segment
[1558, 1698, 5]"] 46[Solid2d] end subgraph path54 [Path] - 54["Path
[1944, 2084, 4]"] - 55["Segment
[1944, 2084, 4]"] + 54["Path
[1944, 2084, 5]"] + 55["Segment
[1944, 2084, 5]"] 56[Solid2d] end subgraph path65 [Path] - 65["Path
[203, 263, 5]"] - 66["Segment
[203, 263, 5]"] + 65["Path
[203, 263, 6]"] + 66["Segment
[203, 263, 6]"] 67[Solid2d] end subgraph path75 [Path] - 75["Path
[493, 529, 5]"] - 76["Segment
[535, 579, 5]"] - 77["Segment
[585, 673, 5]"] - 78["Segment
[679, 728, 5]"] - 79["Segment
[734, 790, 5]"] - 80["Segment
[796, 803, 5]"] + 75["Path
[493, 529, 6]"] + 76["Segment
[535, 579, 6]"] + 77["Segment
[585, 673, 6]"] + 78["Segment
[679, 728, 6]"] + 79["Segment
[734, 790, 6]"] + 80["Segment
[796, 803, 6]"] 81[Solid2d] end subgraph path97 [Path] - 97["Path
[900, 1075, 5]"] - 98["Segment
[900, 1075, 5]"] + 97["Path
[900, 1075, 6]"] + 98["Segment
[900, 1075, 6]"] 99[Solid2d] end subgraph path105 [Path] - 105["Path
[1279, 1426, 5]"] - 106["Segment
[1279, 1426, 5]"] + 105["Path
[1279, 1426, 6]"] + 106["Segment
[1279, 1426, 6]"] 107[Solid2d] end subgraph path116 [Path] - 116["Path
[1743, 1917, 5]"] - 117["Segment
[1743, 1917, 5]"] + 116["Path
[1743, 1917, 6]"] + 117["Segment
[1743, 1917, 6]"] 118[Solid2d] end subgraph path125 [Path] - 125["Path
[2142, 2182, 5]"] - 126["Segment
[2142, 2182, 5]"] + 125["Path
[2142, 2182, 6]"] + 126["Segment
[2142, 2182, 6]"] 127[Solid2d] end subgraph path137 [Path] - 137["Path
[251, 394, 6]"] - 138["Segment
[400, 516, 6]"] - 139["Segment
[522, 600, 6]"] - 140["Segment
[606, 722, 6]"] - 141["Segment
[728, 784, 6]"] - 142["Segment
[790, 797, 6]"] + 137["Path
[251, 394, 7]"] + 138["Segment
[400, 516, 7]"] + 139["Segment
[522, 600, 7]"] + 140["Segment
[606, 722, 7]"] + 141["Segment
[728, 784, 7]"] + 142["Segment
[790, 797, 7]"] 143[Solid2d] end subgraph path159 [Path] - 159["Path
[913, 977, 6]"] - 160["Segment
[913, 977, 6]"] + 159["Path
[913, 977, 7]"] + 160["Segment
[913, 977, 7]"] 161[Solid2d] end subgraph path167 [Path] - 167["Path
[1146, 1354, 6]"] - 168["Segment
[1146, 1354, 6]"] + 167["Path
[1146, 1354, 7]"] + 168["Segment
[1146, 1354, 7]"] 169[Solid2d] end subgraph path175 [Path] - 175["Path
[1557, 1601, 6]"] - 176["Segment
[1557, 1601, 6]"] + 175["Path
[1557, 1601, 7]"] + 176["Segment
[1557, 1601, 7]"] 177[Solid2d] end subgraph path190 [Path] - 190["Path
[1839, 2031, 6]"] - 191["Segment
[1839, 2031, 6]"] + 190["Path
[1839, 2031, 7]"] + 191["Segment
[1839, 2031, 7]"] 192[Solid2d] end subgraph path201 [Path] - 201["Path
[2384, 2559, 6]"] - 202["Segment
[2384, 2559, 6]"] + 201["Path
[2384, 2559, 7]"] + 202["Segment
[2384, 2559, 7]"] 203[Solid2d] end subgraph path210 [Path] - 210["Path
[271, 504, 7]"] - 211["Segment
[510, 629, 7]"] - 212["Segment
[635, 715, 7]"] - 213["Segment
[721, 840, 7]"] - 214["Segment
[846, 916, 7]"] - 215["Segment
[922, 929, 7]"] + 210["Path
[271, 504, 8]"] + 211["Segment
[510, 629, 8]"] + 212["Segment
[635, 715, 8]"] + 213["Segment
[721, 840, 8]"] + 214["Segment
[846, 916, 8]"] + 215["Segment
[922, 929, 8]"] 216[Solid2d] end subgraph path232 [Path] - 232["Path
[1043, 1252, 7]"] - 233["Segment
[1043, 1252, 7]"] + 232["Path
[1043, 1252, 8]"] + 233["Segment
[1043, 1252, 8]"] 234[Solid2d] end subgraph path240 [Path] - 240["Path
[1457, 1646, 7]"] - 241["Segment
[1457, 1646, 7]"] + 240["Path
[1457, 1646, 8]"] + 241["Segment
[1457, 1646, 8]"] 242[Solid2d] end subgraph path255 [Path] - 255["Path
[2067, 2353, 7]"] - 256["Segment
[2067, 2353, 7]"] + 255["Path
[2067, 2353, 8]"] + 256["Segment
[2067, 2353, 8]"] 257[Solid2d] end subgraph path264 [Path] - 264["Path
[2452, 2736, 7]"] - 265["Segment
[2452, 2736, 7]"] + 264["Path
[2452, 2736, 8]"] + 265["Segment
[2452, 2736, 8]"] 266[Solid2d] end subgraph path273 [Path] - 273["Path
[2890, 2928, 7]"] - 274["Segment
[2890, 2928, 7]"] + 273["Path
[2890, 2928, 8]"] + 274["Segment
[2890, 2928, 8]"] 275[Solid2d] end subgraph path282 [Path] - 282["Path
[3058, 3283, 7]"] - 283["Segment
[3289, 3383, 7]"] - 284["Segment
[3389, 3532, 7]"] - 285["Segment
[3538, 3632, 7]"] - 286["Segment
[3638, 3740, 7]"] - 287["Segment
[3746, 3848, 7]"] - 288["Segment
[3854, 3954, 7]"] - 289["Segment
[3960, 4016, 7]"] - 290["Segment
[4022, 4029, 7]"] + 282["Path
[3058, 3283, 8]"] + 283["Segment
[3289, 3383, 8]"] + 284["Segment
[3389, 3532, 8]"] + 285["Segment
[3538, 3632, 8]"] + 286["Segment
[3638, 3740, 8]"] + 287["Segment
[3746, 3848, 8]"] + 288["Segment
[3854, 3954, 8]"] + 289["Segment
[3960, 4016, 8]"] + 290["Segment
[4022, 4029, 8]"] 291[Solid2d] end subgraph path316 [Path] - 316["Path
[4158, 4383, 7]"] - 317["Segment
[4389, 4485, 7]"] - 318["Segment
[4491, 4639, 7]"] - 319["Segment
[4645, 4741, 7]"] - 320["Segment
[4747, 4851, 7]"] - 321["Segment
[4857, 4961, 7]"] - 322["Segment
[4967, 5069, 7]"] - 323["Segment
[5075, 5131, 7]"] - 324["Segment
[5137, 5144, 7]"] + 316["Path
[4158, 4383, 8]"] + 317["Segment
[4389, 4485, 8]"] + 318["Segment
[4491, 4639, 8]"] + 319["Segment
[4645, 4741, 8]"] + 320["Segment
[4747, 4851, 8]"] + 321["Segment
[4857, 4961, 8]"] + 322["Segment
[4967, 5069, 8]"] + 323["Segment
[5075, 5131, 8]"] + 324["Segment
[5137, 5144, 8]"] 325[Solid2d] end - 1["Plane
[201, 218, 4]"] - 9["Sweep Extrusion
[712, 759, 4]"] + 1["Plane
[201, 218, 5]"] + 9["Sweep Extrusion
[712, 759, 5]"] 10[Wall] 11[Wall] 12[Wall] @@ -171,43 +171,43 @@ flowchart LR 21["SweepEdge Adjacent"] 22["SweepEdge Opposite"] 23["SweepEdge Adjacent"] - 24["EdgeCut Chamfer
[765, 1042, 4]"] - 25["EdgeCut Chamfer
[765, 1042, 4]"] - 26["EdgeCut Chamfer
[765, 1042, 4]"] - 27["EdgeCut Chamfer
[765, 1042, 4]"] - 31["Sweep Extrusion
[1205, 1271, 4]"] + 24["EdgeCut Chamfer
[765, 1042, 5]"] + 25["EdgeCut Chamfer
[765, 1042, 5]"] + 26["EdgeCut Chamfer
[765, 1042, 5]"] + 27["EdgeCut Chamfer
[765, 1042, 5]"] + 31["Sweep Extrusion
[1205, 1271, 5]"] 32[Wall] 33["Cap End"] 34["SweepEdge Opposite"] 35["SweepEdge Adjacent"] - 39["Sweep Extrusion
[1440, 1470, 4]"] + 39["Sweep Extrusion
[1440, 1470, 5]"] 40[Wall] 41["Cap End"] 42["SweepEdge Opposite"] 43["SweepEdge Adjacent"] - 47["Sweep Extrusion
[1846, 1893, 4]"] + 47["Sweep Extrusion
[1846, 1893, 5]"] 48[Wall] 49["SweepEdge Opposite"] 50["SweepEdge Adjacent"] - 51["Sweep Extrusion
[1846, 1893, 4]"] - 52["Sweep Extrusion
[1846, 1893, 4]"] - 53["Sweep Extrusion
[1846, 1893, 4]"] - 57["Sweep Extrusion
[2220, 2267, 4]"] + 51["Sweep Extrusion
[1846, 1893, 5]"] + 52["Sweep Extrusion
[1846, 1893, 5]"] + 53["Sweep Extrusion
[1846, 1893, 5]"] + 57["Sweep Extrusion
[2220, 2267, 5]"] 58[Wall] 59["SweepEdge Opposite"] 60["SweepEdge Adjacent"] - 61["Sweep Extrusion
[2220, 2267, 4]"] - 62["Sweep Extrusion
[2220, 2267, 4]"] - 63["Sweep Extrusion
[2220, 2267, 4]"] - 64["Plane
[174, 197, 5]"] - 68["Sweep Extrusion
[277, 315, 5]"] + 61["Sweep Extrusion
[2220, 2267, 5]"] + 62["Sweep Extrusion
[2220, 2267, 5]"] + 63["Sweep Extrusion
[2220, 2267, 5]"] + 64["Plane
[174, 197, 6]"] + 68["Sweep Extrusion
[277, 315, 6]"] 69[Wall] 70["Cap Start"] 71["Cap End"] 72["SweepEdge Opposite"] 73["SweepEdge Adjacent"] - 74["Plane
[464, 487, 5]"] - 82["Sweep Extrusion
[818, 848, 5]"] + 74["Plane
[464, 487, 6]"] + 82["Sweep Extrusion
[818, 848, 6]"] 83[Wall] 84[Wall] 85[Wall] @@ -222,35 +222,35 @@ flowchart LR 94["SweepEdge Adjacent"] 95["SweepEdge Opposite"] 96["SweepEdge Adjacent"] - 100["Sweep Extrusion
[1089, 1121, 5]"] + 100["Sweep Extrusion
[1089, 1121, 6]"] 101[Wall] 102["Cap End"] 103["SweepEdge Opposite"] 104["SweepEdge Adjacent"] - 108["Sweep Extrusion
[1659, 1691, 5]"] + 108["Sweep Extrusion
[1659, 1691, 6]"] 109[Wall] 110["Cap End"] 111["SweepEdge Opposite"] 112["SweepEdge Adjacent"] - 113["Sweep Extrusion
[1659, 1691, 5]"] - 114["Sweep Extrusion
[1659, 1691, 5]"] - 115["Sweep Extrusion
[1659, 1691, 5]"] - 119["Sweep Extrusion
[1931, 1964, 5]"] + 113["Sweep Extrusion
[1659, 1691, 6]"] + 114["Sweep Extrusion
[1659, 1691, 6]"] + 115["Sweep Extrusion
[1659, 1691, 6]"] + 119["Sweep Extrusion
[1931, 1964, 6]"] 120[Wall] 121["Cap End"] 122["SweepEdge Opposite"] 123["SweepEdge Adjacent"] - 124["Plane
[2113, 2136, 5]"] - 128["Sweep Extrusion
[2184, 2215, 5]"] + 124["Plane
[2113, 2136, 6]"] + 128["Sweep Extrusion
[2184, 2215, 6]"] 129[Wall] 130["Cap Start"] 131["Cap End"] 132["SweepEdge Opposite"] 133["SweepEdge Adjacent"] - 134["EdgeCut Fillet
[321, 383, 5]"] - 135["EdgeCut Fillet
[1970, 2032, 5]"] - 136["Plane
[222, 245, 6]"] - 144["Sweep Extrusion
[811, 859, 6]"] + 134["EdgeCut Fillet
[321, 383, 6]"] + 135["EdgeCut Fillet
[1970, 2032, 6]"] + 136["Plane
[222, 245, 7]"] + 144["Sweep Extrusion
[811, 859, 7]"] 145[Wall] 146[Wall] 147[Wall] @@ -265,43 +265,43 @@ flowchart LR 156["SweepEdge Adjacent"] 157["SweepEdge Opposite"] 158["SweepEdge Adjacent"] - 162["Sweep Extrusion
[992, 1025, 6]"] + 162["Sweep Extrusion
[992, 1025, 7]"] 163[Wall] 164["Cap End"] 165["SweepEdge Opposite"] 166["SweepEdge Adjacent"] - 170["Sweep Extrusion
[1369, 1399, 6]"] + 170["Sweep Extrusion
[1369, 1399, 7]"] 171[Wall] 172["Cap End"] 173["SweepEdge Opposite"] 174["SweepEdge Adjacent"] - 178["Sweep Extrusion
[1754, 1787, 6]"] + 178["Sweep Extrusion
[1754, 1787, 7]"] 179[Wall] 180["Cap End"] 181["SweepEdge Opposite"] 182["SweepEdge Adjacent"] - 183["Sweep Extrusion
[1754, 1787, 6]"] - 184["Sweep Extrusion
[1754, 1787, 6]"] - 185["Sweep Extrusion
[1754, 1787, 6]"] - 186["Sweep Extrusion
[1754, 1787, 6]"] - 187["Sweep Extrusion
[1754, 1787, 6]"] - 188["Sweep Extrusion
[1754, 1787, 6]"] - 189["Sweep Extrusion
[1754, 1787, 6]"] - 193["Sweep Extrusion
[2299, 2332, 6]"] + 183["Sweep Extrusion
[1754, 1787, 7]"] + 184["Sweep Extrusion
[1754, 1787, 7]"] + 185["Sweep Extrusion
[1754, 1787, 7]"] + 186["Sweep Extrusion
[1754, 1787, 7]"] + 187["Sweep Extrusion
[1754, 1787, 7]"] + 188["Sweep Extrusion
[1754, 1787, 7]"] + 189["Sweep Extrusion
[1754, 1787, 7]"] + 193["Sweep Extrusion
[2299, 2332, 7]"] 194[Wall] 195["Cap End"] 196["SweepEdge Opposite"] 197["SweepEdge Adjacent"] - 198["Sweep Extrusion
[2299, 2332, 6]"] - 199["Sweep Extrusion
[2299, 2332, 6]"] - 200["Sweep Extrusion
[2299, 2332, 6]"] - 204["Sweep Extrusion
[2561, 2591, 6]"] + 198["Sweep Extrusion
[2299, 2332, 7]"] + 199["Sweep Extrusion
[2299, 2332, 7]"] + 200["Sweep Extrusion
[2299, 2332, 7]"] + 204["Sweep Extrusion
[2561, 2591, 7]"] 205[Wall] 206["Cap End"] 207["SweepEdge Opposite"] 208["SweepEdge Adjacent"] - 209["Plane
[242, 265, 7]"] - 217["Sweep Extrusion
[943, 991, 7]"] + 209["Plane
[242, 265, 8]"] + 217["Sweep Extrusion
[943, 991, 8]"] 218[Wall] 219[Wall] 220[Wall] @@ -316,42 +316,42 @@ flowchart LR 229["SweepEdge Adjacent"] 230["SweepEdge Opposite"] 231["SweepEdge Adjacent"] - 235["Sweep Extrusion
[1267, 1300, 7]"] + 235["Sweep Extrusion
[1267, 1300, 8]"] 236[Wall] 237["Cap End"] 238["SweepEdge Opposite"] 239["SweepEdge Adjacent"] - 243["Sweep Extrusion
[1911, 1944, 7]"] + 243["Sweep Extrusion
[1911, 1944, 8]"] 244[Wall] 245["Cap End"] 246["SweepEdge Opposite"] 247["SweepEdge Adjacent"] - 248["Sweep Extrusion
[1911, 1944, 7]"] - 249["Sweep Extrusion
[1911, 1944, 7]"] - 250["Sweep Extrusion
[1911, 1944, 7]"] - 251["Sweep Extrusion
[1911, 1944, 7]"] - 252["Sweep Extrusion
[1911, 1944, 7]"] - 253["Sweep Extrusion
[1911, 1944, 7]"] - 254["Sweep Extrusion
[1911, 1944, 7]"] - 258["Sweep Extrusion
[2367, 2400, 7]"] + 248["Sweep Extrusion
[1911, 1944, 8]"] + 249["Sweep Extrusion
[1911, 1944, 8]"] + 250["Sweep Extrusion
[1911, 1944, 8]"] + 251["Sweep Extrusion
[1911, 1944, 8]"] + 252["Sweep Extrusion
[1911, 1944, 8]"] + 253["Sweep Extrusion
[1911, 1944, 8]"] + 254["Sweep Extrusion
[1911, 1944, 8]"] + 258["Sweep Extrusion
[2367, 2400, 8]"] 259[Wall] 260["Cap Start"] 261["Cap End"] 262["SweepEdge Opposite"] 263["SweepEdge Adjacent"] - 267["Sweep Extrusion
[2751, 2784, 7]"] + 267["Sweep Extrusion
[2751, 2784, 8]"] 268[Wall] 269["Cap Start"] 270["Cap End"] 271["SweepEdge Opposite"] 272["SweepEdge Adjacent"] - 276["Sweep Extrusion
[2943, 2977, 7]"] + 276["Sweep Extrusion
[2943, 2977, 8]"] 277[Wall] 278["Cap Start"] 279["Cap End"] 280["SweepEdge Opposite"] 281["SweepEdge Adjacent"] - 292["Sweep Extrusion
[4044, 4077, 7]"] + 292["Sweep Extrusion
[4044, 4077, 8]"] 293[Wall] 294[Wall] 295[Wall] @@ -375,7 +375,7 @@ flowchart LR 313["SweepEdge Adjacent"] 314["SweepEdge Opposite"] 315["SweepEdge Adjacent"] - 326["Sweep Extrusion
[5146, 5179, 7]"] + 326["Sweep Extrusion
[5146, 5179, 8]"] 327[Wall] 328[Wall] 329[Wall] @@ -399,25 +399,25 @@ flowchart LR 347["SweepEdge Adjacent"] 348["SweepEdge Opposite"] 349["SweepEdge Adjacent"] - 350["StartSketchOnFace
[1096, 1128, 4]"] - 351["StartSketchOnFace
[1351, 1383, 4]"] - 352["StartSketchOnFace
[1520, 1552, 4]"] - 353["StartSketchOnFace
[1906, 1938, 4]"] - 354["StartSketchOnFace
[862, 894, 5]"] - 355["StartSketchOnFace
[1241, 1273, 5]"] - 356["StartSketchOnFace
[1705, 1737, 5]"] - 357["StartSketchOnFace
[873, 907, 6]"] - 358["StartSketchOnFace
[1106, 1140, 6]"] - 359["StartSketchOnFace
[1519, 1551, 6]"] - 360["StartSketchOnFace
[1801, 1833, 6]"] - 361["StartSketchOnFace
[2346, 2378, 6]"] - 362["StartSketchOnFace
[1005, 1037, 7]"] - 363["StartSketchOnFace
[1419, 1451, 7]"] - 364["StartSketchOnFace
[2027, 2061, 7]"] - 365["StartSketchOnFace
[2414, 2446, 7]"] - 366["StartSketchOnFace
[2850, 2884, 7]"] - 367["StartSketchOnFace
[3018, 3052, 7]"] - 368["StartSketchOnFace
[4118, 4152, 7]"] + 350["StartSketchOnFace
[1096, 1128, 5]"] + 351["StartSketchOnFace
[1351, 1383, 5]"] + 352["StartSketchOnFace
[1520, 1552, 5]"] + 353["StartSketchOnFace
[1906, 1938, 5]"] + 354["StartSketchOnFace
[862, 894, 6]"] + 355["StartSketchOnFace
[1241, 1273, 6]"] + 356["StartSketchOnFace
[1705, 1737, 6]"] + 357["StartSketchOnFace
[873, 907, 7]"] + 358["StartSketchOnFace
[1106, 1140, 7]"] + 359["StartSketchOnFace
[1519, 1551, 7]"] + 360["StartSketchOnFace
[1801, 1833, 7]"] + 361["StartSketchOnFace
[2346, 2378, 7]"] + 362["StartSketchOnFace
[1005, 1037, 8]"] + 363["StartSketchOnFace
[1419, 1451, 8]"] + 364["StartSketchOnFace
[2027, 2061, 8]"] + 365["StartSketchOnFace
[2414, 2446, 8]"] + 366["StartSketchOnFace
[2850, 2884, 8]"] + 367["StartSketchOnFace
[3018, 3052, 8]"] + 368["StartSketchOnFace
[4118, 4152, 8]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/program_memory.snap index 541e65408..ebc803a54 100644 --- a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/program_memory.snap @@ -5,18 +5,18 @@ description: Variables in memory after executing multi-axis-robot.kcl { "j2RobotArm": { "type": "Module", - "value": 6 + "value": 7 }, "j3RobotArm": { "type": "Module", - "value": 7 + "value": 8 }, "robotArmBase": { "type": "Module", - "value": 4 + "value": 5 }, "rotatingBase": { "type": "Module", - "value": 5 + "value": 6 } } diff --git a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_commands.snap index c344e925e..da1cccefb 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pipe-flange-assembly.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_graph_flowchart.snap.md index eafe2cb92..1d683218f 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/artifact_graph_flowchart.snap.md @@ -1,206 +1,206 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[537, 630, 5]"] - 3["Segment
[537, 630, 5]"] + 2["Path
[537, 630, 6]"] + 3["Segment
[537, 630, 6]"] 4[Solid2d] end subgraph path6 [Path] - 6["Path
[859, 914, 5]"] - 7["Segment
[859, 914, 5]"] + 6["Path
[859, 914, 6]"] + 7["Segment
[859, 914, 6]"] 8[Solid2d] end subgraph path15 [Path] - 15["Path
[1129, 1188, 5]"] - 16["Segment
[1129, 1188, 5]"] + 15["Path
[1129, 1188, 6]"] + 16["Segment
[1129, 1188, 6]"] 17[Solid2d] end subgraph path23 [Path] - 23["Path
[1290, 1350, 5]"] - 24["Segment
[1290, 1350, 5]"] + 23["Path
[1290, 1350, 6]"] + 24["Segment
[1290, 1350, 6]"] 25[Solid2d] end subgraph path31 [Path] - 31["Path
[1507, 1560, 5]"] - 32["Segment
[1507, 1560, 5]"] + 31["Path
[1507, 1560, 6]"] + 32["Segment
[1507, 1560, 6]"] 33[Solid2d] end subgraph path39 [Path] - 39["Path
[537, 630, 5]"] - 40["Segment
[537, 630, 5]"] + 39["Path
[537, 630, 6]"] + 40["Segment
[537, 630, 6]"] 41[Solid2d] end subgraph path43 [Path] - 43["Path
[859, 914, 5]"] - 44["Segment
[859, 914, 5]"] + 43["Path
[859, 914, 6]"] + 44["Segment
[859, 914, 6]"] 45[Solid2d] end subgraph path52 [Path] - 52["Path
[1129, 1188, 5]"] - 53["Segment
[1129, 1188, 5]"] + 52["Path
[1129, 1188, 6]"] + 53["Segment
[1129, 1188, 6]"] 54[Solid2d] end subgraph path60 [Path] - 60["Path
[1290, 1350, 5]"] - 61["Segment
[1290, 1350, 5]"] + 60["Path
[1290, 1350, 6]"] + 61["Segment
[1290, 1350, 6]"] 62[Solid2d] end subgraph path68 [Path] - 68["Path
[1507, 1560, 5]"] - 69["Segment
[1507, 1560, 5]"] + 68["Path
[1507, 1560, 6]"] + 69["Segment
[1507, 1560, 6]"] 70[Solid2d] end subgraph path76 [Path] - 76["Path
[494, 556, 6]"] - 77["Segment
[494, 556, 6]"] + 76["Path
[494, 556, 7]"] + 77["Segment
[494, 556, 7]"] 78[Solid2d] end subgraph path85 [Path] - 85["Path
[706, 766, 6]"] - 86["Segment
[706, 766, 6]"] + 85["Path
[706, 766, 7]"] + 86["Segment
[706, 766, 7]"] 87[Solid2d] end subgraph path93 [Path] - 93["Path
[355, 407, 7]"] - 94["Segment
[355, 407, 7]"] + 93["Path
[354, 406, 8]"] + 94["Segment
[354, 406, 8]"] 95[Solid2d] end subgraph path102 [Path] - 102["Path
[540, 592, 7]"] - 103["Segment
[540, 592, 7]"] + 102["Path
[539, 591, 8]"] + 103["Segment
[539, 591, 8]"] 104[Solid2d] end subgraph path110 [Path] - 110["Path
[446, 516, 8]"] - 111["Segment
[446, 516, 8]"] + 110["Path
[445, 515, 9]"] + 111["Segment
[445, 515, 9]"] 112[Solid2d] end subgraph path121 [Path] - 121["Path
[780, 867, 8]"] - 122["Segment
[875, 958, 8]"] - 123["Segment
[966, 1049, 8]"] - 124["Segment
[1057, 1140, 8]"] - 125["Segment
[1148, 1230, 8]"] - 126["Segment
[1238, 1320, 8]"] - 127["Segment
[1328, 1335, 8]"] + 121["Path
[779, 866, 9]"] + 122["Segment
[874, 957, 9]"] + 123["Segment
[965, 1048, 9]"] + 124["Segment
[1056, 1139, 9]"] + 125["Segment
[1147, 1229, 9]"] + 126["Segment
[1237, 1319, 9]"] + 127["Segment
[1327, 1334, 9]"] 128[Solid2d] end subgraph path149 [Path] - 149["Path
[1469, 1538, 8]"] - 150["Segment
[1469, 1538, 8]"] + 149["Path
[1468, 1537, 9]"] + 150["Segment
[1468, 1537, 9]"] 151[Solid2d] end subgraph path158 [Path] - 158["Path
[378, 468, 9]"] - 159["Segment
[476, 558, 9]"] - 160["Segment
[566, 648, 9]"] - 161["Segment
[656, 738, 9]"] - 162["Segment
[746, 827, 9]"] - 163["Segment
[835, 916, 9]"] - 164["Segment
[924, 931, 9]"] + 158["Path
[378, 468, 10]"] + 159["Segment
[476, 558, 10]"] + 160["Segment
[566, 648, 10]"] + 161["Segment
[656, 738, 10]"] + 162["Segment
[746, 827, 10]"] + 163["Segment
[835, 916, 10]"] + 164["Segment
[924, 931, 10]"] 165[Solid2d] end subgraph path187 [Path] - 187["Path
[1075, 1127, 9]"] - 188["Segment
[1075, 1127, 9]"] + 187["Path
[1075, 1127, 10]"] + 188["Segment
[1075, 1127, 10]"] 189[Solid2d] end subgraph path195 [Path] - 195["Path
[313, 371, 10]"] - 196["Segment
[313, 371, 10]"] + 195["Path
[313, 371, 11]"] + 196["Segment
[313, 371, 11]"] 197[Solid2d] end subgraph path204 [Path] - 204["Path
[510, 565, 10]"] - 205["Segment
[510, 565, 10]"] + 204["Path
[510, 565, 11]"] + 205["Segment
[510, 565, 11]"] 206[Solid2d] end subgraph path212 [Path] - 212["Path
[313, 371, 10]"] - 213["Segment
[313, 371, 10]"] + 212["Path
[313, 371, 11]"] + 213["Segment
[313, 371, 11]"] 214[Solid2d] end subgraph path221 [Path] - 221["Path
[510, 565, 10]"] - 222["Segment
[510, 565, 10]"] + 221["Path
[510, 565, 11]"] + 222["Segment
[510, 565, 11]"] 223[Solid2d] end - 1["Plane
[512, 529, 5]"] - 5["Plane
[834, 851, 5]"] - 9["Sweep Extrusion
[952, 992, 5]"] + 1["Plane
[512, 529, 6]"] + 5["Plane
[834, 851, 6]"] + 9["Sweep Extrusion
[952, 992, 6]"] 10[Wall] 11["Cap Start"] 12["Cap End"] 13["SweepEdge Opposite"] 14["SweepEdge Adjacent"] - 18["Sweep Extrusion
[1196, 1233, 5]"] + 18["Sweep Extrusion
[1196, 1233, 6]"] 19[Wall] 20["Cap End"] 21["SweepEdge Opposite"] 22["SweepEdge Adjacent"] - 26["Sweep Extrusion
[1358, 1396, 5]"] + 26["Sweep Extrusion
[1358, 1396, 6]"] 27[Wall] 28["Cap End"] 29["SweepEdge Opposite"] 30["SweepEdge Adjacent"] - 34["Sweep Extrusion
[1568, 1610, 5]"] + 34["Sweep Extrusion
[1568, 1610, 6]"] 35[Wall] 36["SweepEdge Opposite"] 37["SweepEdge Adjacent"] - 38["Plane
[512, 529, 5]"] - 42["Plane
[834, 851, 5]"] - 46["Sweep Extrusion
[952, 992, 5]"] + 38["Plane
[512, 529, 6]"] + 42["Plane
[834, 851, 6]"] + 46["Sweep Extrusion
[952, 992, 6]"] 47[Wall] 48["Cap Start"] 49["Cap End"] 50["SweepEdge Opposite"] 51["SweepEdge Adjacent"] - 55["Sweep Extrusion
[1196, 1233, 5]"] + 55["Sweep Extrusion
[1196, 1233, 6]"] 56[Wall] 57["Cap End"] 58["SweepEdge Opposite"] 59["SweepEdge Adjacent"] - 63["Sweep Extrusion
[1358, 1396, 5]"] + 63["Sweep Extrusion
[1358, 1396, 6]"] 64[Wall] 65["Cap End"] 66["SweepEdge Opposite"] 67["SweepEdge Adjacent"] - 71["Sweep Extrusion
[1568, 1610, 5]"] + 71["Sweep Extrusion
[1568, 1610, 6]"] 72[Wall] 73["SweepEdge Opposite"] 74["SweepEdge Adjacent"] - 75["Plane
[469, 486, 6]"] - 79["Sweep Extrusion
[564, 600, 6]"] + 75["Plane
[469, 486, 7]"] + 79["Sweep Extrusion
[564, 600, 7]"] 80[Wall] 81["Cap Start"] 82["Cap End"] 83["SweepEdge Opposite"] 84["SweepEdge Adjacent"] - 88["Sweep Extrusion
[774, 811, 6]"] + 88["Sweep Extrusion
[774, 811, 7]"] 89[Wall] 90["SweepEdge Opposite"] 91["SweepEdge Adjacent"] - 92["Plane
[330, 347, 7]"] - 96["Sweep Extrusion
[415, 448, 7]"] + 92["Plane
[329, 346, 8]"] + 96["Sweep Extrusion
[414, 447, 8]"] 97[Wall] 98["Cap Start"] 99["Cap End"] 100["SweepEdge Opposite"] 101["SweepEdge Adjacent"] - 105["Sweep Extrusion
[600, 637, 7]"] + 105["Sweep Extrusion
[599, 636, 8]"] 106[Wall] 107["SweepEdge Opposite"] 108["SweepEdge Adjacent"] - 109["Plane
[421, 438, 8]"] - 113["Sweep Extrusion
[524, 557, 8]"] + 109["Plane
[420, 437, 9]"] + 113["Sweep Extrusion
[523, 556, 9]"] 114[Wall] 115["Cap Start"] 116["Cap End"] 117["SweepEdge Opposite"] 118["SweepEdge Adjacent"] - 119["EdgeCut Fillet
[565, 631, 8]"] - 120["EdgeCut Fillet
[565, 631, 8]"] - 129["Sweep Extrusion
[1343, 1383, 8]"] + 119["EdgeCut Fillet
[564, 630, 9]"] + 120["EdgeCut Fillet
[564, 630, 9]"] + 129["Sweep Extrusion
[1342, 1382, 9]"] 130[Wall] 131[Wall] 132[Wall] @@ -220,13 +220,13 @@ flowchart LR 146["SweepEdge Adjacent"] 147["SweepEdge Opposite"] 148["SweepEdge Adjacent"] - 152["Sweep Extrusion
[1546, 1574, 8]"] + 152["Sweep Extrusion
[1545, 1573, 9]"] 153[Wall] 154["Cap End"] 155["SweepEdge Opposite"] 156["SweepEdge Adjacent"] - 157["Plane
[353, 370, 9]"] - 166["Sweep Extrusion
[939, 972, 9]"] + 157["Plane
[353, 370, 10]"] + 166["Sweep Extrusion
[939, 972, 10]"] 167[Wall] 168[Wall] 169[Wall] @@ -247,45 +247,45 @@ flowchart LR 184["SweepEdge Adjacent"] 185["SweepEdge Opposite"] 186["SweepEdge Adjacent"] - 190["Sweep Extrusion
[1135, 1172, 9]"] + 190["Sweep Extrusion
[1135, 1172, 10]"] 191[Wall] 192["SweepEdge Opposite"] 193["SweepEdge Adjacent"] - 194["Plane
[288, 305, 10]"] - 198["Sweep Extrusion
[379, 410, 10]"] + 194["Plane
[288, 305, 11]"] + 198["Sweep Extrusion
[379, 410, 11]"] 199[Wall] 200["Cap Start"] 201["Cap End"] 202["SweepEdge Opposite"] 203["SweepEdge Adjacent"] - 207["Sweep Extrusion
[573, 605, 10]"] + 207["Sweep Extrusion
[573, 605, 11]"] 208[Wall] 209["SweepEdge Opposite"] 210["SweepEdge Adjacent"] - 211["Plane
[288, 305, 10]"] - 215["Sweep Extrusion
[379, 410, 10]"] + 211["Plane
[288, 305, 11]"] + 215["Sweep Extrusion
[379, 410, 11]"] 216[Wall] 217["Cap Start"] 218["Cap End"] 219["SweepEdge Opposite"] 220["SweepEdge Adjacent"] - 224["Sweep Extrusion
[573, 605, 10]"] + 224["Sweep Extrusion
[573, 605, 11]"] 225[Wall] 226["SweepEdge Opposite"] 227["SweepEdge Adjacent"] - 228["StartSketchOnFace
[1087, 1121, 5]"] - 229["StartSketchOnFace
[1250, 1282, 5]"] - 230["StartSketchOnFace
[1466, 1499, 5]"] - 231["StartSketchOnFace
[1087, 1121, 5]"] - 232["StartSketchOnFace
[1250, 1282, 5]"] - 233["StartSketchOnFace
[1466, 1499, 5]"] - 234["StartSketchOnFace
[666, 698, 6]"] - 235["StartSketchOnFace
[500, 532, 7]"] - 236["StartSketchOnFace
[740, 772, 8]"] - 237["StartSketchOnFace
[1431, 1461, 8]"] - 238["StartSketchOnFace
[1035, 1067, 9]"] - 239["StartSketchOnFace
[472, 502, 10]"] - 240["StartSketchOnFace
[472, 502, 10]"] + 228["StartSketchOnFace
[1087, 1121, 6]"] + 229["StartSketchOnFace
[1250, 1282, 6]"] + 230["StartSketchOnFace
[1466, 1499, 6]"] + 231["StartSketchOnFace
[1087, 1121, 6]"] + 232["StartSketchOnFace
[1250, 1282, 6]"] + 233["StartSketchOnFace
[1466, 1499, 6]"] + 234["StartSketchOnFace
[666, 698, 7]"] + 235["StartSketchOnFace
[499, 531, 8]"] + 236["StartSketchOnFace
[739, 771, 9]"] + 237["StartSketchOnFace
[1430, 1460, 9]"] + 238["StartSketchOnFace
[1035, 1067, 10]"] + 239["StartSketchOnFace
[472, 502, 11]"] + 240["StartSketchOnFace
[472, 502, 11]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ast.snap b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ast.snap index 33999ead1..7c314b1cc 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ast.snap @@ -382,102 +382,113 @@ description: Result of parsing pipe-flange-assembly.kcl "label": { "commentStart": 781, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 793, - "elements": [ - { - "commentStart": 802, + "commentStart": 785, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 788, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 792, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 795, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 799, + "end": 0, + "left": { + "commentStart": 799, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 799, "end": 0, - "raw": "0", + "name": { + "commentStart": 799, + "end": 0, + "name": "flangeBackHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 818, + "end": 0, + "raw": "2", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 0.0, + "value": 2.0, "suffix": "None" } }, - { - "commentStart": 812, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 822, + "end": 0, + "name": { "commentStart": 822, "end": 0, - "left": { - "commentStart": 822, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 822, - "end": 0, - "name": { - "commentStart": 822, - "end": 0, - "name": "flangeBackHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 841, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 845, - "end": 0, - "name": { - "commentStart": 845, - "end": 0, - "name": "gasketThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, + "name": "gasketThickness", "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], @@ -510,7 +521,7 @@ description: Result of parsing pipe-flange-assembly.kcl "nonCodeNodes": { "2": [ { - "commentStart": 868, + "commentStart": 838, "end": 0, "start": 0, "type": "NonCodeNode", @@ -533,7 +544,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 906, + "commentStart": 876, "end": 0, "expression": { "body": [ @@ -541,10 +552,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 906, + "commentStart": 876, "end": 0, "name": { - "commentStart": 906, + "commentStart": 876, "end": 0, "name": "gasket", "start": 0, @@ -554,7 +565,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 906, + "commentStart": 876, "end": 0, "start": 0, "type": "CallExpression", @@ -565,101 +576,112 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 930, + "commentStart": 900, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 942, - "elements": [ - { - "commentStart": 951, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 961, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 971, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 972, - "end": 0, - "name": { - "commentStart": 972, - "end": 0, - "name": "flangeBackHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 971, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 991, - "end": 0, - "name": { - "commentStart": 991, - "end": 0, - "name": "gasketThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], + "commentStart": 904, "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 907, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 911, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 914, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 918, + "end": 0, + "left": { + "argument": { + "abs_path": false, + "commentStart": 919, + "end": 0, + "name": { + "commentStart": 919, + "end": 0, + "name": "flangeBackHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 918, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 938, + "end": 0, + "name": { + "commentStart": 938, + "end": 0, + "name": "gasketThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], "callee": { "abs_path": false, - "commentStart": 920, + "commentStart": 890, "end": 0, "name": { - "commentStart": 920, + "commentStart": 890, "end": 0, "name": "translate", "start": 0, @@ -669,7 +691,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 920, + "commentStart": 890, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -677,13 +699,13 @@ description: Result of parsing pipe-flange-assembly.kcl "unlabeled": null } ], - "commentStart": 906, + "commentStart": 876, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "1": [ { - "commentStart": 1014, + "commentStart": 954, "end": 0, "start": 0, "type": "NonCodeNode", @@ -706,7 +728,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 1063, + "commentStart": 1003, "end": 0, "expression": { "body": [ @@ -714,10 +736,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1063, + "commentStart": 1003, "end": 0, "name": { - "commentStart": 1063, + "commentStart": 1003, "end": 0, "name": "washer", "start": 0, @@ -727,7 +749,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1063, + "commentStart": 1003, "end": 0, "start": 0, "type": "CallExpression", @@ -738,93 +760,104 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1087, + "commentStart": 1027, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1099, - "elements": [ - { - "commentStart": 1108, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1108, - "end": 0, - "name": { - "commentStart": 1108, - "end": 0, - "name": "mountingHolePlacementDiameter", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1140, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 1150, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 1160, - "end": 0, - "name": { - "commentStart": 1160, - "end": 0, - "name": "flangeBaseThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], + "commentStart": 1031, "end": 0, + "left": { + "abs_path": false, + "commentStart": 1031, + "end": 0, + "name": { + "commentStart": 1031, + "end": 0, + "name": "mountingHolePlacementDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1063, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1066, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1070, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1073, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "abs_path": false, + "commentStart": 1077, + "end": 0, + "name": { + "commentStart": 1077, + "end": 0, + "name": "flangeBaseThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" } } ], "callee": { "abs_path": false, - "commentStart": 1077, + "commentStart": 1017, "end": 0, "name": { - "commentStart": 1077, + "commentStart": 1017, "end": 0, "name": "translate", "start": 0, @@ -834,7 +867,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1077, + "commentStart": 1017, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -846,14 +879,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1229, + "commentStart": 1139, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1241, + "commentStart": 1151, "end": 0, "raw": "4", "start": 0, @@ -868,17 +901,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1251, + "commentStart": 1161, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1258, + "commentStart": 1168, "elements": [ { - "commentStart": 1259, + "commentStart": 1169, "end": 0, "raw": "0", "start": 0, @@ -890,7 +923,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1262, + "commentStart": 1172, "end": 0, "raw": "0", "start": 0, @@ -902,7 +935,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1265, + "commentStart": 1175, "end": 0, "raw": "1", "start": 0, @@ -923,17 +956,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1276, + "commentStart": 1186, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1285, + "commentStart": 1195, "elements": [ { - "commentStart": 1286, + "commentStart": 1196, "end": 0, "raw": "0", "start": 0, @@ -945,7 +978,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1289, + "commentStart": 1199, "end": 0, "raw": "0", "start": 0, @@ -957,7 +990,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1292, + "commentStart": 1202, "end": 0, "raw": "0", "start": 0, @@ -978,14 +1011,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1303, + "commentStart": 1213, "end": 0, "name": "arcDegrees", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1316, + "commentStart": 1226, "end": 0, "raw": "360", "start": 0, @@ -1000,14 +1033,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1328, + "commentStart": 1238, "end": 0, "name": "rotateDuplicates", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1347, + "commentStart": 1257, "end": 0, "raw": "false", "start": 0, @@ -1019,10 +1052,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 1193, + "commentStart": 1103, "end": 0, "name": { - "commentStart": 1193, + "commentStart": 1103, "end": 0, "name": "patternCircular3d", "start": 0, @@ -1032,13 +1065,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1193, + "commentStart": 1103, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 1219, + "commentStart": 1129, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1050,14 +1083,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1400, + "commentStart": 1310, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1412, + "commentStart": 1322, "end": 0, "raw": "2", "start": 0, @@ -1072,7 +1105,7 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1422, + "commentStart": 1332, "end": 0, "name": "distance", "start": 0, @@ -1080,23 +1113,23 @@ description: Result of parsing pipe-flange-assembly.kcl }, "arg": { "argument": { - "commentStart": 1435, + "commentStart": 1345, "end": 0, "left": { - "commentStart": 1435, + "commentStart": 1345, "end": 0, "left": { - "commentStart": 1435, + "commentStart": 1345, "end": 0, "left": { - "commentStart": 1435, + "commentStart": 1345, "end": 0, "left": { "abs_path": false, - "commentStart": 1435, + "commentStart": 1345, "end": 0, "name": { - "commentStart": 1435, + "commentStart": 1345, "end": 0, "name": "flangeBaseThickness", "start": 0, @@ -1109,7 +1142,7 @@ description: Result of parsing pipe-flange-assembly.kcl }, "operator": "*", "right": { - "commentStart": 1457, + "commentStart": 1367, "end": 0, "raw": "2", "start": 0, @@ -1126,14 +1159,14 @@ description: Result of parsing pipe-flange-assembly.kcl }, "operator": "+", "right": { - "commentStart": 1461, + "commentStart": 1371, "end": 0, "left": { "abs_path": false, - "commentStart": 1461, + "commentStart": 1371, "end": 0, "name": { - "commentStart": 1461, + "commentStart": 1371, "end": 0, "name": "flangeBackHeight", "start": 0, @@ -1146,7 +1179,7 @@ description: Result of parsing pipe-flange-assembly.kcl }, "operator": "*", "right": { - "commentStart": 1480, + "commentStart": 1390, "end": 0, "raw": "2", "start": 0, @@ -1168,10 +1201,10 @@ description: Result of parsing pipe-flange-assembly.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1484, + "commentStart": 1394, "end": 0, "name": { - "commentStart": 1484, + "commentStart": 1394, "end": 0, "name": "gasketThickness", "start": 0, @@ -1189,10 +1222,10 @@ description: Result of parsing pipe-flange-assembly.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1502, + "commentStart": 1412, "end": 0, "name": { - "commentStart": 1502, + "commentStart": 1412, "end": 0, "name": "washerThickness", "start": 0, @@ -1207,7 +1240,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "commentStart": 1433, + "commentStart": 1343, "end": 0, "operator": "-", "start": 0, @@ -1218,17 +1251,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1527, + "commentStart": 1437, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1534, + "commentStart": 1444, "elements": [ { - "commentStart": 1535, + "commentStart": 1445, "end": 0, "raw": "0", "start": 0, @@ -1240,7 +1273,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1538, + "commentStart": 1448, "end": 0, "raw": "0", "start": 0, @@ -1252,7 +1285,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1541, + "commentStart": 1451, "end": 0, "raw": "1", "start": 0, @@ -1273,10 +1306,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 1366, + "commentStart": 1276, "end": 0, "name": { - "commentStart": 1366, + "commentStart": 1276, "end": 0, "name": "patternLinear3d", "start": 0, @@ -1286,13 +1319,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1366, + "commentStart": 1276, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 1390, + "commentStart": 1300, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1300,13 +1333,13 @@ description: Result of parsing pipe-flange-assembly.kcl } } ], - "commentStart": 1063, + "commentStart": 1003, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "3": [ { - "commentStart": 1551, + "commentStart": 1461, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1329,7 +1362,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 1573, + "commentStart": 1483, "end": 0, "expression": { "body": [ @@ -1337,10 +1370,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1573, + "commentStart": 1483, "end": 0, "name": { - "commentStart": 1573, + "commentStart": 1483, "end": 0, "name": "bolt", "start": 0, @@ -1350,7 +1383,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1573, + "commentStart": 1483, "end": 0, "start": 0, "type": "CallExpression", @@ -1361,117 +1394,128 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1595, + "commentStart": 1505, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1607, - "elements": [ - { - "commentStart": 1616, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1616, - "end": 0, - "name": { - "commentStart": 1616, - "end": 0, - "name": "mountingHolePlacementDiameter", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1648, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 1658, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 1668, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1668, - "end": 0, - "name": { - "commentStart": 1668, - "end": 0, - "name": "flangeBaseThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 1690, - "end": 0, - "name": { - "commentStart": 1690, - "end": 0, - "name": "washerThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], + "commentStart": 1509, "end": 0, + "left": { + "abs_path": false, + "commentStart": 1509, + "end": 0, + "name": { + "commentStart": 1509, + "end": 0, + "name": "mountingHolePlacementDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1541, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1544, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1548, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1551, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1555, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1555, + "end": 0, + "name": { + "commentStart": 1555, + "end": 0, + "name": "flangeBaseThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1577, + "end": 0, + "name": { + "commentStart": 1577, + "end": 0, + "name": "washerThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], "callee": { "abs_path": false, - "commentStart": 1585, + "commentStart": 1495, "end": 0, "name": { - "commentStart": 1585, + "commentStart": 1495, "end": 0, "name": "translate", "start": 0, @@ -1481,7 +1525,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1585, + "commentStart": 1495, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1493,14 +1537,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1726, + "commentStart": 1606, "end": 0, "name": "roll", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1733, + "commentStart": 1613, "end": 0, "raw": "90", "start": 0, @@ -1515,14 +1559,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1737, + "commentStart": 1617, "end": 0, "name": "pitch", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1745, + "commentStart": 1625, "end": 0, "raw": "0", "start": 0, @@ -1537,14 +1581,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1748, + "commentStart": 1628, "end": 0, "name": "yaw", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1754, + "commentStart": 1634, "end": 0, "raw": "0", "start": 0, @@ -1559,10 +1603,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 1719, + "commentStart": 1599, "end": 0, "name": { - "commentStart": 1719, + "commentStart": 1599, "end": 0, "name": "rotate", "start": 0, @@ -1572,7 +1616,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1719, + "commentStart": 1599, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1584,14 +1628,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1798, + "commentStart": 1678, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1810, + "commentStart": 1690, "end": 0, "raw": "4", "start": 0, @@ -1606,17 +1650,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1820, + "commentStart": 1700, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1827, + "commentStart": 1707, "elements": [ { - "commentStart": 1828, + "commentStart": 1708, "end": 0, "raw": "0", "start": 0, @@ -1628,7 +1672,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1831, + "commentStart": 1711, "end": 0, "raw": "0", "start": 0, @@ -1640,7 +1684,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1834, + "commentStart": 1714, "end": 0, "raw": "1", "start": 0, @@ -1661,17 +1705,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1845, + "commentStart": 1725, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1854, + "commentStart": 1734, "elements": [ { - "commentStart": 1855, + "commentStart": 1735, "end": 0, "raw": "0", "start": 0, @@ -1683,7 +1727,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1858, + "commentStart": 1738, "end": 0, "raw": "0", "start": 0, @@ -1695,7 +1739,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 1861, + "commentStart": 1741, "end": 0, "raw": "0", "start": 0, @@ -1716,14 +1760,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1872, + "commentStart": 1752, "end": 0, "name": "arcDegrees", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1885, + "commentStart": 1765, "end": 0, "raw": "360", "start": 0, @@ -1738,14 +1782,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1897, + "commentStart": 1777, "end": 0, "name": "rotateDuplicates", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1916, + "commentStart": 1796, "end": 0, "raw": "false", "start": 0, @@ -1757,10 +1801,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 1762, + "commentStart": 1642, "end": 0, "name": { - "commentStart": 1762, + "commentStart": 1642, "end": 0, "name": "patternCircular3d", "start": 0, @@ -1770,13 +1814,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1762, + "commentStart": 1642, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 1788, + "commentStart": 1668, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1784,13 +1828,13 @@ description: Result of parsing pipe-flange-assembly.kcl } } ], - "commentStart": 1573, + "commentStart": 1483, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "3": [ { - "commentStart": 1929, + "commentStart": 1809, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1813,7 +1857,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 1954, + "commentStart": 1834, "end": 0, "expression": { "body": [ @@ -1821,10 +1865,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1954, + "commentStart": 1834, "end": 0, "name": { - "commentStart": 1954, + "commentStart": 1834, "end": 0, "name": "hexNut", "start": 0, @@ -1834,7 +1878,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1954, + "commentStart": 1834, "end": 0, "start": 0, "type": "CallExpression", @@ -1845,142 +1889,104 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 1978, + "commentStart": 1858, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1990, - "elements": [ - { - "commentStart": 1999, + "commentStart": 1862, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1862, + "end": 0, + "name": { + "commentStart": 1862, + "end": 0, + "name": "mountingHolePlacementDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1894, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1897, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1901, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1904, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1910, + "end": 0, + "left": { + "commentStart": 1910, "end": 0, "left": { - "abs_path": false, - "commentStart": 1999, - "end": 0, - "name": { - "commentStart": 1999, - "end": 0, - "name": "mountingHolePlacementDiameter", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 2031, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 2041, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "argument": { - "commentStart": 2053, + "commentStart": 1910, "end": 0, "left": { - "commentStart": 2053, + "commentStart": 1910, "end": 0, "left": { - "commentStart": 2053, + "commentStart": 1910, "end": 0, "left": { - "commentStart": 2053, - "end": 0, - "left": { - "commentStart": 2053, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 2053, - "end": 0, - "name": { - "commentStart": 2053, - "end": 0, - "name": "flangeBackHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 2072, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 2076, - "end": 0, - "name": { - "commentStart": 2076, - "end": 0, - "name": "gasketThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { "abs_path": false, - "commentStart": 2094, + "commentStart": 1910, "end": 0, "name": { - "commentStart": 2094, + "commentStart": 1910, "end": 0, - "name": "flangeBaseThickness", + "name": "flangeBackHeight", "start": 0, "type": "Identifier" }, @@ -1989,6 +1995,19 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "Name", "type": "Name" }, + "operator": "*", + "right": { + "commentStart": 1929, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" @@ -1996,12 +2015,12 @@ description: Result of parsing pipe-flange-assembly.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2116, + "commentStart": 1933, "end": 0, "name": { - "commentStart": 2116, + "commentStart": 1933, "end": 0, - "name": "washerThickness", + "name": "gasketThickness", "start": 0, "type": "Identifier" }, @@ -2017,12 +2036,12 @@ description: Result of parsing pipe-flange-assembly.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2134, + "commentStart": 1951, "end": 0, "name": { - "commentStart": 2134, + "commentStart": 1951, "end": 0, - "name": "hexNutThickness", + "name": "flangeBaseThickness", "start": 0, "type": "Identifier" }, @@ -2035,27 +2054,63 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "commentStart": 2051, - "end": 0, - "operator": "-", + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1973, + "end": 0, + "name": { + "commentStart": 1973, + "end": 0, + "name": "washerThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1991, + "end": 0, + "name": { + "commentStart": 1991, + "end": 0, + "name": "hexNutThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "commentStart": 1908, "end": 0, + "operator": "-", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "UnaryExpression", + "type": "UnaryExpression" } } ], "callee": { "abs_path": false, - "commentStart": 1968, + "commentStart": 1848, "end": 0, "name": { - "commentStart": 1968, + "commentStart": 1848, "end": 0, "name": "translate", "start": 0, @@ -2065,7 +2120,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 1968, + "commentStart": 1848, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2077,14 +2132,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2200, + "commentStart": 2050, "end": 0, "name": "instances", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2212, + "commentStart": 2062, "end": 0, "raw": "4", "start": 0, @@ -2099,17 +2154,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2222, + "commentStart": 2072, "end": 0, "name": "axis", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2229, + "commentStart": 2079, "elements": [ { - "commentStart": 2230, + "commentStart": 2080, "end": 0, "raw": "0", "start": 0, @@ -2121,7 +2176,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 2233, + "commentStart": 2083, "end": 0, "raw": "0", "start": 0, @@ -2133,7 +2188,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 2236, + "commentStart": 2086, "end": 0, "raw": "1", "start": 0, @@ -2154,17 +2209,17 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2247, + "commentStart": 2097, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2256, + "commentStart": 2106, "elements": [ { - "commentStart": 2257, + "commentStart": 2107, "end": 0, "raw": "0", "start": 0, @@ -2176,7 +2231,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 2260, + "commentStart": 2110, "end": 0, "raw": "0", "start": 0, @@ -2188,7 +2243,7 @@ description: Result of parsing pipe-flange-assembly.kcl } }, { - "commentStart": 2263, + "commentStart": 2113, "end": 0, "raw": "0", "start": 0, @@ -2209,14 +2264,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2274, + "commentStart": 2124, "end": 0, "name": "arcDegrees", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2287, + "commentStart": 2137, "end": 0, "raw": "360", "start": 0, @@ -2231,14 +2286,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2299, + "commentStart": 2149, "end": 0, "name": "rotateDuplicates", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2318, + "commentStart": 2168, "end": 0, "raw": "false", "start": 0, @@ -2250,10 +2305,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 2164, + "commentStart": 2014, "end": 0, "name": { - "commentStart": 2164, + "commentStart": 2014, "end": 0, "name": "patternCircular3d", "start": 0, @@ -2263,13 +2318,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2164, + "commentStart": 2014, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 2190, + "commentStart": 2040, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2277,13 +2332,13 @@ description: Result of parsing pipe-flange-assembly.kcl } } ], - "commentStart": 1954, + "commentStart": 1834, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "2": [ { - "commentStart": 2331, + "commentStart": 2181, "end": 0, "start": 0, "type": "NonCodeNode", @@ -2306,7 +2361,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 2362, + "commentStart": 2212, "end": 0, "expression": { "body": [ @@ -2314,10 +2369,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2362, + "commentStart": 2212, "end": 0, "name": { - "commentStart": 2362, + "commentStart": 2212, "end": 0, "name": "pipe", "start": 0, @@ -2327,7 +2382,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2362, + "commentStart": 2212, "end": 0, "start": 0, "type": "CallExpression", @@ -2338,7 +2393,7 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2399, + "commentStart": 2249, "end": 0, "name": "roll", "start": 0, @@ -2346,7 +2401,7 @@ description: Result of parsing pipe-flange-assembly.kcl }, "arg": { "argument": { - "commentStart": 2407, + "commentStart": 2257, "end": 0, "raw": "90", "start": 0, @@ -2357,7 +2412,7 @@ description: Result of parsing pipe-flange-assembly.kcl "suffix": "None" } }, - "commentStart": 2406, + "commentStart": 2256, "end": 0, "operator": "-", "start": 0, @@ -2368,14 +2423,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2418, + "commentStart": 2268, "end": 0, "name": "pitch", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2426, + "commentStart": 2276, "end": 0, "raw": "0", "start": 0, @@ -2390,14 +2445,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2436, + "commentStart": 2286, "end": 0, "name": "yaw", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2442, + "commentStart": 2292, "end": 0, "raw": "0", "start": 0, @@ -2412,10 +2467,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 2374, + "commentStart": 2224, "end": 0, "name": { - "commentStart": 2374, + "commentStart": 2224, "end": 0, "name": "rotate", "start": 0, @@ -2425,13 +2480,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2374, + "commentStart": 2224, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 2389, + "commentStart": 2239, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2443,117 +2498,128 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2485, + "commentStart": 2335, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2497, - "elements": [ - { - "commentStart": 2508, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 2520, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 2532, - "end": 0, - "left": { - "commentStart": 2532, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 2532, - "end": 0, - "name": { - "commentStart": 2532, - "end": 0, - "name": "flangeBaseThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 2554, - "end": 0, - "name": { - "commentStart": 2554, - "end": 0, - "name": "flangeFrontHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "-", - "right": { - "commentStart": 2574, - "end": 0, - "raw": "0.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], + "commentStart": 2339, "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } }, { "type": "LabeledArg", "label": { - "commentStart": 2595, + "commentStart": 2349, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 2353, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 2363, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 2367, + "end": 0, + "left": { + "commentStart": 2367, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 2367, + "end": 0, + "name": { + "commentStart": 2367, + "end": 0, + "name": "flangeBaseThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 2389, + "end": 0, + "name": { + "commentStart": 2389, + "end": 0, + "name": "flangeFrontHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 2409, + "end": 0, + "raw": "0.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 2421, "end": 0, "name": "global", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2604, + "commentStart": 2430, "end": 0, "raw": "true", "start": 0, @@ -2565,10 +2631,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 2457, + "commentStart": 2307, "end": 0, "name": { - "commentStart": 2457, + "commentStart": 2307, "end": 0, "name": "translate", "start": 0, @@ -2578,13 +2644,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2457, + "commentStart": 2307, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 2475, + "commentStart": 2325, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2592,7 +2658,7 @@ description: Result of parsing pipe-flange-assembly.kcl } } ], - "commentStart": 2362, + "commentStart": 2212, "end": 0, "start": 0, "type": "PipeExpression", @@ -2603,7 +2669,7 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "ExpressionStatement" }, { - "commentStart": 2616, + "commentStart": 2442, "end": 0, "expression": { "body": [ @@ -2611,10 +2677,10 @@ description: Result of parsing pipe-flange-assembly.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2618, + "commentStart": 2444, "end": 0, "name": { - "commentStart": 2618, + "commentStart": 2444, "end": 0, "name": "pipe", "start": 0, @@ -2624,7 +2690,7 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2618, + "commentStart": 2444, "end": 0, "start": 0, "type": "CallExpression", @@ -2635,14 +2701,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2655, + "commentStart": 2481, "end": 0, "name": "roll", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2662, + "commentStart": 2488, "end": 0, "raw": "90", "start": 0, @@ -2657,14 +2723,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2673, + "commentStart": 2499, "end": 0, "name": "pitch", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2681, + "commentStart": 2507, "end": 0, "raw": "0", "start": 0, @@ -2679,14 +2745,14 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2691, + "commentStart": 2517, "end": 0, "name": "yaw", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2697, + "commentStart": 2523, "end": 0, "raw": "0", "start": 0, @@ -2701,10 +2767,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 2630, + "commentStart": 2456, "end": 0, "name": { - "commentStart": 2630, + "commentStart": 2456, "end": 0, "name": "rotate", "start": 0, @@ -2714,13 +2780,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2630, + "commentStart": 2456, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 2645, + "commentStart": 2471, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2732,118 +2798,80 @@ description: Result of parsing pipe-flange-assembly.kcl { "type": "LabeledArg", "label": { - "commentStart": 2740, + "commentStart": 2566, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2752, - "elements": [ - { - "commentStart": 2763, + "commentStart": 2570, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 2580, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 2584, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 2594, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 2600, + "end": 0, + "left": { + "commentStart": 2600, "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 2775, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "argument": { - "commentStart": 2789, + "left": { + "commentStart": 2600, "end": 0, "left": { - "commentStart": 2789, + "commentStart": 2600, "end": 0, "left": { - "commentStart": 2789, + "commentStart": 2600, "end": 0, "left": { - "commentStart": 2789, - "end": 0, - "left": { - "commentStart": 2789, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 2789, - "end": 0, - "name": { - "commentStart": 2789, - "end": 0, - "name": "flangeBackHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 2808, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 2812, - "end": 0, - "name": { - "commentStart": 2812, - "end": 0, - "name": "gasketThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { "abs_path": false, - "commentStart": 2830, + "commentStart": 2600, "end": 0, "name": { - "commentStart": 2830, + "commentStart": 2600, "end": 0, - "name": "flangeBaseThickness", + "name": "flangeBackHeight", "start": 0, "type": "Identifier" }, @@ -2852,6 +2880,19 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "Name", "type": "Name" }, + "operator": "*", + "right": { + "commentStart": 2619, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" @@ -2859,12 +2900,12 @@ description: Result of parsing pipe-flange-assembly.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2852, + "commentStart": 2623, "end": 0, "name": { - "commentStart": 2852, + "commentStart": 2623, "end": 0, - "name": "flangeFrontHeight", + "name": "gasketThickness", "start": 0, "type": "Identifier" }, @@ -2877,48 +2918,84 @@ description: Result of parsing pipe-flange-assembly.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "-", + "operator": "+", "right": { - "commentStart": 2872, + "abs_path": false, + "commentStart": 2641, "end": 0, - "raw": "0.5", + "name": { + "commentStart": 2641, + "end": 0, + "name": "flangeBaseThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "commentStart": 2787, - "end": 0, - "operator": "-", + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 2663, + "end": 0, + "name": { + "commentStart": 2663, + "end": 0, + "name": "flangeFrontHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 2683, + "end": 0, + "raw": "0.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "commentStart": 2598, "end": 0, + "operator": "-", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "UnaryExpression", + "type": "UnaryExpression" } }, { "type": "LabeledArg", "label": { - "commentStart": 2894, + "commentStart": 2696, "end": 0, "name": "global", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2903, + "commentStart": 2705, "end": 0, "raw": "true", "start": 0, @@ -2930,10 +3007,10 @@ description: Result of parsing pipe-flange-assembly.kcl ], "callee": { "abs_path": false, - "commentStart": 2712, + "commentStart": 2538, "end": 0, "name": { - "commentStart": 2712, + "commentStart": 2538, "end": 0, "name": "translate", "start": 0, @@ -2943,13 +3020,13 @@ description: Result of parsing pipe-flange-assembly.kcl "start": 0, "type": "Name" }, - "commentStart": 2712, + "commentStart": 2538, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 2730, + "commentStart": 2556, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2957,7 +3034,7 @@ description: Result of parsing pipe-flange-assembly.kcl } } ], - "commentStart": 2618, + "commentStart": 2444, "end": 0, "start": 0, "type": "PipeExpression", @@ -3027,7 +3104,7 @@ description: Result of parsing pipe-flange-assembly.kcl "nonCodeNodes": { "13": [ { - "commentStart": 2616, + "commentStart": 2442, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ops.snap b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ops.snap index cb6de8327..e17bbd3b9 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/pipe-flange-assembly/ops.snap @@ -39,7 +39,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 451, 1670, - 5 + 6 ], "unlabeledArg": null, "labeledArgs": {}, @@ -657,7 +657,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 451, 1670, - 5 + 6 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1275,7 +1275,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 414, 870, - 6 + 7 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1523,9 +1523,9 @@ description: Operations executed pipe-flange-assembly.kcl "type": "UserDefinedFunctionCall", "name": "washer", "functionSourceRange": [ - 275, - 696, - 7 + 274, + 695, + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2022,9 +2022,9 @@ description: Operations executed pipe-flange-assembly.kcl "type": "UserDefinedFunctionCall", "name": "bolt", "functionSourceRange": [ - 365, - 1664, - 8 + 364, + 1663, + 9 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2524,7 +2524,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 297, 1231, - 9 + 10 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2839,7 +2839,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 244, 658, - 10 + 11 ], "unlabeledArg": null, "labeledArgs": {}, @@ -3083,7 +3083,7 @@ description: Operations executed pipe-flange-assembly.kcl "functionSourceRange": [ 244, 658, - 10 + 11 ], "unlabeledArg": null, "labeledArgs": {}, diff --git a/rust/kcl-lib/tests/kcl_samples/pipe-with-bend/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/pipe-with-bend/artifact_commands.snap index 669414905..adfbcf459 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe-with-bend/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/pipe-with-bend/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pipe-with-bend.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/pipe/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/pipe/artifact_commands.snap index a738d8abb..2a00a6cbd 100644 --- a/rust/kcl-lib/tests/kcl_samples/pipe/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/pipe/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pipe.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/poopy-shoe/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/poopy-shoe/artifact_commands.snap index 638fb7c64..a6175f25c 100644 --- a/rust/kcl-lib/tests/kcl_samples/poopy-shoe/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/poopy-shoe/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands poopy-shoe.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_commands.snap index 560ed4bf2..480854b6f 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands router-template-cross-bar.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_graph_flowchart.snap.md index b064f7b19..174a00100 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/artifact_graph_flowchart.snap.md @@ -1,59 +1,59 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[460, 506, 0]"] - 3["Segment
[512, 565, 0]"] - 4["Segment
[571, 673, 0]"] - 5["Segment
[679, 732, 0]"] - 6["Segment
[738, 785, 0]"] - 7["Segment
[791, 886, 0]"] - 8["Segment
[892, 963, 0]"] - 9["Segment
[969, 1020, 0]"] - 10["Segment
[1026, 1079, 0]"] - 11["Segment
[1085, 1154, 0]"] - 12["Segment
[1160, 1199, 0]"] - 13["Segment
[1205, 1235, 0]"] - 14["Segment
[1241, 1271, 0]"] - 15["Segment
[1277, 1307, 0]"] - 16["Segment
[1313, 1343, 0]"] - 17["Segment
[1349, 1378, 0]"] - 18["Segment
[1384, 1414, 0]"] - 19["Segment
[1420, 1449, 0]"] - 20["Segment
[1455, 1484, 0]"] - 21["Segment
[1490, 1586, 0]"] - 22["Segment
[1592, 1648, 0]"] - 23["Segment
[1654, 1661, 0]"] + 2["Path
[460, 503, 0]"] + 3["Segment
[509, 562, 0]"] + 4["Segment
[568, 670, 0]"] + 5["Segment
[676, 729, 0]"] + 6["Segment
[735, 782, 0]"] + 7["Segment
[788, 883, 0]"] + 8["Segment
[889, 960, 0]"] + 9["Segment
[966, 1017, 0]"] + 10["Segment
[1023, 1076, 0]"] + 11["Segment
[1082, 1151, 0]"] + 12["Segment
[1157, 1193, 0]"] + 13["Segment
[1199, 1229, 0]"] + 14["Segment
[1235, 1265, 0]"] + 15["Segment
[1271, 1301, 0]"] + 16["Segment
[1307, 1337, 0]"] + 17["Segment
[1343, 1372, 0]"] + 18["Segment
[1378, 1408, 0]"] + 19["Segment
[1414, 1443, 0]"] + 20["Segment
[1449, 1478, 0]"] + 21["Segment
[1484, 1580, 0]"] + 22["Segment
[1586, 1642, 0]"] + 23["Segment
[1648, 1655, 0]"] 24[Solid2d] end subgraph path85 [Path] - 85["Path
[1759, 1803, 0]"] - 86["Segment
[1809, 1871, 0]"] - 87["Segment
[1877, 1990, 0]"] - 88["Segment
[1996, 2116, 0]"] - 89["Segment
[2122, 2178, 0]"] - 90["Segment
[2184, 2191, 0]"] + 85["Path
[1753, 1797, 0]"] + 86["Segment
[1803, 1865, 0]"] + 87["Segment
[1871, 1984, 0]"] + 88["Segment
[1990, 2110, 0]"] + 89["Segment
[2116, 2172, 0]"] + 90["Segment
[2178, 2185, 0]"] 91[Solid2d] end subgraph path107 [Path] - 107["Path
[2290, 2335, 0]"] - 108["Segment
[2341, 2401, 0]"] - 109["Segment
[2407, 2520, 0]"] - 110["Segment
[2526, 2646, 0]"] - 111["Segment
[2652, 2708, 0]"] - 112["Segment
[2714, 2721, 0]"] + 107["Path
[2284, 2329, 0]"] + 108["Segment
[2335, 2395, 0]"] + 109["Segment
[2401, 2514, 0]"] + 110["Segment
[2520, 2640, 0]"] + 111["Segment
[2646, 2702, 0]"] + 112["Segment
[2708, 2715, 0]"] 113[Solid2d] end subgraph path129 [Path] - 129["Path
[2819, 2864, 0]"] - 130["Segment
[2870, 2937, 0]"] - 131["Segment
[2943, 3056, 0]"] - 132["Segment
[3062, 3182, 0]"] - 133["Segment
[3188, 3244, 0]"] - 134["Segment
[3250, 3257, 0]"] + 129["Path
[2813, 2858, 0]"] + 130["Segment
[2864, 2931, 0]"] + 131["Segment
[2937, 3050, 0]"] + 132["Segment
[3056, 3176, 0]"] + 133["Segment
[3182, 3238, 0]"] + 134["Segment
[3244, 3251, 0]"] 135[Solid2d] end 1["Plane
[437, 454, 0]"] - 25["Sweep Extrusion
[1675, 1705, 0]"] + 25["Sweep Extrusion
[1669, 1699, 0]"] 26[Wall] 27[Wall] 28[Wall] @@ -113,7 +113,7 @@ flowchart LR 82["SweepEdge Adjacent"] 83["SweepEdge Opposite"] 84["SweepEdge Adjacent"] - 92["Sweep Extrusion
[2205, 2236, 0]"] + 92["Sweep Extrusion
[2199, 2230, 0]"] 93[Wall] 94[Wall] 95[Wall] @@ -128,7 +128,7 @@ flowchart LR 104["SweepEdge Adjacent"] 105["SweepEdge Opposite"] 106["SweepEdge Adjacent"] - 114["Sweep Extrusion
[2736, 2767, 0]"] + 114["Sweep Extrusion
[2730, 2761, 0]"] 115[Wall] 116[Wall] 117[Wall] @@ -143,7 +143,7 @@ flowchart LR 126["SweepEdge Adjacent"] 127["SweepEdge Opposite"] 128["SweepEdge Adjacent"] - 136["Sweep Extrusion
[3271, 3301, 0]"] + 136["Sweep Extrusion
[3265, 3295, 0]"] 137[Wall] 138[Wall] 139[Wall] @@ -158,9 +158,9 @@ flowchart LR 148["SweepEdge Adjacent"] 149["SweepEdge Opposite"] 150["SweepEdge Adjacent"] - 151["StartSketchOnFace
[1719, 1753, 0]"] - 152["StartSketchOnFace
[2250, 2284, 0]"] - 153["StartSketchOnFace
[2781, 2813, 0]"] + 151["StartSketchOnFace
[1713, 1747, 0]"] + 152["StartSketchOnFace
[2244, 2278, 0]"] + 153["StartSketchOnFace
[2775, 2807, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/ast.snap b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/ast.snap index ec2ed7550..1c2d22a71 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/ast.snap @@ -573,30 +573,26 @@ description: Result of parsing router-template-cross-bar.kcl "commentStart": 475, "elements": [ { - "abs_path": false, "commentStart": 476, "end": 0, - "name": { - "commentStart": 476, - "end": 0, - "name": "ZERO", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } }, { - "commentStart": 482, + "commentStart": 479, "end": 0, "left": { "abs_path": false, - "commentStart": 482, + "commentStart": 479, "end": 0, "name": { - "commentStart": 482, + "commentStart": 479, "end": 0, "name": "depth", "start": 0, @@ -610,10 +606,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 490, + "commentStart": 487, "end": 0, "name": { - "commentStart": 490, + "commentStart": 487, "end": 0, "name": "templateGap", "start": 0, @@ -635,7 +631,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 504, + "commentStart": 501, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -668,21 +664,21 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 518, + "commentStart": 515, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 527, + "commentStart": 524, "end": 0, "left": { "abs_path": false, - "commentStart": 527, + "commentStart": 524, "end": 0, "name": { - "commentStart": 527, + "commentStart": 524, "end": 0, "name": "slateWidthHalf", "start": 0, @@ -696,10 +692,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 544, + "commentStart": 541, "end": 0, "name": { - "commentStart": 544, + "commentStart": 541, "end": 0, "name": "radius", "start": 0, @@ -718,14 +714,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 552, + "commentStart": 549, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 558, + "commentStart": 555, "end": 0, "start": 0, "type": "TagDeclarator", @@ -736,10 +732,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 512, + "commentStart": 509, "end": 0, "name": { - "commentStart": 512, + "commentStart": 509, "end": 0, "name": "xLine", "start": 0, @@ -749,7 +745,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 512, + "commentStart": 509, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -759,14 +755,14 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 575, + "commentStart": 572, "end": 0, "properties": [ { - "commentStart": 584, + "commentStart": 581, "end": 0, "key": { - "commentStart": 584, + "commentStart": 581, "end": 0, "name": "angleEnd", "start": 0, @@ -775,7 +771,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 595, + "commentStart": 592, "end": 0, "raw": "0", "start": 0, @@ -788,10 +784,10 @@ description: Result of parsing router-template-cross-bar.kcl } }, { - "commentStart": 605, + "commentStart": 602, "end": 0, "key": { - "commentStart": 605, + "commentStart": 602, "end": 0, "name": "angleStart", "start": 0, @@ -800,7 +796,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 618, + "commentStart": 615, "end": 0, "raw": "90", "start": 0, @@ -813,10 +809,10 @@ description: Result of parsing router-template-cross-bar.kcl } }, { - "commentStart": 629, + "commentStart": 626, "end": 0, "key": { - "commentStart": 629, + "commentStart": 626, "end": 0, "name": "radius", "start": 0, @@ -825,10 +821,10 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 638, + "commentStart": 635, "end": 0, "left": { - "commentStart": 638, + "commentStart": 635, "end": 0, "raw": "10", "start": 0, @@ -842,10 +838,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 643, + "commentStart": 640, "end": 0, "name": { - "commentStart": 643, + "commentStart": 640, "end": 0, "name": "templateGap", "start": 0, @@ -867,14 +863,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ObjectExpression" }, { - "commentStart": 663, + "commentStart": 660, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 666, + "commentStart": 663, "end": 0, "start": 0, "type": "TagDeclarator", @@ -884,10 +880,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 571, + "commentStart": 568, "end": 0, "name": { - "commentStart": 571, + "commentStart": 568, "end": 0, "name": "arc", "start": 0, @@ -897,7 +893,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 571, + "commentStart": 568, "end": 0, "start": 0, "type": "CallExpression", @@ -908,7 +904,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 685, + "commentStart": 682, "end": 0, "name": "endAbsolute", "start": 0, @@ -917,10 +913,10 @@ description: Result of parsing router-template-cross-bar.kcl "arg": { "argument": { "abs_path": false, - "commentStart": 700, + "commentStart": 697, "end": 0, "name": { - "commentStart": 700, + "commentStart": 697, "end": 0, "name": "templateThickness", "start": 0, @@ -931,7 +927,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name", "type": "Name" }, - "commentStart": 699, + "commentStart": 696, "end": 0, "operator": "-", "start": 0, @@ -942,14 +938,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 719, + "commentStart": 716, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 725, + "commentStart": 722, "end": 0, "start": 0, "type": "TagDeclarator", @@ -960,10 +956,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 679, + "commentStart": 676, "end": 0, "name": { - "commentStart": 679, + "commentStart": 676, "end": 0, "name": "yLine", "start": 0, @@ -973,7 +969,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 679, + "commentStart": 676, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -985,7 +981,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 744, + "commentStart": 741, "end": 0, "name": "length", "start": 0, @@ -993,10 +989,10 @@ description: Result of parsing router-template-cross-bar.kcl }, "arg": { "abs_path": false, - "commentStart": 753, + "commentStart": 750, "end": 0, "name": { - "commentStart": 753, + "commentStart": 750, "end": 0, "name": "templateThickness", "start": 0, @@ -1011,14 +1007,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 772, + "commentStart": 769, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 778, + "commentStart": 775, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1029,10 +1025,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 738, + "commentStart": 735, "end": 0, "name": { - "commentStart": 738, + "commentStart": 735, "end": 0, "name": "xLine", "start": 0, @@ -1042,7 +1038,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 738, + "commentStart": 735, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1054,29 +1050,29 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 797, + "commentStart": 794, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 812, + "commentStart": 809, "end": 0, "left": { - "commentStart": 812, + "commentStart": 809, "end": 0, "left": { - "commentStart": 812, + "commentStart": 809, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 820, + "commentStart": 817, "end": 0, "name": { - "commentStart": 820, + "commentStart": 817, "end": 0, "name": "seg01", "start": 0, @@ -1090,10 +1086,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 812, + "commentStart": 809, "end": 0, "name": { - "commentStart": 812, + "commentStart": 809, "end": 0, "name": "segEndY", "start": 0, @@ -1103,7 +1099,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 812, + "commentStart": 809, "end": 0, "start": 0, "type": "CallExpression", @@ -1112,10 +1108,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 829, + "commentStart": 826, "end": 0, "name": { - "commentStart": 829, + "commentStart": 826, "end": 0, "name": "templateThickness", "start": 0, @@ -1132,7 +1128,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "/", "right": { - "commentStart": 850, + "commentStart": 847, "end": 0, "raw": "2", "start": 0, @@ -1150,10 +1146,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 854, + "commentStart": 851, "end": 0, "name": { - "commentStart": 854, + "commentStart": 851, "end": 0, "name": "templateThickness", "start": 0, @@ -1172,14 +1168,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 873, + "commentStart": 870, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 879, + "commentStart": 876, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1190,10 +1186,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 791, + "commentStart": 788, "end": 0, "name": { - "commentStart": 791, + "commentStart": 788, "end": 0, "name": "yLine", "start": 0, @@ -1203,7 +1199,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 791, + "commentStart": 788, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1215,23 +1211,23 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 898, + "commentStart": 895, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 912, + "commentStart": 909, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 920, + "commentStart": 917, "end": 0, "name": { - "commentStart": 920, + "commentStart": 917, "end": 0, "name": "seg03", "start": 0, @@ -1245,10 +1241,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 912, + "commentStart": 909, "end": 0, "name": { - "commentStart": 912, + "commentStart": 909, "end": 0, "name": "segEndX", "start": 0, @@ -1258,7 +1254,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 912, + "commentStart": 909, "end": 0, "start": 0, "type": "CallExpression", @@ -1267,10 +1263,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 929, + "commentStart": 926, "end": 0, "name": { - "commentStart": 929, + "commentStart": 926, "end": 0, "name": "minClampingDistance", "start": 0, @@ -1289,14 +1285,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 950, + "commentStart": 947, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 956, + "commentStart": 953, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1307,10 +1303,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 892, + "commentStart": 889, "end": 0, "name": { - "commentStart": 892, + "commentStart": 889, "end": 0, "name": "xLine", "start": 0, @@ -1320,7 +1316,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 892, + "commentStart": 889, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1332,21 +1328,21 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 975, + "commentStart": 972, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 984, + "commentStart": 981, "end": 0, "left": { "abs_path": false, - "commentStart": 984, + "commentStart": 981, "end": 0, "name": { - "commentStart": 984, + "commentStart": 981, "end": 0, "name": "templateThickness", "start": 0, @@ -1359,7 +1355,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "*", "right": { - "commentStart": 1004, + "commentStart": 1001, "end": 0, "raw": "2", "start": 0, @@ -1378,14 +1374,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1007, + "commentStart": 1004, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1013, + "commentStart": 1010, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1396,10 +1392,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 969, + "commentStart": 966, "end": 0, "name": { - "commentStart": 969, + "commentStart": 966, "end": 0, "name": "yLine", "start": 0, @@ -1409,7 +1405,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 969, + "commentStart": 966, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1421,23 +1417,23 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1032, + "commentStart": 1029, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1046, + "commentStart": 1043, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 1054, + "commentStart": 1051, "end": 0, "name": { - "commentStart": 1054, + "commentStart": 1051, "end": 0, "name": "seg02", "start": 0, @@ -1451,10 +1447,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1046, + "commentStart": 1043, "end": 0, "name": { - "commentStart": 1046, + "commentStart": 1043, "end": 0, "name": "segEndX", "start": 0, @@ -1464,7 +1460,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1046, + "commentStart": 1043, "end": 0, "start": 0, "type": "CallExpression", @@ -1472,7 +1468,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "+", "right": { - "commentStart": 1063, + "commentStart": 1060, "end": 0, "raw": "0", "start": 0, @@ -1491,14 +1487,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1066, + "commentStart": 1063, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1072, + "commentStart": 1069, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1509,10 +1505,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1026, + "commentStart": 1023, "end": 0, "name": { - "commentStart": 1026, + "commentStart": 1023, "end": 0, "name": "xLine", "start": 0, @@ -1522,7 +1518,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1026, + "commentStart": 1023, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1534,23 +1530,23 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1091, + "commentStart": 1088, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1105, + "commentStart": 1102, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 1113, + "commentStart": 1110, "end": 0, "name": { - "commentStart": 1113, + "commentStart": 1110, "end": 0, "name": "seg01", "start": 0, @@ -1564,10 +1560,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1105, + "commentStart": 1102, "end": 0, "name": { - "commentStart": 1105, + "commentStart": 1102, "end": 0, "name": "segEndY", "start": 0, @@ -1577,7 +1573,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1105, + "commentStart": 1102, "end": 0, "start": 0, "type": "CallExpression", @@ -1586,10 +1582,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1122, + "commentStart": 1119, "end": 0, "name": { - "commentStart": 1122, + "commentStart": 1119, "end": 0, "name": "templateThickness", "start": 0, @@ -1608,14 +1604,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1141, + "commentStart": 1138, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1147, + "commentStart": 1144, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1626,10 +1622,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1085, + "commentStart": 1082, "end": 0, "name": { - "commentStart": 1085, + "commentStart": 1082, "end": 0, "name": "yLine", "start": 0, @@ -1639,7 +1635,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1085, + "commentStart": 1082, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1651,40 +1647,36 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1166, + "commentStart": 1163, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "abs_path": false, - "commentStart": 1180, + "commentStart": 1177, "end": 0, - "name": { - "commentStart": 1180, - "end": 0, - "name": "ZERO", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } }, { "type": "LabeledArg", "label": { - "commentStart": 1186, + "commentStart": 1180, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1192, + "commentStart": 1186, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1695,10 +1687,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1160, + "commentStart": 1157, "end": 0, "name": { - "commentStart": 1160, + "commentStart": 1157, "end": 0, "name": "xLine", "start": 0, @@ -1708,7 +1700,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1160, + "commentStart": 1157, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1720,7 +1712,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1211, + "commentStart": 1205, "end": 0, "name": "length", "start": 0, @@ -1731,10 +1723,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1228, + "commentStart": 1222, "end": 0, "name": { - "commentStart": 1228, + "commentStart": 1222, "end": 0, "name": "seg04", "start": 0, @@ -1748,10 +1740,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1221, + "commentStart": 1215, "end": 0, "name": { - "commentStart": 1221, + "commentStart": 1215, "end": 0, "name": "segLen", "start": 0, @@ -1761,13 +1753,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1221, + "commentStart": 1215, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1220, + "commentStart": 1214, "end": 0, "operator": "-", "start": 0, @@ -1778,10 +1770,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1205, + "commentStart": 1199, "end": 0, "name": { - "commentStart": 1205, + "commentStart": 1199, "end": 0, "name": "xLine", "start": 0, @@ -1791,7 +1783,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1205, + "commentStart": 1199, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1803,7 +1795,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1247, + "commentStart": 1241, "end": 0, "name": "length", "start": 0, @@ -1814,10 +1806,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1264, + "commentStart": 1258, "end": 0, "name": { - "commentStart": 1264, + "commentStart": 1258, "end": 0, "name": "seg10", "start": 0, @@ -1831,10 +1823,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1257, + "commentStart": 1251, "end": 0, "name": { - "commentStart": 1257, + "commentStart": 1251, "end": 0, "name": "segLen", "start": 0, @@ -1844,13 +1836,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1257, + "commentStart": 1251, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1256, + "commentStart": 1250, "end": 0, "operator": "-", "start": 0, @@ -1861,10 +1853,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1241, + "commentStart": 1235, "end": 0, "name": { - "commentStart": 1241, + "commentStart": 1235, "end": 0, "name": "yLine", "start": 0, @@ -1874,7 +1866,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1241, + "commentStart": 1235, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1886,7 +1878,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1283, + "commentStart": 1277, "end": 0, "name": "length", "start": 0, @@ -1897,10 +1889,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1300, + "commentStart": 1294, "end": 0, "name": { - "commentStart": 1300, + "commentStart": 1294, "end": 0, "name": "seg05", "start": 0, @@ -1914,10 +1906,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1293, + "commentStart": 1287, "end": 0, "name": { - "commentStart": 1293, + "commentStart": 1287, "end": 0, "name": "segLen", "start": 0, @@ -1927,13 +1919,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1293, + "commentStart": 1287, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1292, + "commentStart": 1286, "end": 0, "operator": "-", "start": 0, @@ -1944,10 +1936,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1277, + "commentStart": 1271, "end": 0, "name": { - "commentStart": 1277, + "commentStart": 1271, "end": 0, "name": "xLine", "start": 0, @@ -1957,7 +1949,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1277, + "commentStart": 1271, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1969,7 +1961,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1319, + "commentStart": 1313, "end": 0, "name": "length", "start": 0, @@ -1980,10 +1972,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1336, + "commentStart": 1330, "end": 0, "name": { - "commentStart": 1336, + "commentStart": 1330, "end": 0, "name": "seg08", "start": 0, @@ -1997,10 +1989,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1329, + "commentStart": 1323, "end": 0, "name": { - "commentStart": 1329, + "commentStart": 1323, "end": 0, "name": "segLen", "start": 0, @@ -2010,13 +2002,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1329, + "commentStart": 1323, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1328, + "commentStart": 1322, "end": 0, "operator": "-", "start": 0, @@ -2027,10 +2019,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1313, + "commentStart": 1307, "end": 0, "name": { - "commentStart": 1313, + "commentStart": 1307, "end": 0, "name": "yLine", "start": 0, @@ -2040,7 +2032,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1313, + "commentStart": 1307, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2052,7 +2044,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1355, + "commentStart": 1349, "end": 0, "name": "length", "start": 0, @@ -2062,10 +2054,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1371, + "commentStart": 1365, "end": 0, "name": { - "commentStart": 1371, + "commentStart": 1365, "end": 0, "name": "seg06", "start": 0, @@ -2079,10 +2071,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1364, + "commentStart": 1358, "end": 0, "name": { - "commentStart": 1364, + "commentStart": 1358, "end": 0, "name": "segLen", "start": 0, @@ -2092,7 +2084,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1364, + "commentStart": 1358, "end": 0, "start": 0, "type": "CallExpression", @@ -2102,10 +2094,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1349, + "commentStart": 1343, "end": 0, "name": { - "commentStart": 1349, + "commentStart": 1343, "end": 0, "name": "xLine", "start": 0, @@ -2115,7 +2107,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1349, + "commentStart": 1343, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2127,7 +2119,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1390, + "commentStart": 1384, "end": 0, "name": "length", "start": 0, @@ -2138,10 +2130,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1407, + "commentStart": 1401, "end": 0, "name": { - "commentStart": 1407, + "commentStart": 1401, "end": 0, "name": "seg02", "start": 0, @@ -2155,10 +2147,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1400, + "commentStart": 1394, "end": 0, "name": { - "commentStart": 1400, + "commentStart": 1394, "end": 0, "name": "segLen", "start": 0, @@ -2168,13 +2160,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1400, + "commentStart": 1394, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1399, + "commentStart": 1393, "end": 0, "operator": "-", "start": 0, @@ -2185,10 +2177,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1384, + "commentStart": 1378, "end": 0, "name": { - "commentStart": 1384, + "commentStart": 1378, "end": 0, "name": "yLine", "start": 0, @@ -2198,7 +2190,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1384, + "commentStart": 1378, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2210,7 +2202,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1426, + "commentStart": 1420, "end": 0, "name": "length", "start": 0, @@ -2220,10 +2212,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1442, + "commentStart": 1436, "end": 0, "name": { - "commentStart": 1442, + "commentStart": 1436, "end": 0, "name": "seg07", "start": 0, @@ -2237,10 +2229,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1435, + "commentStart": 1429, "end": 0, "name": { - "commentStart": 1435, + "commentStart": 1429, "end": 0, "name": "segLen", "start": 0, @@ -2250,7 +2242,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1435, + "commentStart": 1429, "end": 0, "start": 0, "type": "CallExpression", @@ -2260,10 +2252,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1420, + "commentStart": 1414, "end": 0, "name": { - "commentStart": 1420, + "commentStart": 1414, "end": 0, "name": "xLine", "start": 0, @@ -2273,7 +2265,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1420, + "commentStart": 1414, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2285,7 +2277,7 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1461, + "commentStart": 1455, "end": 0, "name": "length", "start": 0, @@ -2295,10 +2287,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1477, + "commentStart": 1471, "end": 0, "name": { - "commentStart": 1477, + "commentStart": 1471, "end": 0, "name": "seg03", "start": 0, @@ -2312,10 +2304,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1470, + "commentStart": 1464, "end": 0, "name": { - "commentStart": 1470, + "commentStart": 1464, "end": 0, "name": "segLen", "start": 0, @@ -2325,7 +2317,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1470, + "commentStart": 1464, "end": 0, "start": 0, "type": "CallExpression", @@ -2335,10 +2327,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1455, + "commentStart": 1449, "end": 0, "name": { - "commentStart": 1455, + "commentStart": 1449, "end": 0, "name": "yLine", "start": 0, @@ -2348,7 +2340,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1455, + "commentStart": 1449, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2358,14 +2350,14 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 1494, + "commentStart": 1488, "end": 0, "properties": [ { - "commentStart": 1503, + "commentStart": 1497, "end": 0, "key": { - "commentStart": 1503, + "commentStart": 1497, "end": 0, "name": "angleEnd", "start": 0, @@ -2374,7 +2366,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1514, + "commentStart": 1508, "end": 0, "raw": "90", "start": 0, @@ -2387,10 +2379,10 @@ description: Result of parsing router-template-cross-bar.kcl } }, { - "commentStart": 1525, + "commentStart": 1519, "end": 0, "key": { - "commentStart": 1525, + "commentStart": 1519, "end": 0, "name": "angleStart", "start": 0, @@ -2399,7 +2391,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1538, + "commentStart": 1532, "end": 0, "raw": "180", "start": 0, @@ -2412,10 +2404,10 @@ description: Result of parsing router-template-cross-bar.kcl } }, { - "commentStart": 1550, + "commentStart": 1544, "end": 0, "key": { - "commentStart": 1550, + "commentStart": 1544, "end": 0, "name": "radius", "start": 0, @@ -2424,10 +2416,10 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1559, + "commentStart": 1553, "end": 0, "left": { - "commentStart": 1559, + "commentStart": 1553, "end": 0, "raw": "10", "start": 0, @@ -2441,10 +2433,10 @@ description: Result of parsing router-template-cross-bar.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1564, + "commentStart": 1558, "end": 0, "name": { - "commentStart": 1564, + "commentStart": 1558, "end": 0, "name": "templateGap", "start": 0, @@ -2466,7 +2458,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ObjectExpression" }, { - "commentStart": 1584, + "commentStart": 1578, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2475,10 +2467,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1490, + "commentStart": 1484, "end": 0, "name": { - "commentStart": 1490, + "commentStart": 1484, "end": 0, "name": "arc", "start": 0, @@ -2488,7 +2480,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1490, + "commentStart": 1484, "end": 0, "start": 0, "type": "CallExpression", @@ -2499,19 +2491,19 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1597, + "commentStart": 1591, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1611, + "commentStart": 1605, "elements": [ { "arguments": [ { - "commentStart": 1626, + "commentStart": 1620, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2520,10 +2512,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1612, + "commentStart": 1606, "end": 0, "name": { - "commentStart": 1612, + "commentStart": 1606, "end": 0, "name": "profileStartX", "start": 0, @@ -2533,7 +2525,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1612, + "commentStart": 1606, "end": 0, "start": 0, "type": "CallExpression", @@ -2542,7 +2534,7 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 1644, + "commentStart": 1638, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2551,10 +2543,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1630, + "commentStart": 1624, "end": 0, "name": { - "commentStart": 1630, + "commentStart": 1624, "end": 0, "name": "profileStartY", "start": 0, @@ -2564,7 +2556,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1630, + "commentStart": 1624, "end": 0, "start": 0, "type": "CallExpression", @@ -2580,10 +2572,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1592, + "commentStart": 1586, "end": 0, "name": { - "commentStart": 1592, + "commentStart": 1586, "end": 0, "name": "line", "start": 0, @@ -2593,7 +2585,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1592, + "commentStart": 1586, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2604,10 +2596,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1654, + "commentStart": 1648, "end": 0, "name": { - "commentStart": 1654, + "commentStart": 1648, "end": 0, "name": "close", "start": 0, @@ -2617,7 +2609,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1654, + "commentStart": 1648, "end": 0, "start": 0, "type": "CallExpression", @@ -2640,12 +2632,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 1662, + "commentStart": 1656, "declaration": { - "commentStart": 1662, + "commentStart": 1656, "end": 0, "id": { - "commentStart": 1662, + "commentStart": 1656, "end": 0, "name": "extrude001", "start": 0, @@ -2656,14 +2648,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 1694, + "commentStart": 1688, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1703, + "commentStart": 1697, "end": 0, "raw": "5", "start": 0, @@ -2678,10 +2670,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1675, + "commentStart": 1669, "end": 0, "name": { - "commentStart": 1675, + "commentStart": 1669, "end": 0, "name": "extrude", "start": 0, @@ -2691,17 +2683,17 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1675, + "commentStart": 1669, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1683, + "commentStart": 1677, "end": 0, "name": { - "commentStart": 1683, + "commentStart": 1677, "end": 0, "name": "sketch001", "start": 0, @@ -2723,12 +2715,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 1705, + "commentStart": 1699, "declaration": { - "commentStart": 1707, + "commentStart": 1701, "end": 0, "id": { - "commentStart": 1707, + "commentStart": 1701, "end": 0, "name": "sketch003", "start": 0, @@ -2740,10 +2732,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 1733, + "commentStart": 1727, "end": 0, "name": { - "commentStart": 1733, + "commentStart": 1727, "end": 0, "name": "extrude001", "start": 0, @@ -2755,7 +2747,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name" }, { - "commentStart": 1745, + "commentStart": 1739, "end": 0, "raw": "'START'", "start": 0, @@ -2766,10 +2758,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1719, + "commentStart": 1713, "end": 0, "name": { - "commentStart": 1719, + "commentStart": 1713, "end": 0, "name": "startSketchOn", "start": 0, @@ -2779,7 +2771,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1719, + "commentStart": 1713, "end": 0, "start": 0, "type": "CallExpression", @@ -2788,14 +2780,14 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 1774, + "commentStart": 1768, "elements": [ { "abs_path": false, - "commentStart": 1775, + "commentStart": 1769, "end": 0, "name": { - "commentStart": 1775, + "commentStart": 1769, "end": 0, "name": "distanceToInsideEdge", "start": 0, @@ -2807,7 +2799,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name" }, { - "commentStart": 1797, + "commentStart": 1791, "end": 0, "raw": "0", "start": 0, @@ -2825,7 +2817,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 1801, + "commentStart": 1795, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2834,10 +2826,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1759, + "commentStart": 1753, "end": 0, "name": { - "commentStart": 1759, + "commentStart": 1753, "end": 0, "name": "startProfileAt", "start": 0, @@ -2847,7 +2839,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1759, + "commentStart": 1753, "end": 0, "start": 0, "type": "CallExpression", @@ -2856,10 +2848,10 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 1820, + "commentStart": 1814, "elements": [ { - "commentStart": 1821, + "commentStart": 1815, "end": 0, "raw": "180", "start": 0, @@ -2872,10 +2864,10 @@ description: Result of parsing router-template-cross-bar.kcl }, { "abs_path": false, - "commentStart": 1826, + "commentStart": 1820, "end": 0, "name": { - "commentStart": 1826, + "commentStart": 1820, "end": 0, "name": "templateThickness", "start": 0, @@ -2893,14 +2885,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 1846, + "commentStart": 1840, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 1849, + "commentStart": 1843, "end": 0, "start": 0, "type": "TagDeclarator", @@ -2910,10 +2902,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1809, + "commentStart": 1803, "end": 0, "name": { - "commentStart": 1809, + "commentStart": 1803, "end": 0, "name": "angledLine", "start": 0, @@ -2923,7 +2915,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1809, + "commentStart": 1803, "end": 0, "start": 0, "type": "CallExpression", @@ -2932,19 +2924,19 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 1888, + "commentStart": 1882, "elements": [ { - "commentStart": 1897, + "commentStart": 1891, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 1904, + "commentStart": 1898, "end": 0, "name": { - "commentStart": 1904, + "commentStart": 1898, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -2958,10 +2950,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1897, + "commentStart": 1891, "end": 0, "name": { - "commentStart": 1897, + "commentStart": 1891, "end": 0, "name": "segAng", "start": 0, @@ -2971,7 +2963,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1897, + "commentStart": 1891, "end": 0, "start": 0, "type": "CallExpression", @@ -2979,7 +2971,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "+", "right": { - "commentStart": 1928, + "commentStart": 1922, "end": 0, "raw": "90", "start": 0, @@ -2996,10 +2988,10 @@ description: Result of parsing router-template-cross-bar.kcl }, { "abs_path": false, - "commentStart": 1939, + "commentStart": 1933, "end": 0, "name": { - "commentStart": 1939, + "commentStart": 1933, "end": 0, "name": "templateThickness", "start": 0, @@ -3017,14 +3009,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 1965, + "commentStart": 1959, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 1968, + "commentStart": 1962, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3034,10 +3026,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1877, + "commentStart": 1871, "end": 0, "name": { - "commentStart": 1877, + "commentStart": 1871, "end": 0, "name": "angledLine", "start": 0, @@ -3047,7 +3039,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1877, + "commentStart": 1871, "end": 0, "start": 0, "type": "CallExpression", @@ -3056,16 +3048,16 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2007, + "commentStart": 2001, "elements": [ { "arguments": [ { "abs_path": false, - "commentStart": 2023, + "commentStart": 2017, "end": 0, "name": { - "commentStart": 2023, + "commentStart": 2017, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -3079,10 +3071,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2016, + "commentStart": 2010, "end": 0, "name": { - "commentStart": 2016, + "commentStart": 2010, "end": 0, "name": "segAng", "start": 0, @@ -3092,7 +3084,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2016, + "commentStart": 2010, "end": 0, "start": 0, "type": "CallExpression", @@ -3103,10 +3095,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 2061, + "commentStart": 2055, "end": 0, "name": { - "commentStart": 2061, + "commentStart": 2055, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -3120,10 +3112,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2054, + "commentStart": 2048, "end": 0, "name": { - "commentStart": 2054, + "commentStart": 2048, "end": 0, "name": "segLen", "start": 0, @@ -3133,13 +3125,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2054, + "commentStart": 2048, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 2053, + "commentStart": 2047, "end": 0, "operator": "-", "start": 0, @@ -3153,14 +3145,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2091, + "commentStart": 2085, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 2094, + "commentStart": 2088, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3170,10 +3162,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 1996, + "commentStart": 1990, "end": 0, "name": { - "commentStart": 1996, + "commentStart": 1990, "end": 0, "name": "angledLine", "start": 0, @@ -3183,7 +3175,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 1996, + "commentStart": 1990, "end": 0, "start": 0, "type": "CallExpression", @@ -3194,19 +3186,19 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 2127, + "commentStart": 2121, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2141, + "commentStart": 2135, "elements": [ { "arguments": [ { - "commentStart": 2156, + "commentStart": 2150, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3215,10 +3207,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2142, + "commentStart": 2136, "end": 0, "name": { - "commentStart": 2142, + "commentStart": 2136, "end": 0, "name": "profileStartX", "start": 0, @@ -3228,7 +3220,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2142, + "commentStart": 2136, "end": 0, "start": 0, "type": "CallExpression", @@ -3237,7 +3229,7 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2174, + "commentStart": 2168, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3246,10 +3238,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2160, + "commentStart": 2154, "end": 0, "name": { - "commentStart": 2160, + "commentStart": 2154, "end": 0, "name": "profileStartY", "start": 0, @@ -3259,7 +3251,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2160, + "commentStart": 2154, "end": 0, "start": 0, "type": "CallExpression", @@ -3275,10 +3267,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2122, + "commentStart": 2116, "end": 0, "name": { - "commentStart": 2122, + "commentStart": 2116, "end": 0, "name": "line", "start": 0, @@ -3288,7 +3280,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2122, + "commentStart": 2116, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3299,10 +3291,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2184, + "commentStart": 2178, "end": 0, "name": { - "commentStart": 2184, + "commentStart": 2178, "end": 0, "name": "close", "start": 0, @@ -3312,14 +3304,14 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2184, + "commentStart": 2178, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" } ], - "commentStart": 1719, + "commentStart": 1713, "end": 0, "start": 0, "type": "PipeExpression", @@ -3335,12 +3327,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 2192, + "commentStart": 2186, "declaration": { - "commentStart": 2192, + "commentStart": 2186, "end": 0, "id": { - "commentStart": 2192, + "commentStart": 2186, "end": 0, "name": "extrude003", "start": 0, @@ -3351,14 +3343,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 2224, + "commentStart": 2218, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2233, + "commentStart": 2227, "end": 0, "raw": "13", "start": 0, @@ -3373,10 +3365,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2205, + "commentStart": 2199, "end": 0, "name": { - "commentStart": 2205, + "commentStart": 2199, "end": 0, "name": "extrude", "start": 0, @@ -3386,17 +3378,17 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2205, + "commentStart": 2199, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 2213, + "commentStart": 2207, "end": 0, "name": { - "commentStart": 2213, + "commentStart": 2207, "end": 0, "name": "sketch003", "start": 0, @@ -3418,12 +3410,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 2236, + "commentStart": 2230, "declaration": { - "commentStart": 2238, + "commentStart": 2232, "end": 0, "id": { - "commentStart": 2238, + "commentStart": 2232, "end": 0, "name": "sketch002", "start": 0, @@ -3435,10 +3427,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 2264, + "commentStart": 2258, "end": 0, "name": { - "commentStart": 2264, + "commentStart": 2258, "end": 0, "name": "extrude001", "start": 0, @@ -3450,7 +3442,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name" }, { - "commentStart": 2276, + "commentStart": 2270, "end": 0, "raw": "'START'", "start": 0, @@ -3461,10 +3453,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2250, + "commentStart": 2244, "end": 0, "name": { - "commentStart": 2250, + "commentStart": 2244, "end": 0, "name": "startSketchOn", "start": 0, @@ -3474,7 +3466,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2250, + "commentStart": 2244, "end": 0, "start": 0, "type": "CallExpression", @@ -3483,15 +3475,15 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2305, + "commentStart": 2299, "elements": [ { "argument": { "abs_path": false, - "commentStart": 2307, + "commentStart": 2301, "end": 0, "name": { - "commentStart": 2307, + "commentStart": 2301, "end": 0, "name": "distanceToInsideEdge", "start": 0, @@ -3502,7 +3494,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name", "type": "Name" }, - "commentStart": 2306, + "commentStart": 2300, "end": 0, "operator": "-", "start": 0, @@ -3510,7 +3502,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "UnaryExpression" }, { - "commentStart": 2329, + "commentStart": 2323, "end": 0, "raw": "0", "start": 0, @@ -3528,7 +3520,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2333, + "commentStart": 2327, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3537,10 +3529,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2290, + "commentStart": 2284, "end": 0, "name": { - "commentStart": 2290, + "commentStart": 2284, "end": 0, "name": "startProfileAt", "start": 0, @@ -3550,7 +3542,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2290, + "commentStart": 2284, "end": 0, "start": 0, "type": "CallExpression", @@ -3559,10 +3551,10 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2352, + "commentStart": 2346, "elements": [ { - "commentStart": 2353, + "commentStart": 2347, "end": 0, "raw": "0", "start": 0, @@ -3575,10 +3567,10 @@ description: Result of parsing router-template-cross-bar.kcl }, { "abs_path": false, - "commentStart": 2356, + "commentStart": 2350, "end": 0, "name": { - "commentStart": 2356, + "commentStart": 2350, "end": 0, "name": "templateThickness", "start": 0, @@ -3596,14 +3588,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2376, + "commentStart": 2370, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 2379, + "commentStart": 2373, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3613,10 +3605,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2341, + "commentStart": 2335, "end": 0, "name": { - "commentStart": 2341, + "commentStart": 2335, "end": 0, "name": "angledLine", "start": 0, @@ -3626,7 +3618,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2341, + "commentStart": 2335, "end": 0, "start": 0, "type": "CallExpression", @@ -3635,19 +3627,19 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2418, + "commentStart": 2412, "elements": [ { - "commentStart": 2427, + "commentStart": 2421, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 2434, + "commentStart": 2428, "end": 0, "name": { - "commentStart": 2434, + "commentStart": 2428, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -3661,10 +3653,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2427, + "commentStart": 2421, "end": 0, "name": { - "commentStart": 2427, + "commentStart": 2421, "end": 0, "name": "segAng", "start": 0, @@ -3674,7 +3666,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2427, + "commentStart": 2421, "end": 0, "start": 0, "type": "CallExpression", @@ -3682,7 +3674,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "-", "right": { - "commentStart": 2458, + "commentStart": 2452, "end": 0, "raw": "90", "start": 0, @@ -3699,10 +3691,10 @@ description: Result of parsing router-template-cross-bar.kcl }, { "abs_path": false, - "commentStart": 2469, + "commentStart": 2463, "end": 0, "name": { - "commentStart": 2469, + "commentStart": 2463, "end": 0, "name": "templateThickness", "start": 0, @@ -3720,14 +3712,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2495, + "commentStart": 2489, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 2498, + "commentStart": 2492, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3737,10 +3729,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2407, + "commentStart": 2401, "end": 0, "name": { - "commentStart": 2407, + "commentStart": 2401, "end": 0, "name": "angledLine", "start": 0, @@ -3750,7 +3742,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2407, + "commentStart": 2401, "end": 0, "start": 0, "type": "CallExpression", @@ -3759,16 +3751,16 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2537, + "commentStart": 2531, "elements": [ { "arguments": [ { "abs_path": false, - "commentStart": 2553, + "commentStart": 2547, "end": 0, "name": { - "commentStart": 2553, + "commentStart": 2547, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -3782,10 +3774,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2546, + "commentStart": 2540, "end": 0, "name": { - "commentStart": 2546, + "commentStart": 2540, "end": 0, "name": "segAng", "start": 0, @@ -3795,7 +3787,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2546, + "commentStart": 2540, "end": 0, "start": 0, "type": "CallExpression", @@ -3806,10 +3798,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 2591, + "commentStart": 2585, "end": 0, "name": { - "commentStart": 2591, + "commentStart": 2585, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -3823,10 +3815,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2584, + "commentStart": 2578, "end": 0, "name": { - "commentStart": 2584, + "commentStart": 2578, "end": 0, "name": "segLen", "start": 0, @@ -3836,13 +3828,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2584, + "commentStart": 2578, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 2583, + "commentStart": 2577, "end": 0, "operator": "-", "start": 0, @@ -3856,14 +3848,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2621, + "commentStart": 2615, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 2624, + "commentStart": 2618, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3873,10 +3865,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2526, + "commentStart": 2520, "end": 0, "name": { - "commentStart": 2526, + "commentStart": 2520, "end": 0, "name": "angledLine", "start": 0, @@ -3886,7 +3878,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2526, + "commentStart": 2520, "end": 0, "start": 0, "type": "CallExpression", @@ -3897,19 +3889,19 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 2657, + "commentStart": 2651, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2671, + "commentStart": 2665, "elements": [ { "arguments": [ { - "commentStart": 2686, + "commentStart": 2680, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3918,10 +3910,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2672, + "commentStart": 2666, "end": 0, "name": { - "commentStart": 2672, + "commentStart": 2666, "end": 0, "name": "profileStartX", "start": 0, @@ -3931,7 +3923,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2672, + "commentStart": 2666, "end": 0, "start": 0, "type": "CallExpression", @@ -3940,7 +3932,7 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2704, + "commentStart": 2698, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3949,10 +3941,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2690, + "commentStart": 2684, "end": 0, "name": { - "commentStart": 2690, + "commentStart": 2684, "end": 0, "name": "profileStartY", "start": 0, @@ -3962,7 +3954,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2690, + "commentStart": 2684, "end": 0, "start": 0, "type": "CallExpression", @@ -3978,10 +3970,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2652, + "commentStart": 2646, "end": 0, "name": { - "commentStart": 2652, + "commentStart": 2646, "end": 0, "name": "line", "start": 0, @@ -3991,7 +3983,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2652, + "commentStart": 2646, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4002,10 +3994,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2714, + "commentStart": 2708, "end": 0, "name": { - "commentStart": 2714, + "commentStart": 2708, "end": 0, "name": "close", "start": 0, @@ -4015,14 +4007,14 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2714, + "commentStart": 2708, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" } ], - "commentStart": 2250, + "commentStart": 2244, "end": 0, "start": 0, "type": "PipeExpression", @@ -4038,12 +4030,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 2721, + "commentStart": 2715, "declaration": { - "commentStart": 2723, + "commentStart": 2717, "end": 0, "id": { - "commentStart": 2723, + "commentStart": 2717, "end": 0, "name": "extrude002", "start": 0, @@ -4054,14 +4046,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 2755, + "commentStart": 2749, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2764, + "commentStart": 2758, "end": 0, "raw": "13", "start": 0, @@ -4076,10 +4068,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2736, + "commentStart": 2730, "end": 0, "name": { - "commentStart": 2736, + "commentStart": 2730, "end": 0, "name": "extrude", "start": 0, @@ -4089,17 +4081,17 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2736, + "commentStart": 2730, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 2744, + "commentStart": 2738, "end": 0, "name": { - "commentStart": 2744, + "commentStart": 2738, "end": 0, "name": "sketch002", "start": 0, @@ -4121,12 +4113,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 2767, + "commentStart": 2761, "declaration": { - "commentStart": 2769, + "commentStart": 2763, "end": 0, "id": { - "commentStart": 2769, + "commentStart": 2763, "end": 0, "name": "sketch004", "start": 0, @@ -4138,10 +4130,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 2795, + "commentStart": 2789, "end": 0, "name": { - "commentStart": 2795, + "commentStart": 2789, "end": 0, "name": "extrude002", "start": 0, @@ -4153,7 +4145,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name" }, { - "commentStart": 2807, + "commentStart": 2801, "end": 0, "raw": "'END'", "start": 0, @@ -4164,10 +4156,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2781, + "commentStart": 2775, "end": 0, "name": { - "commentStart": 2781, + "commentStart": 2775, "end": 0, "name": "startSketchOn", "start": 0, @@ -4177,7 +4169,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2781, + "commentStart": 2775, "end": 0, "start": 0, "type": "CallExpression", @@ -4186,15 +4178,15 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2834, + "commentStart": 2828, "elements": [ { "argument": { "abs_path": false, - "commentStart": 2836, + "commentStart": 2830, "end": 0, "name": { - "commentStart": 2836, + "commentStart": 2830, "end": 0, "name": "distanceToInsideEdge", "start": 0, @@ -4205,7 +4197,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "Name", "type": "Name" }, - "commentStart": 2835, + "commentStart": 2829, "end": 0, "operator": "-", "start": 0, @@ -4213,7 +4205,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "UnaryExpression" }, { - "commentStart": 2858, + "commentStart": 2852, "end": 0, "raw": "0", "start": 0, @@ -4231,7 +4223,7 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2862, + "commentStart": 2856, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4240,10 +4232,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2819, + "commentStart": 2813, "end": 0, "name": { - "commentStart": 2819, + "commentStart": 2813, "end": 0, "name": "startProfileAt", "start": 0, @@ -4253,7 +4245,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2819, + "commentStart": 2813, "end": 0, "start": 0, "type": "CallExpression", @@ -4262,10 +4254,10 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2881, + "commentStart": 2875, "elements": [ { - "commentStart": 2882, + "commentStart": 2876, "end": 0, "raw": "0", "start": 0, @@ -4277,14 +4269,14 @@ description: Result of parsing router-template-cross-bar.kcl } }, { - "commentStart": 2885, + "commentStart": 2879, "end": 0, "left": { "abs_path": false, - "commentStart": 2885, + "commentStart": 2879, "end": 0, "name": { - "commentStart": 2885, + "commentStart": 2879, "end": 0, "name": "distanceToInsideEdge", "start": 0, @@ -4297,7 +4289,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "*", "right": { - "commentStart": 2908, + "commentStart": 2902, "end": 0, "raw": "2", "start": 0, @@ -4319,14 +4311,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 2912, + "commentStart": 2906, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 2915, + "commentStart": 2909, "end": 0, "start": 0, "type": "TagDeclarator", @@ -4336,10 +4328,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2870, + "commentStart": 2864, "end": 0, "name": { - "commentStart": 2870, + "commentStart": 2864, "end": 0, "name": "angledLine", "start": 0, @@ -4349,7 +4341,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2870, + "commentStart": 2864, "end": 0, "start": 0, "type": "CallExpression", @@ -4358,19 +4350,19 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 2954, + "commentStart": 2948, "elements": [ { - "commentStart": 2963, + "commentStart": 2957, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 2970, + "commentStart": 2964, "end": 0, "name": { - "commentStart": 2970, + "commentStart": 2964, "end": 0, "name": "rectangleSegmentA003", "start": 0, @@ -4384,10 +4376,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2963, + "commentStart": 2957, "end": 0, "name": { - "commentStart": 2963, + "commentStart": 2957, "end": 0, "name": "segAng", "start": 0, @@ -4397,7 +4389,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2963, + "commentStart": 2957, "end": 0, "start": 0, "type": "CallExpression", @@ -4405,7 +4397,7 @@ description: Result of parsing router-template-cross-bar.kcl }, "operator": "-", "right": { - "commentStart": 2994, + "commentStart": 2988, "end": 0, "raw": "90", "start": 0, @@ -4422,10 +4414,10 @@ description: Result of parsing router-template-cross-bar.kcl }, { "abs_path": false, - "commentStart": 3005, + "commentStart": 2999, "end": 0, "name": { - "commentStart": 3005, + "commentStart": 2999, "end": 0, "name": "templateThickness", "start": 0, @@ -4443,14 +4435,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 3031, + "commentStart": 3025, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 3034, + "commentStart": 3028, "end": 0, "start": 0, "type": "TagDeclarator", @@ -4460,10 +4452,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 2943, + "commentStart": 2937, "end": 0, "name": { - "commentStart": 2943, + "commentStart": 2937, "end": 0, "name": "angledLine", "start": 0, @@ -4473,7 +4465,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 2943, + "commentStart": 2937, "end": 0, "start": 0, "type": "CallExpression", @@ -4482,16 +4474,16 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 3073, + "commentStart": 3067, "elements": [ { "arguments": [ { "abs_path": false, - "commentStart": 3089, + "commentStart": 3083, "end": 0, "name": { - "commentStart": 3089, + "commentStart": 3083, "end": 0, "name": "rectangleSegmentA003", "start": 0, @@ -4505,10 +4497,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3082, + "commentStart": 3076, "end": 0, "name": { - "commentStart": 3082, + "commentStart": 3076, "end": 0, "name": "segAng", "start": 0, @@ -4518,7 +4510,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3082, + "commentStart": 3076, "end": 0, "start": 0, "type": "CallExpression", @@ -4529,10 +4521,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [ { "abs_path": false, - "commentStart": 3127, + "commentStart": 3121, "end": 0, "name": { - "commentStart": 3127, + "commentStart": 3121, "end": 0, "name": "rectangleSegmentA003", "start": 0, @@ -4546,10 +4538,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3120, + "commentStart": 3114, "end": 0, "name": { - "commentStart": 3120, + "commentStart": 3114, "end": 0, "name": "segLen", "start": 0, @@ -4559,13 +4551,13 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3120, + "commentStart": 3114, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 3119, + "commentStart": 3113, "end": 0, "operator": "-", "start": 0, @@ -4579,14 +4571,14 @@ description: Result of parsing router-template-cross-bar.kcl "type": "ArrayExpression" }, { - "commentStart": 3157, + "commentStart": 3151, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 3160, + "commentStart": 3154, "end": 0, "start": 0, "type": "TagDeclarator", @@ -4596,10 +4588,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3062, + "commentStart": 3056, "end": 0, "name": { - "commentStart": 3062, + "commentStart": 3056, "end": 0, "name": "angledLine", "start": 0, @@ -4609,7 +4601,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3062, + "commentStart": 3056, "end": 0, "start": 0, "type": "CallExpression", @@ -4620,19 +4612,19 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 3193, + "commentStart": 3187, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3207, + "commentStart": 3201, "elements": [ { "arguments": [ { - "commentStart": 3222, + "commentStart": 3216, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4641,10 +4633,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3208, + "commentStart": 3202, "end": 0, "name": { - "commentStart": 3208, + "commentStart": 3202, "end": 0, "name": "profileStartX", "start": 0, @@ -4654,7 +4646,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3208, + "commentStart": 3202, "end": 0, "start": 0, "type": "CallExpression", @@ -4663,7 +4655,7 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 3240, + "commentStart": 3234, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -4672,10 +4664,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3226, + "commentStart": 3220, "end": 0, "name": { - "commentStart": 3226, + "commentStart": 3220, "end": 0, "name": "profileStartY", "start": 0, @@ -4685,7 +4677,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3226, + "commentStart": 3220, "end": 0, "start": 0, "type": "CallExpression", @@ -4701,10 +4693,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3188, + "commentStart": 3182, "end": 0, "name": { - "commentStart": 3188, + "commentStart": 3182, "end": 0, "name": "line", "start": 0, @@ -4714,7 +4706,7 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3188, + "commentStart": 3182, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -4725,10 +4717,10 @@ description: Result of parsing router-template-cross-bar.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 3250, + "commentStart": 3244, "end": 0, "name": { - "commentStart": 3250, + "commentStart": 3244, "end": 0, "name": "close", "start": 0, @@ -4738,14 +4730,14 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3250, + "commentStart": 3244, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" } ], - "commentStart": 2781, + "commentStart": 2775, "end": 0, "start": 0, "type": "PipeExpression", @@ -4761,12 +4753,12 @@ description: Result of parsing router-template-cross-bar.kcl "type": "VariableDeclaration" }, { - "commentStart": 3258, + "commentStart": 3252, "declaration": { - "commentStart": 3258, + "commentStart": 3252, "end": 0, "id": { - "commentStart": 3258, + "commentStart": 3252, "end": 0, "name": "extrude004", "start": 0, @@ -4777,14 +4769,14 @@ description: Result of parsing router-template-cross-bar.kcl { "type": "LabeledArg", "label": { - "commentStart": 3290, + "commentStart": 3284, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 3299, + "commentStart": 3293, "end": 0, "raw": "4", "start": 0, @@ -4799,10 +4791,10 @@ description: Result of parsing router-template-cross-bar.kcl ], "callee": { "abs_path": false, - "commentStart": 3271, + "commentStart": 3265, "end": 0, "name": { - "commentStart": 3271, + "commentStart": 3265, "end": 0, "name": "extrude", "start": 0, @@ -4812,17 +4804,17 @@ description: Result of parsing router-template-cross-bar.kcl "start": 0, "type": "Name" }, - "commentStart": 3271, + "commentStart": 3265, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 3279, + "commentStart": 3273, "end": 0, "name": { - "commentStart": 3279, + "commentStart": 3273, "end": 0, "name": "sketch004", "start": 0, @@ -4903,7 +4895,7 @@ description: Result of parsing router-template-cross-bar.kcl "nonCodeNodes": { "10": [ { - "commentStart": 1705, + "commentStart": 1699, "end": 0, "start": 0, "type": "NonCodeNode", @@ -4914,7 +4906,7 @@ description: Result of parsing router-template-cross-bar.kcl ], "12": [ { - "commentStart": 2236, + "commentStart": 2230, "end": 0, "start": 0, "type": "NonCodeNode", @@ -4925,7 +4917,7 @@ description: Result of parsing router-template-cross-bar.kcl ], "13": [ { - "commentStart": 2721, + "commentStart": 2715, "end": 0, "start": 0, "type": "NonCodeNode", @@ -4936,7 +4928,7 @@ description: Result of parsing router-template-cross-bar.kcl ], "14": [ { - "commentStart": 2767, + "commentStart": 2761, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/program_memory.snap index bcb135c7e..969d993ad 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-cross-bar/program_memory.snap @@ -35,9 +35,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -48,9 +48,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -61,9 +61,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -74,9 +74,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -87,9 +87,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -100,9 +100,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -113,9 +113,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -126,9 +126,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -139,9 +139,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -152,9 +152,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -238,9 +238,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -269,9 +269,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -294,9 +294,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -319,9 +319,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -344,9 +344,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -369,9 +369,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -394,9 +394,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -419,9 +419,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -444,9 +444,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -469,9 +469,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -815,9 +815,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -828,9 +828,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -841,9 +841,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -871,9 +871,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -896,9 +896,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -921,9 +921,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -1005,9 +1005,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -1018,9 +1018,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -1031,9 +1031,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -1044,9 +1044,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -1057,9 +1057,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -1070,9 +1070,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -1083,9 +1083,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -1096,9 +1096,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -1109,9 +1109,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -1122,9 +1122,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -1208,9 +1208,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -1239,9 +1239,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -1264,9 +1264,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -1289,9 +1289,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -1314,9 +1314,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -1339,9 +1339,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -1364,9 +1364,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -1389,9 +1389,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -1414,9 +1414,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -1439,9 +1439,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -1834,9 +1834,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1849, - "end": 1870, - "start": 1849, + "commentStart": 1843, + "end": 1864, + "start": 1843, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -1847,9 +1847,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1968, - "end": 1989, - "start": 1968, + "commentStart": 1962, + "end": 1983, + "start": 1962, "type": "TagDeclarator", "value": "rectangleSegmentB002" }, @@ -1860,9 +1860,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2094, - "end": 2115, - "start": 2094, + "commentStart": 2088, + "end": 2109, + "start": 2088, "type": "TagDeclarator", "value": "rectangleSegmentC002" }, @@ -1890,9 +1890,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 1849, - "end": 1870, - "start": 1849, + "commentStart": 1843, + "end": 1864, + "start": 1843, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -1915,9 +1915,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 1968, - "end": 1989, - "start": 1968, + "commentStart": 1962, + "end": 1983, + "start": 1962, "type": "TagDeclarator", "value": "rectangleSegmentB002" }, @@ -1940,9 +1940,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2094, - "end": 2115, - "start": 2094, + "commentStart": 2088, + "end": 2109, + "start": 2088, "type": "TagDeclarator", "value": "rectangleSegmentC002" }, @@ -2024,9 +2024,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -2037,9 +2037,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -2050,9 +2050,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -2063,9 +2063,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -2076,9 +2076,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -2089,9 +2089,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -2102,9 +2102,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -2115,9 +2115,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -2128,9 +2128,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -2141,9 +2141,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -2227,9 +2227,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -2258,9 +2258,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -2283,9 +2283,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -2308,9 +2308,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -2333,9 +2333,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -2358,9 +2358,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -2383,9 +2383,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -2408,9 +2408,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -2433,9 +2433,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -2458,9 +2458,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -2853,9 +2853,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2915, - "end": 2936, - "start": 2915, + "commentStart": 2909, + "end": 2930, + "start": 2909, "type": "TagDeclarator", "value": "rectangleSegmentA003" }, @@ -2866,9 +2866,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 3034, - "end": 3055, - "start": 3034, + "commentStart": 3028, + "end": 3049, + "start": 3028, "type": "TagDeclarator", "value": "rectangleSegmentB003" }, @@ -2879,9 +2879,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 3160, - "end": 3181, - "start": 3160, + "commentStart": 3154, + "end": 3175, + "start": 3154, "type": "TagDeclarator", "value": "rectangleSegmentC003" }, @@ -2909,9 +2909,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2915, - "end": 2936, - "start": 2915, + "commentStart": 2909, + "end": 2930, + "start": 2909, "type": "TagDeclarator", "value": "rectangleSegmentA003" }, @@ -2934,9 +2934,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 3034, - "end": 3055, - "start": 3034, + "commentStart": 3028, + "end": 3049, + "start": 3028, "type": "TagDeclarator", "value": "rectangleSegmentB003" }, @@ -2959,9 +2959,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 3160, - "end": 3181, - "start": 3160, + "commentStart": 3154, + "end": 3175, + "start": 3154, "type": "TagDeclarator", "value": "rectangleSegmentC003" }, @@ -3043,9 +3043,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -3056,9 +3056,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -3069,9 +3069,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -3099,9 +3099,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -3124,9 +3124,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -3149,9 +3149,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -3233,9 +3233,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -3246,9 +3246,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -3259,9 +3259,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -3272,9 +3272,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -3285,9 +3285,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -3298,9 +3298,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -3311,9 +3311,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -3324,9 +3324,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -3337,9 +3337,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -3350,9 +3350,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -3436,9 +3436,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -3467,9 +3467,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -3492,9 +3492,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -3517,9 +3517,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -3542,9 +3542,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -3567,9 +3567,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -3592,9 +3592,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -3617,9 +3617,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -3642,9 +3642,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -3667,9 +3667,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -4249,9 +4249,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -4280,9 +4280,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -4305,9 +4305,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -4330,9 +4330,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -4355,9 +4355,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -4380,9 +4380,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -4405,9 +4405,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -4430,9 +4430,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -4455,9 +4455,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -4480,9 +4480,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -4823,9 +4823,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -4848,9 +4848,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -4873,9 +4873,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -4957,9 +4957,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -4970,9 +4970,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -4983,9 +4983,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -4996,9 +4996,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -5009,9 +5009,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -5022,9 +5022,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -5035,9 +5035,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -5048,9 +5048,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -5061,9 +5061,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -5074,9 +5074,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -5160,9 +5160,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -5191,9 +5191,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -5216,9 +5216,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -5241,9 +5241,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -5266,9 +5266,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -5291,9 +5291,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -5316,9 +5316,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -5341,9 +5341,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -5366,9 +5366,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -5391,9 +5391,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -5783,9 +5783,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 1849, - "end": 1870, - "start": 1849, + "commentStart": 1843, + "end": 1864, + "start": 1843, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -5808,9 +5808,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 1968, - "end": 1989, - "start": 1968, + "commentStart": 1962, + "end": 1983, + "start": 1962, "type": "TagDeclarator", "value": "rectangleSegmentB002" }, @@ -5833,9 +5833,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2094, - "end": 2115, - "start": 2094, + "commentStart": 2088, + "end": 2109, + "start": 2088, "type": "TagDeclarator", "value": "rectangleSegmentC002" }, @@ -5917,9 +5917,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -5930,9 +5930,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -5943,9 +5943,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -5956,9 +5956,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -5969,9 +5969,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -5982,9 +5982,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -5995,9 +5995,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -6008,9 +6008,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -6021,9 +6021,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -6034,9 +6034,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -6120,9 +6120,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -6151,9 +6151,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -6176,9 +6176,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -6201,9 +6201,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -6226,9 +6226,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -6251,9 +6251,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -6276,9 +6276,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -6301,9 +6301,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -6326,9 +6326,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -6351,9 +6351,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -6743,9 +6743,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2915, - "end": 2936, - "start": 2915, + "commentStart": 2909, + "end": 2930, + "start": 2909, "type": "TagDeclarator", "value": "rectangleSegmentA003" }, @@ -6768,9 +6768,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 3034, - "end": 3055, - "start": 3034, + "commentStart": 3028, + "end": 3049, + "start": 3028, "type": "TagDeclarator", "value": "rectangleSegmentB003" }, @@ -6793,9 +6793,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 3160, - "end": 3181, - "start": 3160, + "commentStart": 3154, + "end": 3175, + "start": 3154, "type": "TagDeclarator", "value": "rectangleSegmentC003" }, @@ -6877,9 +6877,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -6890,9 +6890,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -6903,9 +6903,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -6933,9 +6933,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2379, - "end": 2400, - "start": 2379, + "commentStart": 2373, + "end": 2394, + "start": 2373, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -6958,9 +6958,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 0.0 ], "tag": { - "commentStart": 2498, - "end": 2519, - "start": 2498, + "commentStart": 2492, + "end": 2513, + "start": 2492, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -6983,9 +6983,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 2624, - "end": 2645, - "start": 2624, + "commentStart": 2618, + "end": 2639, + "start": 2618, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -7067,9 +7067,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -7080,9 +7080,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -7093,9 +7093,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -7106,9 +7106,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -7119,9 +7119,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -7132,9 +7132,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -7145,9 +7145,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -7158,9 +7158,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -7171,9 +7171,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -7184,9 +7184,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, @@ -7270,9 +7270,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 31.8813 ], "tag": { - "commentStart": 558, - "end": 564, - "start": 558, + "commentStart": 555, + "end": 561, + "start": 555, "type": "TagDeclarator", "value": "seg01" }, @@ -7301,9 +7301,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl ], "radius": 11.88125, "tag": { - "commentStart": 666, - "end": 672, - "start": 666, + "commentStart": 663, + "end": 669, + "start": 663, "type": "TagDeclarator", "value": "seg09" }, @@ -7326,9 +7326,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 20.0 ], "tag": { - "commentStart": 725, - "end": 731, - "start": 725, + "commentStart": 722, + "end": 728, + "start": 722, "type": "TagDeclarator", "value": "seg03" }, @@ -7351,9 +7351,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 778, - "end": 784, - "start": 778, + "commentStart": 775, + "end": 781, + "start": 775, "type": "TagDeclarator", "value": "seg07" }, @@ -7376,9 +7376,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl -10.0 ], "tag": { - "commentStart": 879, - "end": 885, - "start": 879, + "commentStart": 876, + "end": 882, + "start": 876, "type": "TagDeclarator", "value": "seg02" }, @@ -7401,9 +7401,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 956, - "end": 962, - "start": 956, + "commentStart": 953, + "end": 959, + "start": 953, "type": "TagDeclarator", "value": "seg06" }, @@ -7426,9 +7426,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 10.9406 ], "tag": { - "commentStart": 1013, - "end": 1019, - "start": 1013, + "commentStart": 1010, + "end": 1016, + "start": 1010, "type": "TagDeclarator", "value": "seg08" }, @@ -7451,9 +7451,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1072, - "end": 1078, - "start": 1072, + "commentStart": 1069, + "end": 1075, + "start": 1069, "type": "TagDeclarator", "value": "seg05" }, @@ -7476,9 +7476,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 30.9406 ], "tag": { - "commentStart": 1147, - "end": 1153, - "start": 1147, + "commentStart": 1144, + "end": 1150, + "start": 1144, "type": "TagDeclarator", "value": "seg10" }, @@ -7501,9 +7501,9 @@ description: Variables in memory after executing router-template-cross-bar.kcl 41.8813 ], "tag": { - "commentStart": 1192, - "end": 1198, - "start": 1192, + "commentStart": 1186, + "end": 1192, + "start": 1186, "type": "TagDeclarator", "value": "seg04" }, diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_commands.snap index 2fedc3b87..a1bc94bf9 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands router-template-slate.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_graph_flowchart.snap.md index 4c27a6527..2cbc5e206 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/router-template-slate/artifact_graph_flowchart.snap.md @@ -7,36 +7,36 @@ flowchart LR 5["Segment
[705, 781, 0]"] 6["Segment
[787, 856, 0]"] 7["Segment
[862, 902, 0]"] - 8["Segment
[908, 947, 0]"] - 9["Segment
[987, 1017, 0]"] - 10["Segment
[1023, 1052, 0]"] - 11["Segment
[1058, 1087, 0]"] - 12["Segment
[1093, 1122, 0]"] - 13["Segment
[1128, 1228, 0]"] - 14["Segment
[1234, 1290, 0]"] - 15["Segment
[1296, 1303, 0]"] + 8["Segment
[908, 944, 0]"] + 9["Segment
[984, 1014, 0]"] + 10["Segment
[1020, 1049, 0]"] + 11["Segment
[1055, 1084, 0]"] + 12["Segment
[1090, 1119, 0]"] + 13["Segment
[1125, 1225, 0]"] + 14["Segment
[1231, 1287, 0]"] + 15["Segment
[1293, 1300, 0]"] 16[Solid2d] end subgraph path52 [Path] - 52["Path
[1458, 1558, 0]"] - 53["Segment
[1564, 1611, 0]"] - 54["Segment
[1617, 1732, 0]"] - 55["Segment
[1738, 1858, 0]"] - 56["Segment
[1864, 1920, 0]"] - 57["Segment
[1926, 1933, 0]"] + 52["Path
[1455, 1555, 0]"] + 53["Segment
[1561, 1608, 0]"] + 54["Segment
[1614, 1729, 0]"] + 55["Segment
[1735, 1855, 0]"] + 56["Segment
[1861, 1917, 0]"] + 57["Segment
[1923, 1930, 0]"] 58[Solid2d] end subgraph path74 [Path] - 74["Path
[2090, 2189, 0]"] - 75["Segment
[2195, 2241, 0]"] - 76["Segment
[2247, 2339, 0]"] - 77["Segment
[2345, 2442, 0]"] - 78["Segment
[2448, 2504, 0]"] - 79["Segment
[2510, 2517, 0]"] + 74["Path
[2087, 2186, 0]"] + 75["Segment
[2192, 2238, 0]"] + 76["Segment
[2244, 2336, 0]"] + 77["Segment
[2342, 2439, 0]"] + 78["Segment
[2445, 2501, 0]"] + 79["Segment
[2507, 2514, 0]"] 80[Solid2d] end 1["Plane
[484, 501, 0]"] - 17["Sweep Extrusion
[1346, 1376, 0]"] + 17["Sweep Extrusion
[1343, 1373, 0]"] 18[Wall] 19[Wall] 20[Wall] @@ -71,7 +71,7 @@ flowchart LR 49["SweepEdge Opposite"] 50["SweepEdge Adjacent"] 51["SweepEdge Opposite"] - 59["Sweep Extrusion
[1977, 2009, 0]"] + 59["Sweep Extrusion
[1974, 2006, 0]"] 60[Wall] 61[Wall] 62[Wall] @@ -86,7 +86,7 @@ flowchart LR 71["SweepEdge Adjacent"] 72["SweepEdge Opposite"] 73["SweepEdge Adjacent"] - 81["Sweep Extrusion
[2560, 2592, 0]"] + 81["Sweep Extrusion
[2557, 2589, 0]"] 82[Wall] 83[Wall] 84[Wall] @@ -101,8 +101,8 @@ flowchart LR 93["SweepEdge Adjacent"] 94["SweepEdge Opposite"] 95["SweepEdge Adjacent"] - 96["StartSketchOnFace
[1418, 1452, 0]"] - 97["StartSketchOnFace
[2050, 2084, 0]"] + 96["StartSketchOnFace
[1415, 1449, 0]"] + 97["StartSketchOnFace
[2047, 2081, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-slate/ast.snap b/rust/kcl-lib/tests/kcl_samples/router-template-slate/ast.snap index b0a744e13..9add12d6e 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-slate/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-slate/ast.snap @@ -1234,33 +1234,29 @@ description: Result of parsing router-template-slate.kcl "type": "Identifier" }, "arg": { - "abs_path": false, "commentStart": 928, "end": 0, - "name": { - "commentStart": 928, - "end": 0, - "name": "ZERO", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } }, { "type": "LabeledArg", "label": { - "commentStart": 934, + "commentStart": 931, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 940, + "commentStart": 937, "end": 0, "start": 0, "type": "TagDeclarator", @@ -1296,7 +1292,7 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 993, + "commentStart": 990, "end": 0, "name": "length", "start": 0, @@ -1307,10 +1303,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1010, + "commentStart": 1007, "end": 0, "name": { - "commentStart": 1010, + "commentStart": 1007, "end": 0, "name": "seg02", "start": 0, @@ -1324,10 +1320,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1003, + "commentStart": 1000, "end": 0, "name": { - "commentStart": 1003, + "commentStart": 1000, "end": 0, "name": "segLen", "start": 0, @@ -1337,13 +1333,13 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1003, + "commentStart": 1000, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1002, + "commentStart": 999, "end": 0, "operator": "-", "start": 0, @@ -1354,10 +1350,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 987, + "commentStart": 984, "end": 0, "name": { - "commentStart": 987, + "commentStart": 984, "end": 0, "name": "xLine", "start": 0, @@ -1367,7 +1363,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 987, + "commentStart": 984, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1379,7 +1375,7 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1029, + "commentStart": 1026, "end": 0, "name": "length", "start": 0, @@ -1389,10 +1385,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1045, + "commentStart": 1042, "end": 0, "name": { - "commentStart": 1045, + "commentStart": 1042, "end": 0, "name": "seg03", "start": 0, @@ -1406,10 +1402,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1038, + "commentStart": 1035, "end": 0, "name": { - "commentStart": 1038, + "commentStart": 1035, "end": 0, "name": "segLen", "start": 0, @@ -1419,7 +1415,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1038, + "commentStart": 1035, "end": 0, "start": 0, "type": "CallExpression", @@ -1429,10 +1425,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1023, + "commentStart": 1020, "end": 0, "name": { - "commentStart": 1023, + "commentStart": 1020, "end": 0, "name": "yLine", "start": 0, @@ -1442,7 +1438,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1023, + "commentStart": 1020, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1454,7 +1450,7 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1064, + "commentStart": 1061, "end": 0, "name": "length", "start": 0, @@ -1464,10 +1460,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1080, + "commentStart": 1077, "end": 0, "name": { - "commentStart": 1080, + "commentStart": 1077, "end": 0, "name": "seg04", "start": 0, @@ -1481,10 +1477,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1073, + "commentStart": 1070, "end": 0, "name": { - "commentStart": 1073, + "commentStart": 1070, "end": 0, "name": "segLen", "start": 0, @@ -1494,7 +1490,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1073, + "commentStart": 1070, "end": 0, "start": 0, "type": "CallExpression", @@ -1504,10 +1500,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1058, + "commentStart": 1055, "end": 0, "name": { - "commentStart": 1058, + "commentStart": 1055, "end": 0, "name": "xLine", "start": 0, @@ -1517,7 +1513,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1058, + "commentStart": 1055, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1529,7 +1525,7 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1099, + "commentStart": 1096, "end": 0, "name": "length", "start": 0, @@ -1539,10 +1535,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1115, + "commentStart": 1112, "end": 0, "name": { - "commentStart": 1115, + "commentStart": 1112, "end": 0, "name": "seg05", "start": 0, @@ -1556,10 +1552,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1108, + "commentStart": 1105, "end": 0, "name": { - "commentStart": 1108, + "commentStart": 1105, "end": 0, "name": "segLen", "start": 0, @@ -1569,7 +1565,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1108, + "commentStart": 1105, "end": 0, "start": 0, "type": "CallExpression", @@ -1579,10 +1575,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1093, + "commentStart": 1090, "end": 0, "name": { - "commentStart": 1093, + "commentStart": 1090, "end": 0, "name": "yLine", "start": 0, @@ -1592,7 +1588,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1093, + "commentStart": 1090, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1602,14 +1598,14 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1132, + "commentStart": 1129, "end": 0, "properties": [ { - "commentStart": 1141, + "commentStart": 1138, "end": 0, "key": { - "commentStart": 1141, + "commentStart": 1138, "end": 0, "name": "angleEnd", "start": 0, @@ -1618,7 +1614,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1152, + "commentStart": 1149, "end": 0, "raw": "90", "start": 0, @@ -1631,10 +1627,10 @@ description: Result of parsing router-template-slate.kcl } }, { - "commentStart": 1163, + "commentStart": 1160, "end": 0, "key": { - "commentStart": 1163, + "commentStart": 1160, "end": 0, "name": "angleStart", "start": 0, @@ -1643,7 +1639,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1176, + "commentStart": 1173, "end": 0, "raw": "180", "start": 0, @@ -1656,10 +1652,10 @@ description: Result of parsing router-template-slate.kcl } }, { - "commentStart": 1188, + "commentStart": 1185, "end": 0, "key": { - "commentStart": 1188, + "commentStart": 1185, "end": 0, "name": "radius", "start": 0, @@ -1668,14 +1664,14 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1197, + "commentStart": 1194, "end": 0, "left": { "abs_path": false, - "commentStart": 1197, + "commentStart": 1194, "end": 0, "name": { - "commentStart": 1197, + "commentStart": 1194, "end": 0, "name": "radius", "start": 0, @@ -1689,10 +1685,10 @@ description: Result of parsing router-template-slate.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1206, + "commentStart": 1203, "end": 0, "name": { - "commentStart": 1206, + "commentStart": 1203, "end": 0, "name": "templateGap", "start": 0, @@ -1714,7 +1710,7 @@ description: Result of parsing router-template-slate.kcl "type": "ObjectExpression" }, { - "commentStart": 1226, + "commentStart": 1223, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1723,10 +1719,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1128, + "commentStart": 1125, "end": 0, "name": { - "commentStart": 1128, + "commentStart": 1125, "end": 0, "name": "arc", "start": 0, @@ -1736,7 +1732,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1128, + "commentStart": 1125, "end": 0, "start": 0, "type": "CallExpression", @@ -1747,19 +1743,19 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1239, + "commentStart": 1236, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1253, + "commentStart": 1250, "elements": [ { "arguments": [ { - "commentStart": 1268, + "commentStart": 1265, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1768,10 +1764,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1254, + "commentStart": 1251, "end": 0, "name": { - "commentStart": 1254, + "commentStart": 1251, "end": 0, "name": "profileStartX", "start": 0, @@ -1781,7 +1777,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1254, + "commentStart": 1251, "end": 0, "start": 0, "type": "CallExpression", @@ -1790,7 +1786,7 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1286, + "commentStart": 1283, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1799,10 +1795,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1272, + "commentStart": 1269, "end": 0, "name": { - "commentStart": 1272, + "commentStart": 1269, "end": 0, "name": "profileStartY", "start": 0, @@ -1812,7 +1808,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1272, + "commentStart": 1269, "end": 0, "start": 0, "type": "CallExpression", @@ -1828,10 +1824,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1234, + "commentStart": 1231, "end": 0, "name": { - "commentStart": 1234, + "commentStart": 1231, "end": 0, "name": "line", "start": 0, @@ -1841,7 +1837,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1234, + "commentStart": 1231, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1852,10 +1848,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1296, + "commentStart": 1293, "end": 0, "name": { - "commentStart": 1296, + "commentStart": 1293, "end": 0, "name": "close", "start": 0, @@ -1865,7 +1861,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1296, + "commentStart": 1293, "end": 0, "start": 0, "type": "CallExpression", @@ -1878,7 +1874,7 @@ description: Result of parsing router-template-slate.kcl "nonCodeNodes": { "7": [ { - "commentStart": 949, + "commentStart": 946, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1891,7 +1887,7 @@ description: Result of parsing router-template-slate.kcl ], "14": [ { - "commentStart": 1303, + "commentStart": 1300, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1924,12 +1920,12 @@ description: Result of parsing router-template-slate.kcl "type": "VariableDeclaration" }, { - "commentStart": 1333, + "commentStart": 1330, "declaration": { - "commentStart": 1333, + "commentStart": 1330, "end": 0, "id": { - "commentStart": 1333, + "commentStart": 1330, "end": 0, "name": "extrude001", "start": 0, @@ -1940,14 +1936,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1365, + "commentStart": 1362, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1374, + "commentStart": 1371, "end": 0, "raw": "5", "start": 0, @@ -1962,10 +1958,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1346, + "commentStart": 1343, "end": 0, "name": { - "commentStart": 1346, + "commentStart": 1343, "end": 0, "name": "extrude", "start": 0, @@ -1975,17 +1971,17 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1346, + "commentStart": 1343, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1354, + "commentStart": 1351, "end": 0, "name": { - "commentStart": 1354, + "commentStart": 1351, "end": 0, "name": "sketch001", "start": 0, @@ -2007,12 +2003,12 @@ description: Result of parsing router-template-slate.kcl "type": "VariableDeclaration" }, { - "commentStart": 1376, + "commentStart": 1373, "declaration": { - "commentStart": 1406, + "commentStart": 1403, "end": 0, "id": { - "commentStart": 1406, + "commentStart": 1403, "end": 0, "name": "sketch002", "start": 0, @@ -2024,10 +2020,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1432, + "commentStart": 1429, "end": 0, "name": { - "commentStart": 1432, + "commentStart": 1429, "end": 0, "name": "extrude001", "start": 0, @@ -2039,7 +2035,7 @@ description: Result of parsing router-template-slate.kcl "type": "Name" }, { - "commentStart": 1444, + "commentStart": 1441, "end": 0, "raw": "'START'", "start": 0, @@ -2050,10 +2046,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1418, + "commentStart": 1415, "end": 0, "name": { - "commentStart": 1418, + "commentStart": 1415, "end": 0, "name": "startSketchOn", "start": 0, @@ -2063,7 +2059,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1418, + "commentStart": 1415, "end": 0, "start": 0, "type": "CallExpression", @@ -2072,15 +2068,15 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1473, + "commentStart": 1470, "elements": [ { "argument": { "abs_path": false, - "commentStart": 1483, + "commentStart": 1480, "end": 0, "name": { - "commentStart": 1483, + "commentStart": 1480, "end": 0, "name": "slateWidthHalf", "start": 0, @@ -2091,7 +2087,7 @@ description: Result of parsing router-template-slate.kcl "type": "Name", "type": "Name" }, - "commentStart": 1482, + "commentStart": 1479, "end": 0, "operator": "-", "start": 0, @@ -2099,18 +2095,18 @@ description: Result of parsing router-template-slate.kcl "type": "UnaryExpression" }, { - "commentStart": 1506, + "commentStart": 1503, "end": 0, "left": { - "commentStart": 1506, + "commentStart": 1503, "end": 0, "left": { "argument": { "abs_path": false, - "commentStart": 1507, + "commentStart": 1504, "end": 0, "name": { - "commentStart": 1507, + "commentStart": 1504, "end": 0, "name": "templateGap", "start": 0, @@ -2121,7 +2117,7 @@ description: Result of parsing router-template-slate.kcl "type": "Name", "type": "Name" }, - "commentStart": 1506, + "commentStart": 1503, "end": 0, "operator": "-", "start": 0, @@ -2130,7 +2126,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "*", "right": { - "commentStart": 1521, + "commentStart": 1518, "end": 0, "raw": "2", "start": 0, @@ -2147,14 +2143,14 @@ description: Result of parsing router-template-slate.kcl }, "operator": "-", "right": { - "commentStart": 1526, + "commentStart": 1523, "end": 0, "left": { "abs_path": false, - "commentStart": 1526, + "commentStart": 1523, "end": 0, "name": { - "commentStart": 1526, + "commentStart": 1523, "end": 0, "name": "templateDiameter", "start": 0, @@ -2167,7 +2163,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "/", "right": { - "commentStart": 1545, + "commentStart": 1542, "end": 0, "raw": "2", "start": 0, @@ -2193,7 +2189,7 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 1556, + "commentStart": 1553, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2202,10 +2198,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1458, + "commentStart": 1455, "end": 0, "name": { - "commentStart": 1458, + "commentStart": 1455, "end": 0, "name": "startProfileAt", "start": 0, @@ -2215,7 +2211,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1458, + "commentStart": 1455, "end": 0, "start": 0, "type": "CallExpression", @@ -2226,7 +2222,7 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1570, + "commentStart": 1567, "end": 0, "name": "length", "start": 0, @@ -2234,7 +2230,7 @@ description: Result of parsing router-template-slate.kcl }, "arg": { "argument": { - "commentStart": 1580, + "commentStart": 1577, "end": 0, "raw": "7", "start": 0, @@ -2245,7 +2241,7 @@ description: Result of parsing router-template-slate.kcl "suffix": "None" } }, - "commentStart": 1579, + "commentStart": 1576, "end": 0, "operator": "-", "start": 0, @@ -2256,14 +2252,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1583, + "commentStart": 1580, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1589, + "commentStart": 1586, "end": 0, "start": 0, "type": "TagDeclarator", @@ -2274,10 +2270,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1564, + "commentStart": 1561, "end": 0, "name": { - "commentStart": 1564, + "commentStart": 1561, "end": 0, "name": "xLine", "start": 0, @@ -2287,7 +2283,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1564, + "commentStart": 1561, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2297,19 +2293,19 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1628, + "commentStart": 1625, "elements": [ { - "commentStart": 1637, + "commentStart": 1634, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 1644, + "commentStart": 1641, "end": 0, "name": { - "commentStart": 1644, + "commentStart": 1641, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -2323,10 +2319,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1637, + "commentStart": 1634, "end": 0, "name": { - "commentStart": 1637, + "commentStart": 1634, "end": 0, "name": "segAng", "start": 0, @@ -2336,7 +2332,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1637, + "commentStart": 1634, "end": 0, "start": 0, "type": "CallExpression", @@ -2344,7 +2340,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "+", "right": { - "commentStart": 1668, + "commentStart": 1665, "end": 0, "raw": "90", "start": 0, @@ -2361,10 +2357,10 @@ description: Result of parsing router-template-slate.kcl }, { "abs_path": false, - "commentStart": 1679, + "commentStart": 1676, "end": 0, "name": { - "commentStart": 1679, + "commentStart": 1676, "end": 0, "name": "minClampingDistance", "start": 0, @@ -2382,14 +2378,14 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 1707, + "commentStart": 1704, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 1710, + "commentStart": 1707, "end": 0, "start": 0, "type": "TagDeclarator", @@ -2399,10 +2395,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1617, + "commentStart": 1614, "end": 0, "name": { - "commentStart": 1617, + "commentStart": 1614, "end": 0, "name": "angledLine", "start": 0, @@ -2412,7 +2408,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1617, + "commentStart": 1614, "end": 0, "start": 0, "type": "CallExpression", @@ -2421,16 +2417,16 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1749, + "commentStart": 1746, "elements": [ { "arguments": [ { "abs_path": false, - "commentStart": 1765, + "commentStart": 1762, "end": 0, "name": { - "commentStart": 1765, + "commentStart": 1762, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -2444,10 +2440,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1758, + "commentStart": 1755, "end": 0, "name": { - "commentStart": 1758, + "commentStart": 1755, "end": 0, "name": "segAng", "start": 0, @@ -2457,7 +2453,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1758, + "commentStart": 1755, "end": 0, "start": 0, "type": "CallExpression", @@ -2468,10 +2464,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 1803, + "commentStart": 1800, "end": 0, "name": { - "commentStart": 1803, + "commentStart": 1800, "end": 0, "name": "rectangleSegmentA001", "start": 0, @@ -2485,10 +2481,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1796, + "commentStart": 1793, "end": 0, "name": { - "commentStart": 1796, + "commentStart": 1793, "end": 0, "name": "segLen", "start": 0, @@ -2498,13 +2494,13 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1796, + "commentStart": 1793, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 1795, + "commentStart": 1792, "end": 0, "operator": "-", "start": 0, @@ -2518,14 +2514,14 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 1833, + "commentStart": 1830, "end": 0, "start": 0, "type": "PipeSubstitution", "type": "PipeSubstitution" }, { - "commentStart": 1836, + "commentStart": 1833, "end": 0, "start": 0, "type": "TagDeclarator", @@ -2535,10 +2531,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1738, + "commentStart": 1735, "end": 0, "name": { - "commentStart": 1738, + "commentStart": 1735, "end": 0, "name": "angledLine", "start": 0, @@ -2548,7 +2544,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1738, + "commentStart": 1735, "end": 0, "start": 0, "type": "CallExpression", @@ -2559,19 +2555,19 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1869, + "commentStart": 1866, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1883, + "commentStart": 1880, "elements": [ { "arguments": [ { - "commentStart": 1898, + "commentStart": 1895, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2580,10 +2576,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1884, + "commentStart": 1881, "end": 0, "name": { - "commentStart": 1884, + "commentStart": 1881, "end": 0, "name": "profileStartX", "start": 0, @@ -2593,7 +2589,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1884, + "commentStart": 1881, "end": 0, "start": 0, "type": "CallExpression", @@ -2602,7 +2598,7 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 1916, + "commentStart": 1913, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2611,10 +2607,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1902, + "commentStart": 1899, "end": 0, "name": { - "commentStart": 1902, + "commentStart": 1899, "end": 0, "name": "profileStartY", "start": 0, @@ -2624,7 +2620,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1902, + "commentStart": 1899, "end": 0, "start": 0, "type": "CallExpression", @@ -2640,10 +2636,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1864, + "commentStart": 1861, "end": 0, "name": { - "commentStart": 1864, + "commentStart": 1861, "end": 0, "name": "line", "start": 0, @@ -2653,7 +2649,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1864, + "commentStart": 1861, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2664,10 +2660,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1926, + "commentStart": 1923, "end": 0, "name": { - "commentStart": 1926, + "commentStart": 1923, "end": 0, "name": "close", "start": 0, @@ -2677,20 +2673,20 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1926, + "commentStart": 1923, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" } ], - "commentStart": 1418, + "commentStart": 1415, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "6": [ { - "commentStart": 1933, + "commentStart": 1930, "end": 0, "start": 0, "type": "NonCodeNode", @@ -2723,12 +2719,12 @@ description: Result of parsing router-template-slate.kcl "type": "VariableDeclaration" }, { - "commentStart": 1964, + "commentStart": 1961, "declaration": { - "commentStart": 1964, + "commentStart": 1961, "end": 0, "id": { - "commentStart": 1964, + "commentStart": 1961, "end": 0, "name": "extrude002", "start": 0, @@ -2739,14 +2735,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 1996, + "commentStart": 1993, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2005, + "commentStart": 2002, "end": 0, "raw": "7.5", "start": 0, @@ -2761,10 +2757,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 1977, + "commentStart": 1974, "end": 0, "name": { - "commentStart": 1977, + "commentStart": 1974, "end": 0, "name": "extrude", "start": 0, @@ -2774,17 +2770,17 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 1977, + "commentStart": 1974, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1985, + "commentStart": 1982, "end": 0, "name": { - "commentStart": 1985, + "commentStart": 1982, "end": 0, "name": "sketch002", "start": 0, @@ -2806,12 +2802,12 @@ description: Result of parsing router-template-slate.kcl "type": "VariableDeclaration" }, { - "commentStart": 2009, + "commentStart": 2006, "declaration": { - "commentStart": 2038, + "commentStart": 2035, "end": 0, "id": { - "commentStart": 2038, + "commentStart": 2035, "end": 0, "name": "sketch003", "start": 0, @@ -2823,10 +2819,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 2064, + "commentStart": 2061, "end": 0, "name": { - "commentStart": 2064, + "commentStart": 2061, "end": 0, "name": "extrude001", "start": 0, @@ -2838,7 +2834,7 @@ description: Result of parsing router-template-slate.kcl "type": "Name" }, { - "commentStart": 2076, + "commentStart": 2073, "end": 0, "raw": "'START'", "start": 0, @@ -2849,10 +2845,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2050, + "commentStart": 2047, "end": 0, "name": { - "commentStart": 2050, + "commentStart": 2047, "end": 0, "name": "startSketchOn", "start": 0, @@ -2862,7 +2858,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2050, + "commentStart": 2047, "end": 0, "start": 0, "type": "CallExpression", @@ -2871,14 +2867,14 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 2105, + "commentStart": 2102, "elements": [ { "abs_path": false, - "commentStart": 2114, + "commentStart": 2111, "end": 0, "name": { - "commentStart": 2114, + "commentStart": 2111, "end": 0, "name": "slateWidthHalf", "start": 0, @@ -2890,18 +2886,18 @@ description: Result of parsing router-template-slate.kcl "type": "Name" }, { - "commentStart": 2137, + "commentStart": 2134, "end": 0, "left": { - "commentStart": 2137, + "commentStart": 2134, "end": 0, "left": { "argument": { "abs_path": false, - "commentStart": 2138, + "commentStart": 2135, "end": 0, "name": { - "commentStart": 2138, + "commentStart": 2135, "end": 0, "name": "templateGap", "start": 0, @@ -2912,7 +2908,7 @@ description: Result of parsing router-template-slate.kcl "type": "Name", "type": "Name" }, - "commentStart": 2137, + "commentStart": 2134, "end": 0, "operator": "-", "start": 0, @@ -2921,7 +2917,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "*", "right": { - "commentStart": 2152, + "commentStart": 2149, "end": 0, "raw": "2", "start": 0, @@ -2938,14 +2934,14 @@ description: Result of parsing router-template-slate.kcl }, "operator": "-", "right": { - "commentStart": 2157, + "commentStart": 2154, "end": 0, "left": { "abs_path": false, - "commentStart": 2157, + "commentStart": 2154, "end": 0, "name": { - "commentStart": 2157, + "commentStart": 2154, "end": 0, "name": "templateDiameter", "start": 0, @@ -2958,7 +2954,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "/", "right": { - "commentStart": 2176, + "commentStart": 2173, "end": 0, "raw": "2", "start": 0, @@ -2984,7 +2980,7 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 2187, + "commentStart": 2184, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -2993,10 +2989,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2090, + "commentStart": 2087, "end": 0, "name": { - "commentStart": 2090, + "commentStart": 2087, "end": 0, "name": "startProfileAt", "start": 0, @@ -3006,7 +3002,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2090, + "commentStart": 2087, "end": 0, "start": 0, "type": "CallExpression", @@ -3017,14 +3013,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 2201, + "commentStart": 2198, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2210, + "commentStart": 2207, "end": 0, "raw": "7", "start": 0, @@ -3039,14 +3035,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 2213, + "commentStart": 2210, "end": 0, "name": "tag", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2219, + "commentStart": 2216, "end": 0, "start": 0, "type": "TagDeclarator", @@ -3057,10 +3053,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2195, + "commentStart": 2192, "end": 0, "name": { - "commentStart": 2195, + "commentStart": 2192, "end": 0, "name": "xLine", "start": 0, @@ -3070,7 +3066,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2195, + "commentStart": 2192, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3080,19 +3076,19 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 2258, + "commentStart": 2255, "elements": [ { - "commentStart": 2267, + "commentStart": 2264, "end": 0, "left": { "arguments": [ { "abs_path": false, - "commentStart": 2274, + "commentStart": 2271, "end": 0, "name": { - "commentStart": 2274, + "commentStart": 2271, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -3106,10 +3102,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2267, + "commentStart": 2264, "end": 0, "name": { - "commentStart": 2267, + "commentStart": 2264, "end": 0, "name": "segAng", "start": 0, @@ -3119,7 +3115,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2267, + "commentStart": 2264, "end": 0, "start": 0, "type": "CallExpression", @@ -3127,7 +3123,7 @@ description: Result of parsing router-template-slate.kcl }, "operator": "-", "right": { - "commentStart": 2298, + "commentStart": 2295, "end": 0, "raw": "90", "start": 0, @@ -3144,10 +3140,10 @@ description: Result of parsing router-template-slate.kcl }, { "abs_path": false, - "commentStart": 2309, + "commentStart": 2306, "end": 0, "name": { - "commentStart": 2309, + "commentStart": 2306, "end": 0, "name": "minClampingDistance", "start": 0, @@ -3165,7 +3161,7 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 2337, + "commentStart": 2334, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3174,10 +3170,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2247, + "commentStart": 2244, "end": 0, "name": { - "commentStart": 2247, + "commentStart": 2244, "end": 0, "name": "angledLine", "start": 0, @@ -3187,7 +3183,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2247, + "commentStart": 2244, "end": 0, "start": 0, "type": "CallExpression", @@ -3196,16 +3192,16 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 2356, + "commentStart": 2353, "elements": [ { "arguments": [ { "abs_path": false, - "commentStart": 2372, + "commentStart": 2369, "end": 0, "name": { - "commentStart": 2372, + "commentStart": 2369, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -3219,10 +3215,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2365, + "commentStart": 2362, "end": 0, "name": { - "commentStart": 2365, + "commentStart": 2362, "end": 0, "name": "segAng", "start": 0, @@ -3232,7 +3228,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2365, + "commentStart": 2362, "end": 0, "start": 0, "type": "CallExpression", @@ -3243,10 +3239,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [ { "abs_path": false, - "commentStart": 2410, + "commentStart": 2407, "end": 0, "name": { - "commentStart": 2410, + "commentStart": 2407, "end": 0, "name": "rectangleSegmentA002", "start": 0, @@ -3260,10 +3256,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2403, + "commentStart": 2400, "end": 0, "name": { - "commentStart": 2403, + "commentStart": 2400, "end": 0, "name": "segLen", "start": 0, @@ -3273,13 +3269,13 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2403, + "commentStart": 2400, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" }, - "commentStart": 2402, + "commentStart": 2399, "end": 0, "operator": "-", "start": 0, @@ -3293,7 +3289,7 @@ description: Result of parsing router-template-slate.kcl "type": "ArrayExpression" }, { - "commentStart": 2440, + "commentStart": 2437, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3302,10 +3298,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2345, + "commentStart": 2342, "end": 0, "name": { - "commentStart": 2345, + "commentStart": 2342, "end": 0, "name": "angledLine", "start": 0, @@ -3315,7 +3311,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2345, + "commentStart": 2342, "end": 0, "start": 0, "type": "CallExpression", @@ -3326,19 +3322,19 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 2453, + "commentStart": 2450, "end": 0, "name": "endAbsolute", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2467, + "commentStart": 2464, "elements": [ { "arguments": [ { - "commentStart": 2482, + "commentStart": 2479, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3347,10 +3343,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2468, + "commentStart": 2465, "end": 0, "name": { - "commentStart": 2468, + "commentStart": 2465, "end": 0, "name": "profileStartX", "start": 0, @@ -3360,7 +3356,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2468, + "commentStart": 2465, "end": 0, "start": 0, "type": "CallExpression", @@ -3369,7 +3365,7 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 2500, + "commentStart": 2497, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3378,10 +3374,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2486, + "commentStart": 2483, "end": 0, "name": { - "commentStart": 2486, + "commentStart": 2483, "end": 0, "name": "profileStartY", "start": 0, @@ -3391,7 +3387,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2486, + "commentStart": 2483, "end": 0, "start": 0, "type": "CallExpression", @@ -3407,10 +3403,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2448, + "commentStart": 2445, "end": 0, "name": { - "commentStart": 2448, + "commentStart": 2445, "end": 0, "name": "line", "start": 0, @@ -3420,7 +3416,7 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2448, + "commentStart": 2445, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3431,10 +3427,10 @@ description: Result of parsing router-template-slate.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2510, + "commentStart": 2507, "end": 0, "name": { - "commentStart": 2510, + "commentStart": 2507, "end": 0, "name": "close", "start": 0, @@ -3444,20 +3440,20 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2510, + "commentStart": 2507, "end": 0, "start": 0, "type": "CallExpression", "type": "CallExpression" } ], - "commentStart": 2050, + "commentStart": 2047, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "6": [ { - "commentStart": 2517, + "commentStart": 2514, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3490,12 +3486,12 @@ description: Result of parsing router-template-slate.kcl "type": "VariableDeclaration" }, { - "commentStart": 2547, + "commentStart": 2544, "declaration": { - "commentStart": 2547, + "commentStart": 2544, "end": 0, "id": { - "commentStart": 2547, + "commentStart": 2544, "end": 0, "name": "extrude003", "start": 0, @@ -3506,14 +3502,14 @@ description: Result of parsing router-template-slate.kcl { "type": "LabeledArg", "label": { - "commentStart": 2579, + "commentStart": 2576, "end": 0, "name": "length", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 2588, + "commentStart": 2585, "end": 0, "raw": "7.5", "start": 0, @@ -3528,10 +3524,10 @@ description: Result of parsing router-template-slate.kcl ], "callee": { "abs_path": false, - "commentStart": 2560, + "commentStart": 2557, "end": 0, "name": { - "commentStart": 2560, + "commentStart": 2557, "end": 0, "name": "extrude", "start": 0, @@ -3541,17 +3537,17 @@ description: Result of parsing router-template-slate.kcl "start": 0, "type": "Name" }, - "commentStart": 2560, + "commentStart": 2557, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 2568, + "commentStart": 2565, "end": 0, "name": { - "commentStart": 2568, + "commentStart": 2565, "end": 0, "name": "sketch003", "start": 0, diff --git a/rust/kcl-lib/tests/kcl_samples/router-template-slate/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/router-template-slate/program_memory.snap index 11024462b..c18415276 100644 --- a/rust/kcl-lib/tests/kcl_samples/router-template-slate/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/router-template-slate/program_memory.snap @@ -264,9 +264,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, @@ -514,9 +514,9 @@ description: Variables in memory after executing router-template-slate.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1589, - "end": 1610, - "start": 1589, + "commentStart": 1586, + "end": 1607, + "start": 1586, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -527,9 +527,9 @@ description: Variables in memory after executing router-template-slate.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1710, - "end": 1731, - "start": 1710, + "commentStart": 1707, + "end": 1728, + "start": 1707, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -540,9 +540,9 @@ description: Variables in memory after executing router-template-slate.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1836, - "end": 1857, - "start": 1836, + "commentStart": 1833, + "end": 1854, + "start": 1833, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -570,9 +570,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 1589, - "end": 1610, - "start": 1589, + "commentStart": 1586, + "end": 1607, + "start": 1586, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -595,9 +595,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 1710, - "end": 1731, - "start": 1710, + "commentStart": 1707, + "end": 1728, + "start": 1707, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -620,9 +620,9 @@ description: Variables in memory after executing router-template-slate.kcl -92.4938 ], "tag": { - "commentStart": 1836, - "end": 1857, - "start": 1836, + "commentStart": 1833, + "end": 1854, + "start": 1833, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -940,9 +940,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, @@ -1239,9 +1239,9 @@ description: Variables in memory after executing router-template-slate.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2219, - "end": 2240, - "start": 2219, + "commentStart": 2216, + "end": 2237, + "start": 2216, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -1283,9 +1283,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 2219, - "end": 2240, - "start": 2219, + "commentStart": 2216, + "end": 2237, + "start": 2216, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -1641,9 +1641,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, @@ -2165,9 +2165,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, @@ -2412,9 +2412,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 1589, - "end": 1610, - "start": 1589, + "commentStart": 1586, + "end": 1607, + "start": 1586, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -2437,9 +2437,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 1710, - "end": 1731, - "start": 1710, + "commentStart": 1707, + "end": 1728, + "start": 1707, "type": "TagDeclarator", "value": "rectangleSegmentB001" }, @@ -2462,9 +2462,9 @@ description: Variables in memory after executing router-template-slate.kcl -92.4938 ], "tag": { - "commentStart": 1836, - "end": 1857, - "start": 1836, + "commentStart": 1833, + "end": 1854, + "start": 1833, "type": "TagDeclarator", "value": "rectangleSegmentC001" }, @@ -2782,9 +2782,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, @@ -3078,9 +3078,9 @@ description: Variables in memory after executing router-template-slate.kcl -12.4937 ], "tag": { - "commentStart": 2219, - "end": 2240, - "start": 2219, + "commentStart": 2216, + "end": 2237, + "start": 2216, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -3436,9 +3436,9 @@ description: Variables in memory after executing router-template-slate.kcl -122.4938 ], "tag": { - "commentStart": 940, - "end": 946, - "start": 940, + "commentStart": 937, + "end": 943, + "start": 937, "type": "TagDeclarator", "value": "seg02" }, diff --git a/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/artifact_commands.snap index c32759dd1..4816f9016 100644 --- a/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sheet-metal-bracket.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/artifact_commands.snap index 267e44d0c..b04405acf 100644 --- a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands socket-head-cap-screw.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_commands.snap index e2eb2891c..a647e1932 100644 --- a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands walkie-talkie.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_graph_flowchart.snap.md index 5460744d6..5705ab3a9 100644 --- a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/artifact_graph_flowchart.snap.md @@ -1,186 +1,186 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[458, 501, 5]"] - 3["Segment
[509, 547, 5]"] - 4["Segment
[555, 595, 5]"] - 5["Segment
[603, 642, 5]"] - 6["Segment
[650, 672, 5]"] + 2["Path
[458, 501, 6]"] + 3["Segment
[509, 547, 6]"] + 4["Segment
[555, 595, 6]"] + 5["Segment
[603, 642, 6]"] + 6["Segment
[650, 672, 6]"] 7[Solid2d] end subgraph path27 [Path] - 27["Path
[1082, 1213, 5]"] - 28["Segment
[1221, 1279, 5]"] - 29["Segment
[1287, 1418, 5]"] - 30["Segment
[1426, 1484, 5]"] - 31["Segment
[1492, 1626, 5]"] - 32["Segment
[1634, 1720, 5]"] - 33["Segment
[1728, 1863, 5]"] - 34["Segment
[1871, 1956, 5]"] - 35["Segment
[1964, 1971, 5]"] + 27["Path
[1082, 1213, 6]"] + 28["Segment
[1221, 1279, 6]"] + 29["Segment
[1287, 1418, 6]"] + 30["Segment
[1426, 1484, 6]"] + 31["Segment
[1492, 1626, 6]"] + 32["Segment
[1634, 1720, 6]"] + 33["Segment
[1728, 1863, 6]"] + 34["Segment
[1871, 1956, 6]"] + 35["Segment
[1964, 1971, 6]"] 36[Solid2d] end subgraph path63 [Path] - 63["Path
[2119, 2173, 5]"] - 64["Segment
[2181, 2222, 5]"] - 65["Segment
[2230, 2259, 5]"] - 66["Segment
[2267, 2297, 5]"] - 67["Segment
[2305, 2361, 5]"] - 68["Segment
[2369, 2376, 5]"] + 63["Path
[2119, 2173, 6]"] + 64["Segment
[2181, 2222, 6]"] + 65["Segment
[2230, 2259, 6]"] + 66["Segment
[2267, 2297, 6]"] + 67["Segment
[2305, 2361, 6]"] + 68["Segment
[2369, 2376, 6]"] 69[Solid2d] end subgraph path84 [Path] - 84["Path
[2518, 2555, 5]"] - 85["Segment
[2563, 2594, 5]"] - 86["Segment
[2602, 2635, 5]"] - 87["Segment
[2643, 2675, 5]"] - 88["Segment
[2683, 2690, 5]"] + 84["Path
[2518, 2555, 6]"] + 85["Segment
[2563, 2594, 6]"] + 86["Segment
[2602, 2635, 6]"] + 87["Segment
[2643, 2675, 6]"] + 88["Segment
[2683, 2690, 6]"] 89[Solid2d] end subgraph path105 [Path] - 105["Path
[346, 371, 8]"] - 106["Segment
[379, 412, 8]"] - 107["Segment
[420, 455, 8]"] - 108["Segment
[463, 497, 8]"] - 109["Segment
[505, 512, 8]"] + 105["Path
[346, 371, 9]"] + 106["Segment
[379, 412, 9]"] + 107["Segment
[420, 455, 9]"] + 108["Segment
[463, 497, 9]"] + 109["Segment
[505, 512, 9]"] 110[Solid2d] end subgraph path112 [Path] - 112["Path
[649, 781, 8]"] + 112["Path
[649, 781, 9]"] 117[Solid2d] end subgraph path130 [Path] - 130["Path
[551, 605, 6]"] - 131["Segment
[613, 640, 6]"] - 132["Segment
[648, 677, 6]"] - 133["Segment
[685, 713, 6]"] - 134["Segment
[721, 777, 6]"] - 135["Segment
[785, 792, 6]"] + 130["Path
[551, 605, 7]"] + 131["Segment
[613, 640, 7]"] + 132["Segment
[648, 677, 7]"] + 133["Segment
[685, 713, 7]"] + 134["Segment
[721, 777, 7]"] + 135["Segment
[785, 792, 7]"] 136[Solid2d] end subgraph path138 [Path] - 138["Path
[1098, 1145, 6]"] - 139["Segment
[1153, 1194, 6]"] - 140["Segment
[1202, 1244, 6]"] - 141["Segment
[1252, 1294, 6]"] - 142["Segment
[1302, 1309, 6]"] + 138["Path
[1098, 1145, 7]"] + 139["Segment
[1153, 1194, 7]"] + 140["Segment
[1202, 1244, 7]"] + 141["Segment
[1252, 1294, 7]"] + 142["Segment
[1302, 1309, 7]"] 143[Solid2d] end subgraph path145 [Path] - 145["Path
[1597, 1762, 6]"] - 146["Segment
[1770, 1871, 6]"] - 147["Segment
[1879, 2046, 6]"] - 148["Segment
[2054, 2155, 6]"] - 149["Segment
[2163, 2333, 6]"] - 150["Segment
[2341, 2443, 6]"] - 151["Segment
[2451, 2620, 6]"] - 152["Segment
[2628, 2729, 6]"] - 153["Segment
[2737, 2744, 6]"] + 145["Path
[1597, 1762, 7]"] + 146["Segment
[1770, 1871, 7]"] + 147["Segment
[1879, 2046, 7]"] + 148["Segment
[2054, 2155, 7]"] + 149["Segment
[2163, 2333, 7]"] + 150["Segment
[2341, 2443, 7]"] + 151["Segment
[2451, 2620, 7]"] + 152["Segment
[2628, 2729, 7]"] + 153["Segment
[2737, 2744, 7]"] 154[Solid2d] end subgraph path156 [Path] - 156["Path
[123, 210, 7]"] - 157["Segment
[218, 247, 7]"] - 158["Segment
[255, 283, 7]"] - 159["Segment
[291, 388, 7]"] - 160["Segment
[396, 443, 7]"] - 161["Segment
[451, 479, 7]"] - 162["Segment
[487, 516, 7]"] - 163["Segment
[524, 553, 7]"] - 164["Segment
[561, 652, 7]"] - 165["Segment
[660, 688, 7]"] - 166["Segment
[696, 725, 7]"] - 167["Segment
[733, 821, 7]"] - 168["Segment
[829, 857, 7]"] - 169["Segment
[865, 899, 7]"] - 170["Segment
[907, 937, 7]"] - 171["Segment
[945, 1054, 7]"] - 172["Segment
[1062, 1069, 7]"] + 156["Path
[123, 210, 8]"] + 157["Segment
[218, 247, 8]"] + 158["Segment
[255, 283, 8]"] + 159["Segment
[291, 388, 8]"] + 160["Segment
[396, 443, 8]"] + 161["Segment
[451, 479, 8]"] + 162["Segment
[487, 516, 8]"] + 163["Segment
[524, 553, 8]"] + 164["Segment
[561, 652, 8]"] + 165["Segment
[660, 688, 8]"] + 166["Segment
[696, 725, 8]"] + 167["Segment
[733, 821, 8]"] + 168["Segment
[829, 857, 8]"] + 169["Segment
[865, 899, 8]"] + 170["Segment
[907, 937, 8]"] + 171["Segment
[945, 1054, 8]"] + 172["Segment
[1062, 1069, 8]"] 173[Solid2d] end subgraph path175 [Path] - 175["Path
[1203, 1301, 7]"] - 176["Segment
[1309, 1428, 7]"] - 177["Segment
[1436, 1490, 7]"] - 178["Segment
[1498, 1619, 7]"] - 179["Segment
[1627, 1634, 7]"] + 175["Path
[1203, 1301, 8]"] + 176["Segment
[1309, 1428, 8]"] + 177["Segment
[1436, 1490, 8]"] + 178["Segment
[1498, 1619, 8]"] + 179["Segment
[1627, 1634, 8]"] 180[Solid2d] end subgraph path182 [Path] - 182["Path
[1731, 1828, 7]"] - 183["Segment
[1836, 1955, 7]"] - 184["Segment
[1963, 2018, 7]"] - 185["Segment
[2026, 2147, 7]"] - 186["Segment
[2155, 2162, 7]"] + 182["Path
[1731, 1828, 8]"] + 183["Segment
[1836, 1955, 8]"] + 184["Segment
[1963, 2018, 8]"] + 185["Segment
[2026, 2147, 8]"] + 186["Segment
[2155, 2162, 8]"] 187[Solid2d] end subgraph path189 [Path] - 189["Path
[1203, 1301, 7]"] - 190["Segment
[1309, 1428, 7]"] - 191["Segment
[1436, 1490, 7]"] - 192["Segment
[1498, 1619, 7]"] - 193["Segment
[1627, 1634, 7]"] + 189["Path
[1203, 1301, 8]"] + 190["Segment
[1309, 1428, 8]"] + 191["Segment
[1436, 1490, 8]"] + 192["Segment
[1498, 1619, 8]"] + 193["Segment
[1627, 1634, 8]"] 194[Solid2d] end subgraph path196 [Path] - 196["Path
[1731, 1828, 7]"] - 197["Segment
[1836, 1955, 7]"] - 198["Segment
[1963, 2018, 7]"] - 199["Segment
[2026, 2147, 7]"] - 200["Segment
[2155, 2162, 7]"] + 196["Path
[1731, 1828, 8]"] + 197["Segment
[1836, 1955, 8]"] + 198["Segment
[1963, 2018, 8]"] + 199["Segment
[2026, 2147, 8]"] + 200["Segment
[2155, 2162, 8]"] 201[Solid2d] end subgraph path230 [Path] - 230["Path
[288, 387, 9]"] - 231["Segment
[395, 444, 9]"] - 232["Segment
[452, 502, 9]"] - 233["Segment
[510, 560, 9]"] - 234["Segment
[568, 586, 9]"] + 230["Path
[288, 387, 10]"] + 231["Segment
[395, 444, 10]"] + 232["Segment
[452, 502, 10]"] + 233["Segment
[510, 560, 10]"] + 234["Segment
[568, 586, 10]"] 235[Solid2d] end subgraph path256 [Path] - 256["Path
[377, 407, 10]"] - 257["Segment
[415, 447, 10]"] - 258["Segment
[455, 488, 10]"] - 259["Segment
[496, 585, 10]"] - 260["Segment
[593, 620, 10]"] - 261["Segment
[628, 635, 10]"] + 256["Path
[377, 407, 11]"] + 257["Segment
[415, 447, 11]"] + 258["Segment
[455, 488, 11]"] + 259["Segment
[496, 585, 11]"] + 260["Segment
[593, 620, 11]"] + 261["Segment
[628, 635, 11]"] 262[Solid2d] end subgraph path274 [Path] - 274["Path
[311, 336, 11]"] - 275["Segment
[344, 403, 11]"] - 276["Segment
[411, 471, 11]"] - 277["Segment
[479, 529, 11]"] - 278["Segment
[537, 544, 11]"] + 274["Path
[311, 336, 12]"] + 275["Segment
[344, 403, 12]"] + 276["Segment
[411, 471, 12]"] + 277["Segment
[479, 529, 12]"] + 278["Segment
[537, 544, 12]"] 279[Solid2d] end subgraph path298 [Path] - 298["Path
[311, 336, 11]"] - 299["Segment
[344, 403, 11]"] - 300["Segment
[411, 471, 11]"] - 301["Segment
[479, 529, 11]"] - 302["Segment
[537, 544, 11]"] + 298["Path
[311, 336, 12]"] + 299["Segment
[344, 403, 12]"] + 300["Segment
[411, 471, 12]"] + 301["Segment
[479, 529, 12]"] + 302["Segment
[537, 544, 12]"] 303[Solid2d] end subgraph path322 [Path] - 322["Path
[311, 336, 11]"] - 323["Segment
[344, 403, 11]"] - 324["Segment
[411, 471, 11]"] - 325["Segment
[479, 529, 11]"] - 326["Segment
[537, 544, 11]"] + 322["Path
[311, 336, 12]"] + 323["Segment
[344, 403, 12]"] + 324["Segment
[411, 471, 12]"] + 325["Segment
[479, 529, 12]"] + 326["Segment
[537, 544, 12]"] 327[Solid2d] end subgraph path346 [Path] - 346["Path
[311, 336, 11]"] - 347["Segment
[344, 403, 11]"] - 348["Segment
[411, 471, 11]"] - 349["Segment
[479, 529, 11]"] - 350["Segment
[537, 544, 11]"] + 346["Path
[311, 336, 12]"] + 347["Segment
[344, 403, 12]"] + 348["Segment
[411, 471, 12]"] + 349["Segment
[479, 529, 12]"] + 350["Segment
[537, 544, 12]"] 351[Solid2d] end - 1["Plane
[433, 450, 5]"] - 8["Sweep Extrusion
[689, 728, 5]"] + 1["Plane
[433, 450, 6]"] + 8["Sweep Extrusion
[689, 728, 6]"] 9[Wall] 10[Wall] 11[Wall] @@ -195,11 +195,11 @@ flowchart LR 20["SweepEdge Adjacent"] 21["SweepEdge Opposite"] 22["SweepEdge Adjacent"] - 23["EdgeCut Chamfer
[736, 983, 5]"] - 24["EdgeCut Chamfer
[736, 983, 5]"] - 25["EdgeCut Chamfer
[736, 983, 5]"] - 26["EdgeCut Chamfer
[736, 983, 5]"] - 37["Sweep Extrusion
[1987, 2023, 5]"] + 23["EdgeCut Chamfer
[736, 983, 6]"] + 24["EdgeCut Chamfer
[736, 983, 6]"] + 25["EdgeCut Chamfer
[736, 983, 6]"] + 26["EdgeCut Chamfer
[736, 983, 6]"] + 37["Sweep Extrusion
[1987, 2023, 6]"] 38[Wall] 39[Wall] 40[Wall] @@ -225,7 +225,7 @@ flowchart LR 60["SweepEdge Adjacent"] 61["SweepEdge Opposite"] 62["SweepEdge Adjacent"] - 70["Sweep Extrusion
[2392, 2432, 5]"] + 70["Sweep Extrusion
[2392, 2432, 6]"] 71[Wall] 72[Wall] 73[Wall] @@ -239,7 +239,7 @@ flowchart LR 81["SweepEdge Adjacent"] 82["SweepEdge Opposite"] 83["SweepEdge Adjacent"] - 90["Sweep Extrusion
[2701, 2733, 5]"] + 90["Sweep Extrusion
[2701, 2733, 6]"] 91[Wall] 92[Wall] 93[Wall] @@ -253,13 +253,13 @@ flowchart LR 101["SweepEdge Adjacent"] 102["SweepEdge Opposite"] 103["SweepEdge Adjacent"] - 104["Plane
[321, 338, 8]"] - 111["Plane
[563, 602, 8]"] + 104["Plane
[321, 338, 9]"] + 111["Plane
[563, 602, 9]"] 113["SweepEdge Opposite"] 114["SweepEdge Opposite"] 115["SweepEdge Opposite"] 116["SweepEdge Opposite"] - 118["Sweep Loft
[967, 995, 8]"] + 118["Sweep Loft
[967, 995, 9]"] 119[Wall] 120[Wall] 121[Wall] @@ -270,15 +270,15 @@ flowchart LR 126["SweepEdge Adjacent"] 127["SweepEdge Adjacent"] 128["SweepEdge Adjacent"] - 129["Plane
[525, 542, 6]"] - 137["Plane
[1072, 1089, 6]"] - 144["Plane
[1571, 1588, 6]"] - 155["Plane
[2857, 2874, 6]"] - 174["Plane
[2919, 2936, 6]"] - 181["Plane
[2983, 3000, 6]"] - 188["Plane
[3046, 3063, 6]"] - 195["Plane
[3109, 3126, 6]"] - 202["Sweep Extrusion
[3162, 3198, 6]"] + 129["Plane
[525, 542, 7]"] + 137["Plane
[1072, 1089, 7]"] + 144["Plane
[1571, 1588, 7]"] + 155["Plane
[2857, 2874, 7]"] + 174["Plane
[2919, 2936, 7]"] + 181["Plane
[2983, 3000, 7]"] + 188["Plane
[3046, 3063, 7]"] + 195["Plane
[3109, 3126, 7]"] + 202["Sweep Extrusion
[3162, 3198, 7]"] 203[Wall] 204[Wall] 205[Wall] @@ -305,8 +305,8 @@ flowchart LR 226["SweepEdge Adjacent"] 227["SweepEdge Opposite"] 228["SweepEdge Adjacent"] - 229["Plane
[263, 280, 9]"] - 236["Sweep Extrusion
[649, 701, 9]"] + 229["Plane
[263, 280, 10]"] + 236["Sweep Extrusion
[649, 701, 10]"] 237[Wall] 238[Wall] 239[Wall] @@ -321,12 +321,12 @@ flowchart LR 248["SweepEdge Adjacent"] 249["SweepEdge Opposite"] 250["SweepEdge Adjacent"] - 251["EdgeCut Fillet
[709, 931, 9]"] - 252["EdgeCut Fillet
[709, 931, 9]"] - 253["EdgeCut Fillet
[709, 931, 9]"] - 254["EdgeCut Fillet
[709, 931, 9]"] - 255["Plane
[352, 369, 10]"] - 263["Sweep Revolve
[643, 662, 10]"] + 251["EdgeCut Fillet
[709, 931, 10]"] + 252["EdgeCut Fillet
[709, 931, 10]"] + 253["EdgeCut Fillet
[709, 931, 10]"] + 254["EdgeCut Fillet
[709, 931, 10]"] + 255["Plane
[352, 369, 11]"] + 263["Sweep Revolve
[643, 662, 11]"] 264[Wall] 265[Wall] 266[Wall] @@ -336,8 +336,8 @@ flowchart LR 270["SweepEdge Adjacent"] 271["SweepEdge Adjacent"] 272["SweepEdge Adjacent"] - 273["Plane
[286, 303, 11]"] - 280["Sweep Extrusion
[563, 610, 11]"] + 273["Plane
[286, 303, 12]"] + 280["Sweep Extrusion
[563, 610, 12]"] 281[Wall] 282[Wall] 283[Wall] @@ -352,10 +352,10 @@ flowchart LR 292["SweepEdge Adjacent"] 293["SweepEdge Opposite"] 294["SweepEdge Adjacent"] - 295["EdgeCut Chamfer
[618, 764, 11]"] - 296["EdgeCut Chamfer
[618, 764, 11]"] - 297["Plane
[286, 303, 11]"] - 304["Sweep Extrusion
[563, 610, 11]"] + 295["EdgeCut Chamfer
[618, 764, 12]"] + 296["EdgeCut Chamfer
[618, 764, 12]"] + 297["Plane
[286, 303, 12]"] + 304["Sweep Extrusion
[563, 610, 12]"] 305[Wall] 306[Wall] 307[Wall] @@ -370,10 +370,10 @@ flowchart LR 316["SweepEdge Adjacent"] 317["SweepEdge Opposite"] 318["SweepEdge Adjacent"] - 319["EdgeCut Chamfer
[618, 764, 11]"] - 320["EdgeCut Chamfer
[618, 764, 11]"] - 321["Plane
[286, 303, 11]"] - 328["Sweep Extrusion
[563, 610, 11]"] + 319["EdgeCut Chamfer
[618, 764, 12]"] + 320["EdgeCut Chamfer
[618, 764, 12]"] + 321["Plane
[286, 303, 12]"] + 328["Sweep Extrusion
[563, 610, 12]"] 329[Wall] 330[Wall] 331[Wall] @@ -388,10 +388,10 @@ flowchart LR 340["SweepEdge Adjacent"] 341["SweepEdge Opposite"] 342["SweepEdge Adjacent"] - 343["EdgeCut Chamfer
[618, 764, 11]"] - 344["EdgeCut Chamfer
[618, 764, 11]"] - 345["Plane
[286, 303, 11]"] - 352["Sweep Extrusion
[563, 610, 11]"] + 343["EdgeCut Chamfer
[618, 764, 12]"] + 344["EdgeCut Chamfer
[618, 764, 12]"] + 345["Plane
[286, 303, 12]"] + 352["Sweep Extrusion
[563, 610, 12]"] 353[Wall] 354[Wall] 355[Wall] @@ -406,18 +406,18 @@ flowchart LR 364["SweepEdge Adjacent"] 365["SweepEdge Opposite"] 366["SweepEdge Adjacent"] - 367["EdgeCut Chamfer
[618, 764, 11]"] - 368["EdgeCut Chamfer
[618, 764, 11]"] - 369["StartSketchOnFace
[1041, 1074, 5]"] - 370["StartSketchOnFace
[2077, 2111, 5]"] - 371["StartSketchOnFace
[2476, 2510, 5]"] - 372["StartSketchOnFace
[1041, 1074, 5]"] - 373["StartSketchOnFace
[2077, 2111, 5]"] - 374["StartSketchOnFace
[2476, 2510, 5]"] - 375["StartSketchOnPlane
[617, 641, 8]"] - 376["StartSketchOnPlane
[511, 543, 6]"] - 377["StartSketchOnPlane
[1058, 1090, 6]"] - 378["StartSketchOnPlane
[1557, 1589, 6]"] + 367["EdgeCut Chamfer
[618, 764, 12]"] + 368["EdgeCut Chamfer
[618, 764, 12]"] + 369["StartSketchOnFace
[1041, 1074, 6]"] + 370["StartSketchOnFace
[2077, 2111, 6]"] + 371["StartSketchOnFace
[2476, 2510, 6]"] + 372["StartSketchOnFace
[1041, 1074, 6]"] + 373["StartSketchOnFace
[2077, 2111, 6]"] + 374["StartSketchOnFace
[2476, 2510, 6]"] + 375["StartSketchOnPlane
[617, 641, 9]"] + 376["StartSketchOnPlane
[511, 543, 7]"] + 377["StartSketchOnPlane
[1058, 1090, 7]"] + 378["StartSketchOnPlane
[1557, 1589, 7]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ast.snap b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ast.snap index 426588857..f26b222a4 100644 --- a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ast.snap @@ -280,108 +280,25 @@ description: Result of parsing walkie-talkie.kcl "label": { "commentStart": 730, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 742, - "elements": [ - { - "commentStart": 743, - "end": 0, - "left": { - "commentStart": 743, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 744, - "end": 0, - "name": { - "commentStart": 744, - "end": 0, - "name": "width", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 743, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 752, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "commentStart": 756, - "end": 0, - "raw": ".45", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.45, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { + "commentStart": 734, + "end": 0, + "left": { + "commentStart": 734, + "end": 0, + "left": { "argument": { - "commentStart": 762, - "end": 0, - "raw": "0.10", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.1, - "suffix": "None" - } - }, - "commentStart": 761, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 768, - "end": 0, - "left": { "abs_path": false, - "commentStart": 768, + "commentStart": 735, "end": 0, "name": { - "commentStart": 768, + "commentStart": 735, "end": 0, - "name": "height", + "name": "width", "start": 0, "type": "Identifier" }, @@ -390,28 +307,122 @@ description: Result of parsing walkie-talkie.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 777, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, + "commentStart": 734, + "end": 0, + "operator": "-", "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 743, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 747, + "end": 0, + "raw": ".45", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.45, + "suffix": "None" } - ], - "end": 0, + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 752, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 757, + "end": 0, + "raw": "0.10", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.1, + "suffix": "None" + } + }, + "commentStart": 756, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 763, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 767, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 767, + "end": 0, + "name": { + "commentStart": 767, + "end": 0, + "name": "height", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 776, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], @@ -444,7 +455,7 @@ description: Result of parsing walkie-talkie.kcl "nonCodeNodes": { "1": [ { - "commentStart": 780, + "commentStart": 778, "end": 0, "start": 0, "type": "NonCodeNode", @@ -472,7 +483,7 @@ description: Result of parsing walkie-talkie.kcl "type": "ExpressionStatement" }, { - "commentStart": 801, + "commentStart": 799, "end": 0, "expression": { "body": [ @@ -480,10 +491,10 @@ description: Result of parsing walkie-talkie.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 801, + "commentStart": 799, "end": 0, "name": { - "commentStart": 801, + "commentStart": 799, "end": 0, "name": "case", "start": 0, @@ -493,7 +504,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 801, + "commentStart": 799, "end": 0, "start": 0, "type": "CallExpression", @@ -504,73 +515,84 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 823, + "commentStart": 821, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 835, - "elements": [ - { - "commentStart": 836, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "argument": { - "commentStart": 840, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "commentStart": 839, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 843, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], + "commentStart": 825, "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 828, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 833, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "commentStart": 832, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 836, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 840, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } } ], "callee": { "abs_path": false, - "commentStart": 813, + "commentStart": 811, "end": 0, "name": { - "commentStart": 813, + "commentStart": 811, "end": 0, "name": "translate", "start": 0, @@ -580,7 +602,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 813, + "commentStart": 811, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -588,13 +610,13 @@ description: Result of parsing walkie-talkie.kcl "unlabeled": null } ], - "commentStart": 801, + "commentStart": 799, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "1": [ { - "commentStart": 846, + "commentStart": 842, "end": 0, "start": 0, "type": "NonCodeNode", @@ -617,7 +639,7 @@ description: Result of parsing walkie-talkie.kcl "type": "ExpressionStatement" }, { - "commentStart": 874, + "commentStart": 870, "end": 0, "expression": { "body": [ @@ -625,10 +647,10 @@ description: Result of parsing walkie-talkie.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 874, + "commentStart": 870, "end": 0, "name": { - "commentStart": 874, + "commentStart": 870, "end": 0, "name": "talkButton", "start": 0, @@ -638,7 +660,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 874, + "commentStart": 870, "end": 0, "start": 0, "type": "CallExpression", @@ -649,121 +671,132 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 902, + "commentStart": 898, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 914, - "elements": [ - { - "commentStart": 915, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 915, - "end": 0, - "name": { - "commentStart": 915, - "end": 0, - "name": "width", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 923, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 926, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 927, - "end": 0, - "name": { - "commentStart": 927, - "end": 0, - "name": "thickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 926, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 939, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 942, - "end": 0, - "raw": ".5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" - } - } - ], + "commentStart": 902, "end": 0, + "left": { + "abs_path": false, + "commentStart": 902, + "end": 0, + "name": { + "commentStart": 902, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 910, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 913, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 917, + "end": 0, + "left": { + "argument": { + "abs_path": false, + "commentStart": 918, + "end": 0, + "name": { + "commentStart": 918, + "end": 0, + "name": "thickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 917, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 930, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 933, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 937, + "end": 0, + "raw": ".5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } } } ], "callee": { "abs_path": false, - "commentStart": 892, + "commentStart": 888, "end": 0, "name": { - "commentStart": 892, + "commentStart": 888, "end": 0, "name": "translate", "start": 0, @@ -773,7 +806,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 892, + "commentStart": 888, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -781,13 +814,13 @@ description: Result of parsing walkie-talkie.kcl "unlabeled": null } ], - "commentStart": 874, + "commentStart": 870, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "1": [ { - "commentStart": 946, + "commentStart": 940, "end": 0, "start": 0, "type": "NonCodeNode", @@ -810,7 +843,7 @@ description: Result of parsing walkie-talkie.kcl "type": "ExpressionStatement" }, { - "commentStart": 977, + "commentStart": 971, "end": 0, "expression": { "body": [ @@ -818,10 +851,10 @@ description: Result of parsing walkie-talkie.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 977, + "commentStart": 971, "end": 0, "name": { - "commentStart": 977, + "commentStart": 971, "end": 0, "name": "knob", "start": 0, @@ -831,7 +864,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 977, + "commentStart": 971, "end": 0, "start": 0, "type": "CallExpression", @@ -842,165 +875,176 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 999, + "commentStart": 993, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1011, - "elements": [ - { + "commentStart": 997, + "end": 0, + "left": { + "commentStart": 997, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 997, + "end": 0, + "name": { + "commentStart": 997, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1005, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 1009, + "end": 0, + "raw": "0.70", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.7, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1015, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1019, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 1020, "end": 0, - "left": { + "name": { "commentStart": 1020, "end": 0, - "left": { - "abs_path": false, - "commentStart": 1020, - "end": 0, - "name": { - "commentStart": 1020, - "end": 0, - "name": "width", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1028, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, + "name": "thickness", "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "-", - "right": { - "commentStart": 1032, - "end": 0, - "raw": "0.70", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.7, - "suffix": "None" - } + "type": "Identifier" }, + "path": [], "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "Name", + "type": "Name" }, - { - "commentStart": 1045, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 1046, - "end": 0, - "name": { - "commentStart": 1046, - "end": 0, - "name": "thickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 1045, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 1058, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 1068, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1068, - "end": 0, - "name": { - "commentStart": 1068, - "end": 0, - "name": "height", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1077, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "commentStart": 1019, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 1032, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" } - ], - "end": 0, + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1035, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1039, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1039, + "end": 0, + "name": { + "commentStart": 1039, + "end": 0, + "name": "height", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1048, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], "callee": { "abs_path": false, - "commentStart": 989, + "commentStart": 983, "end": 0, "name": { - "commentStart": 989, + "commentStart": 983, "end": 0, "name": "translate", "start": 0, @@ -1010,7 +1054,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 989, + "commentStart": 983, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1018,13 +1062,13 @@ description: Result of parsing walkie-talkie.kcl "unlabeled": null } ], - "commentStart": 977, + "commentStart": 971, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "1": [ { - "commentStart": 1086, + "commentStart": 1050, "end": 0, "start": 0, "type": "NonCodeNode", @@ -1047,7 +1091,7 @@ description: Result of parsing walkie-talkie.kcl "type": "ExpressionStatement" }, { - "commentStart": 1110, + "commentStart": 1074, "end": 0, "expression": { "body": [ @@ -1055,10 +1099,10 @@ description: Result of parsing walkie-talkie.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1110, + "commentStart": 1074, "end": 0, "name": { - "commentStart": 1110, + "commentStart": 1074, "end": 0, "name": "button", "start": 0, @@ -1068,7 +1112,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 1110, + "commentStart": 1074, "end": 0, "start": 0, "type": "CallExpression", @@ -1079,109 +1123,330 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 1134, + "commentStart": 1098, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1146, - "elements": [ - { - "argument": { - "commentStart": 1157, - "end": 0, - "left": { - "commentStart": 1157, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1157, - "end": 0, - "name": { - "commentStart": 1157, - "end": 0, - "name": "screenWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1171, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 1175, - "end": 0, - "name": { - "commentStart": 1175, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "commentStart": 1155, + "argument": { + "commentStart": 1104, + "end": 0, + "left": { + "commentStart": 1104, "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { - "commentStart": 1195, + "left": { + "abs_path": false, + "commentStart": 1104, "end": 0, - "raw": "1", + "name": { + "commentStart": 1104, + "end": 0, + "name": "screenWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1118, + "end": 0, + "raw": "2", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 1.0, + "value": 2.0, "suffix": "None" } }, - "commentStart": 1194, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - { + "operator": "+", + "right": { "abs_path": false, - "commentStart": 1205, + "commentStart": 1122, "end": 0, "name": { - "commentStart": 1205, + "commentStart": 1122, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "commentStart": 1102, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1134, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1139, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "commentStart": 1138, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1142, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "abs_path": false, + "commentStart": 1146, + "end": 0, + "name": { + "commentStart": 1146, + "end": 0, + "name": "screenYPosition", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 1088, + "end": 0, + "name": { + "commentStart": 1088, + "end": 0, + "name": "translate", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 1088, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + } + ], + "commentStart": 1074, + "end": 0, + "start": 0, + "type": "PipeExpression", + "type": "PipeExpression" + }, + "start": 0, + "type": "ExpressionStatement", + "type": "ExpressionStatement" + }, + { + "commentStart": 1163, + "end": 0, + "expression": { + "body": [ + { + "arguments": [], + "callee": { + "abs_path": false, + "commentStart": 1163, + "end": 0, + "name": { + "commentStart": 1163, + "end": 0, + "name": "button", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 1163, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 1187, + "end": 0, + "name": "x", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1193, + "end": 0, + "left": { + "commentStart": 1193, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1193, + "end": 0, + "name": { + "commentStart": 1193, + "end": 0, + "name": "screenWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1207, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1211, + "end": 0, + "name": { + "commentStart": 1211, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "commentStart": 1191, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1223, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1228, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "commentStart": 1227, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1231, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1235, + "end": 0, + "left": { + "commentStart": 1235, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1235, + "end": 0, + "name": { + "commentStart": 1235, "end": 0, "name": "screenYPosition", "start": 0, @@ -1191,21 +1456,77 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name", "type": "Name" - } - ], - "end": 0, + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 1253, + "end": 0, + "name": { + "commentStart": 1253, + "end": 0, + "name": "buttonHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 1269, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1269, + "end": 0, + "name": { + "commentStart": 1269, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 1281, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" } } ], "callee": { "abs_path": false, - "commentStart": 1124, + "commentStart": 1177, "end": 0, "name": { - "commentStart": 1124, + "commentStart": 1177, "end": 0, "name": "translate", "start": 0, @@ -1215,7 +1536,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 1124, + "commentStart": 1177, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1223,7 +1544,7 @@ description: Result of parsing walkie-talkie.kcl "unlabeled": null } ], - "commentStart": 1110, + "commentStart": 1163, "end": 0, "start": 0, "type": "PipeExpression", @@ -1234,7 +1555,7 @@ description: Result of parsing walkie-talkie.kcl "type": "ExpressionStatement" }, { - "commentStart": 1229, + "commentStart": 1285, "end": 0, "expression": { "body": [ @@ -1242,10 +1563,10 @@ description: Result of parsing walkie-talkie.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 1229, + "commentStart": 1285, "end": 0, "name": { - "commentStart": 1229, + "commentStart": 1285, "end": 0, "name": "button", "start": 0, @@ -1255,7 +1576,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 1229, + "commentStart": 1285, "end": 0, "start": 0, "type": "CallExpression", @@ -1266,269 +1587,14 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 1253, - "end": 0, - "name": "translate", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1265, - "elements": [ - { - "argument": { - "commentStart": 1276, - "end": 0, - "left": { - "commentStart": 1276, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1276, - "end": 0, - "name": { - "commentStart": 1276, - "end": 0, - "name": "screenWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1290, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 1294, - "end": 0, - "name": { - "commentStart": 1294, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "commentStart": 1274, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { - "commentStart": 1314, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "commentStart": 1313, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 1324, - "end": 0, - "left": { - "commentStart": 1324, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1324, - "end": 0, - "name": { - "commentStart": 1324, - "end": 0, - "name": "screenYPosition", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 1342, - "end": 0, - "name": { - "commentStart": 1342, - "end": 0, - "name": "buttonHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "-", - "right": { - "commentStart": 1358, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1358, - "end": 0, - "name": { - "commentStart": 1358, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 1370, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - } - } - ], - "callee": { - "abs_path": false, - "commentStart": 1243, - "end": 0, - "name": { - "commentStart": 1243, - "end": 0, - "name": "translate", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 1243, - "end": 0, - "start": 0, - "type": "CallExpressionKw", - "type": "CallExpressionKw", - "unlabeled": null - } - ], - "commentStart": 1229, - "end": 0, - "start": 0, - "type": "PipeExpression", - "type": "PipeExpression" - }, - "start": 0, - "type": "ExpressionStatement", - "type": "ExpressionStatement" - }, - { - "commentStart": 1381, - "end": 0, - "expression": { - "body": [ - { - "arguments": [], - "callee": { - "abs_path": false, - "commentStart": 1381, - "end": 0, - "name": { - "commentStart": 1381, - "end": 0, - "name": "button", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 1381, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - { - "arguments": [ - { - "type": "LabeledArg", - "label": { - "commentStart": 1420, + "commentStart": 1324, "end": 0, "name": "roll", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1427, + "commentStart": 1331, "end": 0, "raw": "0", "start": 0, @@ -1543,14 +1609,14 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 1437, + "commentStart": 1341, "end": 0, "name": "pitch", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1445, + "commentStart": 1349, "end": 0, "raw": "180", "start": 0, @@ -1565,14 +1631,14 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 1457, + "commentStart": 1361, "end": 0, "name": "yaw", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1463, + "commentStart": 1367, "end": 0, "raw": "0", "start": 0, @@ -1587,10 +1653,10 @@ description: Result of parsing walkie-talkie.kcl ], "callee": { "abs_path": false, - "commentStart": 1395, + "commentStart": 1299, "end": 0, "name": { - "commentStart": 1395, + "commentStart": 1299, "end": 0, "name": "rotate", "start": 0, @@ -1600,13 +1666,13 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 1395, + "commentStart": 1299, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { - "commentStart": 1410, + "commentStart": 1314, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -1618,121 +1684,474 @@ description: Result of parsing walkie-talkie.kcl { "type": "LabeledArg", "label": { - "commentStart": 1496, + "commentStart": 1400, "end": 0, - "name": "translate", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1508, - "elements": [ - { - "commentStart": 1519, + "commentStart": 1404, + "end": 0, + "left": { + "commentStart": 1404, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1404, "end": 0, - "left": { - "commentStart": 1519, + "name": { + "commentStart": 1404, "end": 0, - "left": { - "abs_path": false, - "commentStart": 1519, - "end": 0, - "name": { - "commentStart": 1519, - "end": 0, - "name": "screenWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1533, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, + "name": "screenWidth", "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 1537, - "end": 0, - "name": { - "commentStart": 1537, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "Identifier" }, + "path": [], "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "Name", + "type": "Name" }, - { - "argument": { - "commentStart": 1558, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "commentStart": 1557, + "operator": "/", + "right": { + "commentStart": 1418, "end": 0, - "operator": "-", + "raw": "2", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - { - "commentStart": 1570, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1422, + "end": 0, + "name": { + "commentStart": 1422, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1440, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1445, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "commentStart": 1444, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1455, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1459, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1459, + "end": 0, + "name": { + "commentStart": 1459, + "end": 0, + "name": "screenYPosition", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 1477, + "end": 0, + "name": { + "commentStart": 1477, + "end": 0, + "name": "buttonHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1498, + "end": 0, + "name": "global", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1507, + "end": 0, + "raw": "true", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": true + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 1382, + "end": 0, + "name": { + "commentStart": 1382, + "end": 0, + "name": "translate", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 1382, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + } + ], + "commentStart": 1285, + "end": 0, + "start": 0, + "type": "PipeExpression", + "type": "PipeExpression" + }, + "start": 0, + "type": "ExpressionStatement", + "type": "ExpressionStatement" + }, + { + "commentStart": 1520, + "end": 0, + "expression": { + "body": [ + { + "arguments": [], + "callee": { + "abs_path": false, + "commentStart": 1520, + "end": 0, + "name": { + "commentStart": 1520, + "end": 0, + "name": "button", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 1520, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 1559, + "end": 0, + "name": "roll", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1566, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1576, + "end": 0, + "name": "pitch", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1584, + "end": 0, + "raw": "180", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 180.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1596, + "end": 0, + "name": "yaw", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1602, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 1534, + "end": 0, + "name": { + "commentStart": 1534, + "end": 0, + "name": "rotate", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 1534, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 1549, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 1635, + "end": 0, + "name": "x", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1639, + "end": 0, + "left": { + "commentStart": 1639, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1639, + "end": 0, + "name": { + "commentStart": 1639, + "end": 0, + "name": "screenWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 1653, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 1657, + "end": 0, + "name": { + "commentStart": 1657, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1675, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "commentStart": 1680, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "commentStart": 1679, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1690, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1694, + "end": 0, + "left": { + "commentStart": 1694, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1694, + "end": 0, + "name": { + "commentStart": 1694, + "end": 0, + "name": "screenYPosition", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "commentStart": 1713, "end": 0, "left": { "abs_path": false, - "commentStart": 1570, + "commentStart": 1713, "end": 0, "name": { - "commentStart": 1570, - "end": 0, - "name": "screenYPosition", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 1588, - "end": 0, - "name": { - "commentStart": 1588, + "commentStart": 1713, "end": 0, "name": "buttonHeight", "start": 0, @@ -1743,411 +2162,80 @@ description: Result of parsing walkie-talkie.kcl "type": "Name", "type": "Name" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - } - }, - { - "type": "LabeledArg", - "label": { - "commentStart": 1618, - "end": 0, - "name": "global", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1627, - "end": 0, - "raw": "true", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": true - } - } - ], - "callee": { - "abs_path": false, - "commentStart": 1478, - "end": 0, - "name": { - "commentStart": 1478, - "end": 0, - "name": "translate", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 1478, - "end": 0, - "start": 0, - "type": "CallExpressionKw", - "type": "CallExpressionKw", - "unlabeled": null - } - ], - "commentStart": 1381, - "end": 0, - "start": 0, - "type": "PipeExpression", - "type": "PipeExpression" - }, - "start": 0, - "type": "ExpressionStatement", - "type": "ExpressionStatement" - }, - { - "commentStart": 1640, - "end": 0, - "expression": { - "body": [ - { - "arguments": [], - "callee": { - "abs_path": false, - "commentStart": 1640, - "end": 0, - "name": { - "commentStart": 1640, - "end": 0, - "name": "button", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 1640, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - { - "arguments": [ - { - "type": "LabeledArg", - "label": { - "commentStart": 1679, - "end": 0, - "name": "roll", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1686, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - }, - { - "type": "LabeledArg", - "label": { - "commentStart": 1696, - "end": 0, - "name": "pitch", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1704, - "end": 0, - "raw": "180", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 180.0, - "suffix": "None" - } - } - }, - { - "type": "LabeledArg", - "label": { - "commentStart": 1716, - "end": 0, - "name": "yaw", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1722, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - } - ], - "callee": { - "abs_path": false, - "commentStart": 1654, - "end": 0, - "name": { - "commentStart": 1654, - "end": 0, - "name": "rotate", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 1654, - "end": 0, - "start": 0, - "type": "CallExpressionKw", - "type": "CallExpressionKw", - "unlabeled": { - "commentStart": 1669, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" - } - }, - { - "arguments": [ - { - "type": "LabeledArg", - "label": { - "commentStart": 1755, - "end": 0, - "name": "translate", - "start": 0, - "type": "Identifier" - }, - "arg": { - "commentStart": 1767, - "elements": [ - { - "commentStart": 1778, - "end": 0, - "left": { - "commentStart": 1778, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1778, - "end": 0, - "name": { - "commentStart": 1778, - "end": 0, - "name": "screenWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 1792, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", + "operator": "*", "right": { - "abs_path": false, - "commentStart": 1796, + "commentStart": 1728, "end": 0, - "name": { - "commentStart": 1796, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "argument": { - "commentStart": 1817, - "end": 0, - "raw": "1", + "raw": "2", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 1.0, + "value": 2.0, "suffix": "None" } }, - "commentStart": 1816, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 1829, - "end": 0, - "left": { - "commentStart": 1829, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1829, - "end": 0, - "name": { - "commentStart": 1829, - "end": 0, - "name": "screenYPosition", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "commentStart": 1848, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1848, - "end": 0, - "name": { - "commentStart": 1848, - "end": 0, - "name": "buttonHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 1863, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "-", - "right": { - "commentStart": 1869, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 1869, - "end": 0, - "name": { - "commentStart": 1869, - "end": 0, - "name": "tolerance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 1881, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - } - ], - "end": 0, + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 1734, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 1734, + "end": 0, + "name": { + "commentStart": 1734, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 1746, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" } }, { "type": "LabeledArg", "label": { - "commentStart": 1901, + "commentStart": 1757, "end": 0, "name": "global", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1910, + "commentStart": 1766, "end": 0, "raw": "true", "start": 0, @@ -2159,10 +2247,10 @@ description: Result of parsing walkie-talkie.kcl ], "callee": { "abs_path": false, - "commentStart": 1737, + "commentStart": 1617, "end": 0, "name": { - "commentStart": 1737, + "commentStart": 1617, "end": 0, "name": "translate", "start": 0, @@ -2172,7 +2260,7 @@ description: Result of parsing walkie-talkie.kcl "start": 0, "type": "Name" }, - "commentStart": 1737, + "commentStart": 1617, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2180,7 +2268,7 @@ description: Result of parsing walkie-talkie.kcl "unlabeled": null } ], - "commentStart": 1640, + "commentStart": 1520, "end": 0, "start": 0, "type": "PipeExpression", diff --git a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap index d420379e4..959b9886b 100644 --- a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap @@ -9,7 +9,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 359, 2786, - 5 + 6 ], "unlabeledArg": null, "labeledArgs": {}, @@ -355,7 +355,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 359, 2786, - 5 + 6 ], "unlabeledArg": null, "labeledArgs": {}, @@ -701,7 +701,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 266, 1051, - 8 + 9 ], "unlabeledArg": null, "labeledArgs": {}, @@ -804,7 +804,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 454, 3283, - 6 + 7 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1890,7 +1890,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 69, 1088, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -1946,7 +1946,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 1146, 1656, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2002,7 +2002,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 1674, 2184, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2058,7 +2058,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 1146, 1656, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2114,7 +2114,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 1674, 2184, - 7 + 8 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2190,7 +2190,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 202, 1023, - 9 + 10 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2308,7 +2308,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 298, 748, - 10 + 11 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2361,7 +2361,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 221, 827, - 11 + 12 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2471,7 +2471,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 221, 827, - 11 + 12 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2581,7 +2581,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 221, 827, - 11 + 12 ], "unlabeledArg": null, "labeledArgs": {}, @@ -2691,7 +2691,7 @@ description: Operations executed walkie-talkie.kcl "functionSourceRange": [ 221, 827, - 11 + 12 ], "unlabeledArg": null, "labeledArgs": {}, diff --git a/rust/kcl-lib/tests/kcl_samples/washer/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/washer/artifact_commands.snap index 8b83f2e68..6e405f5a6 100644 --- a/rust/kcl-lib/tests/kcl_samples/washer/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/washer/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands washer.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kittycad_svg/artifact_commands.snap b/rust/kcl-lib/tests/kittycad_svg/artifact_commands.snap index 775f58ba4..2f0884759 100644 --- a/rust/kcl-lib/tests/kittycad_svg/artifact_commands.snap +++ b/rust/kcl-lib/tests/kittycad_svg/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kittycad_svg.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kw_fn/artifact_commands.snap b/rust/kcl-lib/tests/kw_fn/artifact_commands.snap index 544a4f7d4..6bbd1fc4e 100644 --- a/rust/kcl-lib/tests/kw_fn/artifact_commands.snap +++ b/rust/kcl-lib/tests/kw_fn/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kw_fn.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kw_fn_too_few_args/artifact_commands.snap b/rust/kcl-lib/tests/kw_fn_too_few_args/artifact_commands.snap index 8cf5dfd3e..1b849e3cc 100644 --- a/rust/kcl-lib/tests/kw_fn_too_few_args/artifact_commands.snap +++ b/rust/kcl-lib/tests/kw_fn_too_few_args/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kw_fn_too_few_args.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kw_fn_unlabeled_but_has_label/artifact_commands.snap b/rust/kcl-lib/tests/kw_fn_unlabeled_but_has_label/artifact_commands.snap index a3ee9277d..7f52f6ee2 100644 --- a/rust/kcl-lib/tests/kw_fn_unlabeled_but_has_label/artifact_commands.snap +++ b/rust/kcl-lib/tests/kw_fn_unlabeled_but_has_label/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kw_fn_unlabeled_but_has_label.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/kw_fn_with_defaults/artifact_commands.snap b/rust/kcl-lib/tests/kw_fn_with_defaults/artifact_commands.snap index 56a2d58c2..e604be4b8 100644 --- a/rust/kcl-lib/tests/kw_fn_with_defaults/artifact_commands.snap +++ b/rust/kcl-lib/tests/kw_fn_with_defaults/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands kw_fn_with_defaults.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/artifact_commands.snap b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/artifact_commands.snap index 572908ee2..071dc3c37 100644 --- a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/artifact_commands.snap +++ b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands linear_pattern3d_a_pattern.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/mike_stress_test/artifact_commands.snap b/rust/kcl-lib/tests/mike_stress_test/artifact_commands.snap index b6bd6ccc9..75ae6551f 100644 --- a/rust/kcl-lib/tests/mike_stress_test/artifact_commands.snap +++ b/rust/kcl-lib/tests/mike_stress_test/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands mike_stress_test.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/multi_transform/artifact_commands.snap b/rust/kcl-lib/tests/multi_transform/artifact_commands.snap index d1d0c82c0..a42d8a434 100644 --- a/rust/kcl-lib/tests/multi_transform/artifact_commands.snap +++ b/rust/kcl-lib/tests/multi_transform/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands multi_transform.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/neg_xz_plane/artifact_commands.snap b/rust/kcl-lib/tests/neg_xz_plane/artifact_commands.snap index a803f20d2..f76b9f0d4 100644 --- a/rust/kcl-lib/tests/neg_xz_plane/artifact_commands.snap +++ b/rust/kcl-lib/tests/neg_xz_plane/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands neg_xz_plane.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/non_string_key_of_object/artifact_commands.snap b/rust/kcl-lib/tests/non_string_key_of_object/artifact_commands.snap index 2e9335f3c..346495b20 100644 --- a/rust/kcl-lib/tests/non_string_key_of_object/artifact_commands.snap +++ b/rust/kcl-lib/tests/non_string_key_of_object/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands non_string_key_of_object.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/object_prop_not_found/artifact_commands.snap b/rust/kcl-lib/tests/object_prop_not_found/artifact_commands.snap index 2f4ee8596..1425055e3 100644 --- a/rust/kcl-lib/tests/object_prop_not_found/artifact_commands.snap +++ b/rust/kcl-lib/tests/object_prop_not_found/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands object_prop_not_found.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/out_of_band_sketches/artifact_commands.snap b/rust/kcl-lib/tests/out_of_band_sketches/artifact_commands.snap index c1f5ba1f1..f73f2f84a 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/artifact_commands.snap +++ b/rust/kcl-lib/tests/out_of_band_sketches/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands out_of_band_sketches.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/parametric/artifact_commands.snap b/rust/kcl-lib/tests/parametric/artifact_commands.snap index fbd4dfa29..964e9c8ad 100644 --- a/rust/kcl-lib/tests/parametric/artifact_commands.snap +++ b/rust/kcl-lib/tests/parametric/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands parametric.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/parametric_with_tan_arc/artifact_commands.snap b/rust/kcl-lib/tests/parametric_with_tan_arc/artifact_commands.snap index 4f4b60860..f7be42358 100644 --- a/rust/kcl-lib/tests/parametric_with_tan_arc/artifact_commands.snap +++ b/rust/kcl-lib/tests/parametric_with_tan_arc/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands parametric_with_tan_arc.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/pentagon_fillet_sugar/artifact_commands.snap b/rust/kcl-lib/tests/pentagon_fillet_sugar/artifact_commands.snap index f12fd872d..add89aa8d 100644 --- a/rust/kcl-lib/tests/pentagon_fillet_sugar/artifact_commands.snap +++ b/rust/kcl-lib/tests/pentagon_fillet_sugar/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pentagon_fillet_sugar.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/pipe_as_arg/artifact_commands.snap b/rust/kcl-lib/tests/pipe_as_arg/artifact_commands.snap index 9b89cbb3f..9b440bdd0 100644 --- a/rust/kcl-lib/tests/pipe_as_arg/artifact_commands.snap +++ b/rust/kcl-lib/tests/pipe_as_arg/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pipe_as_arg.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/pipe_substitution_inside_function_called_from_pipeline/artifact_commands.snap b/rust/kcl-lib/tests/pipe_substitution_inside_function_called_from_pipeline/artifact_commands.snap index 84d21eecd..8ab594fcb 100644 --- a/rust/kcl-lib/tests/pipe_substitution_inside_function_called_from_pipeline/artifact_commands.snap +++ b/rust/kcl-lib/tests/pipe_substitution_inside_function_called_from_pipeline/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands pipe_substitution_inside_function_called_from_pip "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/poop_chute/artifact_commands.snap b/rust/kcl-lib/tests/poop_chute/artifact_commands.snap index 37a8f580d..020bc0418 100644 --- a/rust/kcl-lib/tests/poop_chute/artifact_commands.snap +++ b/rust/kcl-lib/tests/poop_chute/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands poop_chute.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/property_of_object/artifact_commands.snap b/rust/kcl-lib/tests/property_of_object/artifact_commands.snap index fbe3e57a0..513d26c0b 100644 --- a/rust/kcl-lib/tests/property_of_object/artifact_commands.snap +++ b/rust/kcl-lib/tests/property_of_object/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands property_of_object.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/revolve_about_edge/artifact_commands.snap b/rust/kcl-lib/tests/revolve_about_edge/artifact_commands.snap index d6cb74271..e5d3120b8 100644 --- a/rust/kcl-lib/tests/revolve_about_edge/artifact_commands.snap +++ b/rust/kcl-lib/tests/revolve_about_edge/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands revolve_about_edge.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/riddle_small/artifact_commands.snap b/rust/kcl-lib/tests/riddle_small/artifact_commands.snap index 5fdc8f6c9..222b2b5f7 100644 --- a/rust/kcl-lib/tests/riddle_small/artifact_commands.snap +++ b/rust/kcl-lib/tests/riddle_small/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands riddle_small.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/rotate_after_fillet/artifact_commands.snap b/rust/kcl-lib/tests/rotate_after_fillet/artifact_commands.snap index a94b0be47..8c18be435 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/artifact_commands.snap +++ b/rust/kcl-lib/tests/rotate_after_fillet/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands rotate_after_fillet.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/scale_after_fillet/artifact_commands.snap b/rust/kcl-lib/tests/scale_after_fillet/artifact_commands.snap index 5d911b59c..6e1139869 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/artifact_commands.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands scale_after_fillet.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/scale_after_fillet/ast.snap b/rust/kcl-lib/tests/scale_after_fillet/ast.snap index ceb4fd731..61ed95ce4 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/ast.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/ast.snap @@ -2097,54 +2097,65 @@ description: Result of parsing scale_after_fillet.kcl "label": { "commentStart": 1593, "end": 0, - "name": "scale", + "name": "x", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1601, - "elements": [ - { - "commentStart": 1602, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 1608, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - }, - { - "commentStart": 1614, - "end": 0, - "raw": "3.14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.14, - "suffix": "None" - } - } - ], + "commentStart": 1597, "end": 0, + "raw": "3.14", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1603, + "end": 0, + "name": "y", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1607, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1613, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1617, + "end": 0, + "raw": "3.14", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.14, + "suffix": "None" + } } } ], @@ -2177,7 +2188,7 @@ description: Result of parsing scale_after_fillet.kcl "nonCodeNodes": { "1": [ { - "commentStart": 1620, + "commentStart": 1622, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/scale_after_fillet/input.kcl b/rust/kcl-lib/tests/scale_after_fillet/input.kcl index 975256834..df0fa29ab 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/input.kcl +++ b/rust/kcl-lib/tests/scale_after_fillet/input.kcl @@ -52,6 +52,6 @@ export fn bolt() { } bolt() - |> scale(scale = [3.14, 3.14, 3.14]) + |> scale(x = 3.14, y = 3.14, z = 3.14) // https://www.mcmaster.com/91251a404/ diff --git a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap index c2e54902a..412227e5a 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap @@ -56,6 +56,6 @@ export fn bolt() { } bolt() - |> scale(scale = [3.14, 3.14, 3.14]) + |> scale(x = 3.14, y = 3.14, z = 3.14) // https://www.mcmaster.com/91251a404/ diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/artifact_commands.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/artifact_commands.snap index 6e036a30c..7b02e81ed 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch-on-chamfer-two-times-different-order.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/artifact_commands.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/artifact_commands.snap index 6a6f00d85..0d3adf5aa 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch-on-chamfer-two-times.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_in_object/artifact_commands.snap b/rust/kcl-lib/tests/sketch_in_object/artifact_commands.snap index c7fbc4106..c260a3a0d 100644 --- a/rust/kcl-lib/tests/sketch_in_object/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_in_object/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_in_object.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face/artifact_commands.snap index 7f733af2b..f37c2234b 100644 --- a/rust/kcl-lib/tests/sketch_on_face/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/artifact_commands.snap index b9c8b2e5a..f171056e3 100644 --- a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face_after_fillets_referencing_face.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/artifact_commands.snap index a6839fac1..75da18b40 100644 --- a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face_circle_tagged.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face_end/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face_end/artifact_commands.snap index ead803a03..a86e87380 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face_end.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/artifact_commands.snap index 6fc2dd25b..9832f6e82 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face_end_negative_extrude.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/sketch_on_face_start/artifact_commands.snap b/rust/kcl-lib/tests/sketch_on_face_start/artifact_commands.snap index 5699daa3e..ba5108432 100644 --- a/rust/kcl-lib/tests/sketch_on_face_start/artifact_commands.snap +++ b/rust/kcl-lib/tests/sketch_on_face_start/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands sketch_on_face_start.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/ssi_pattern/artifact_commands.snap b/rust/kcl-lib/tests/ssi_pattern/artifact_commands.snap index 2f5343f95..4d3ca26ce 100644 --- a/rust/kcl-lib/tests/ssi_pattern/artifact_commands.snap +++ b/rust/kcl-lib/tests/ssi_pattern/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands ssi_pattern.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/subtract_cylinder_from_cube/artifact_commands.snap b/rust/kcl-lib/tests/subtract_cylinder_from_cube/artifact_commands.snap index bb6a03ef3..86815f4f1 100644 --- a/rust/kcl-lib/tests/subtract_cylinder_from_cube/artifact_commands.snap +++ b/rust/kcl-lib/tests/subtract_cylinder_from_cube/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands subtract_cylinder_from_cube.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/tan_arc_x_line/artifact_commands.snap b/rust/kcl-lib/tests/tan_arc_x_line/artifact_commands.snap index c2c2b045c..3628827d6 100644 --- a/rust/kcl-lib/tests/tan_arc_x_line/artifact_commands.snap +++ b/rust/kcl-lib/tests/tan_arc_x_line/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands tan_arc_x_line.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/tangential_arc/artifact_commands.snap b/rust/kcl-lib/tests/tangential_arc/artifact_commands.snap index 5798d0d31..01e609007 100644 --- a/rust/kcl-lib/tests/tangential_arc/artifact_commands.snap +++ b/rust/kcl-lib/tests/tangential_arc/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands tangential_arc.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/translate_after_fillet/artifact_commands.snap b/rust/kcl-lib/tests/translate_after_fillet/artifact_commands.snap index 5a51ad708..46afdef21 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/artifact_commands.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands translate_after_fillet.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/translate_after_fillet/ast.snap b/rust/kcl-lib/tests/translate_after_fillet/ast.snap index 66a7ca7c6..eeefb9b59 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/ast.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/ast.snap @@ -2097,54 +2097,65 @@ description: Result of parsing translate_after_fillet.kcl "label": { "commentStart": 1597, "end": 0, - "name": "translate", + "name": "x", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1601, + "end": 0, + "raw": "10", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 10.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1605, + "end": 0, + "name": "y", "start": 0, "type": "Identifier" }, "arg": { "commentStart": 1609, - "elements": [ - { - "commentStart": 1610, - "end": 0, - "raw": "10", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 10.0, - "suffix": "None" - } - }, - { - "commentStart": 1614, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 1617, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], "end": 0, + "raw": "0", "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 1612, + "end": 0, + "name": "z", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 1616, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } } ], @@ -2177,7 +2188,7 @@ description: Result of parsing translate_after_fillet.kcl "nonCodeNodes": { "1": [ { - "commentStart": 1620, + "commentStart": 1618, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/translate_after_fillet/input.kcl b/rust/kcl-lib/tests/translate_after_fillet/input.kcl index 99489a82a..a53c193c7 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/input.kcl +++ b/rust/kcl-lib/tests/translate_after_fillet/input.kcl @@ -52,6 +52,6 @@ export fn bolt() { } bolt() - |> translate(translate = [10, 0, 0]) + |> translate(x = 10, y = 0, z = 0) // https://www.mcmaster.com/91251a404/ diff --git a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap index 54648c487..c7233b53a 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap @@ -56,6 +56,6 @@ export fn bolt() { } bolt() - |> translate(translate = [10, 0, 0]) + |> translate(x = 10, y = 0, z = 0) // https://www.mcmaster.com/91251a404/ diff --git a/rust/kcl-lib/tests/union_cubes/artifact_commands.snap b/rust/kcl-lib/tests/union_cubes/artifact_commands.snap index 725a7ecef..4a790e730 100644 --- a/rust/kcl-lib/tests/union_cubes/artifact_commands.snap +++ b/rust/kcl-lib/tests/union_cubes/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands union_cubes.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-lib/tests/xz_plane/artifact_commands.snap b/rust/kcl-lib/tests/xz_plane/artifact_commands.snap index 7d289fd6c..7dc70cd21 100644 --- a/rust/kcl-lib/tests/xz_plane/artifact_commands.snap +++ b/rust/kcl-lib/tests/xz_plane/artifact_commands.snap @@ -11,14 +11,6 @@ description: Artifact commands xz_plane.kcl "hidden": false } }, - { - "cmdId": "[uuid]", - "range": [], - "command": { - "type": "set_scene_units", - "unit": "mm" - } - }, { "cmdId": "[uuid]", "range": [], diff --git a/rust/kcl-python-bindings/Cargo.toml b/rust/kcl-python-bindings/Cargo.toml index 6983fab29..06d0a8036 100644 --- a/rust/kcl-python-bindings/Cargo.toml +++ b/rust/kcl-python-bindings/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "kcl-python-bindings" -version = "0.3.55" +version = "0.3.56" edition = "2021" repository = "https://github.com/kittycad/modeling-app" diff --git a/rust/kcl-test-server/Cargo.toml b/rust/kcl-test-server/Cargo.toml index 1ebf22028..b7a8591f6 100644 --- a/rust/kcl-test-server/Cargo.toml +++ b/rust/kcl-test-server/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-test-server" description = "A test server for KCL" -version = "0.1.55" +version = "0.1.56" edition = "2021" license = "MIT" diff --git a/rust/kcl-test-server/src/lib.rs b/rust/kcl-test-server/src/lib.rs index f23680119..308534269 100644 --- a/rust/kcl-test-server/src/lib.rs +++ b/rust/kcl-test-server/src/lib.rs @@ -15,7 +15,7 @@ use hyper::{ service::{make_service_fn, service_fn}, Body, Error, Response, Server, }; -use kcl_lib::{test_server::RequestBody, ExecState, ExecutorContext, Program, UnitLength}; +use kcl_lib::{test_server::RequestBody, ExecState, ExecutorContext, Program}; use tokio::{ sync::{mpsc, oneshot}, task::JoinHandle, @@ -69,9 +69,7 @@ fn start_worker(i: u8, engine_addr: Option) -> mpsc::Sender { // Make a work queue for this worker. let (tx, mut rx) = mpsc::channel(1); tokio::task::spawn(async move { - let state = ExecutorContext::new_for_unit_test(UnitLength::Mm, engine_addr) - .await - .unwrap(); + let state = ExecutorContext::new_for_unit_test(engine_addr).await.unwrap(); println!("Worker {i} ready"); while let Some(req) = rx.recv().await { let req: WorkerReq = req; diff --git a/rust/kcl-to-core/Cargo.toml b/rust/kcl-to-core/Cargo.toml index 3c863872a..a7157d158 100644 --- a/rust/kcl-to-core/Cargo.toml +++ b/rust/kcl-to-core/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "kcl-to-core" description = "Utility methods to convert kcl to engine core executable tests" -version = "0.1.55" +version = "0.1.56" edition = "2021" license = "MIT" repository = "https://github.com/KittyCAD/modeling-app" diff --git a/rust/kcl-wasm-lib/Cargo.toml b/rust/kcl-wasm-lib/Cargo.toml index 6a48b1d36..b05826044 100644 --- a/rust/kcl-wasm-lib/Cargo.toml +++ b/rust/kcl-wasm-lib/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "kcl-wasm-lib" -version = "0.1.55" +version = "0.1.56" edition = "2021" repository = "https://github.com/KittyCAD/modeling-app" rust-version = "1.83" diff --git a/rust/kcl-wasm-lib/src/context.rs b/rust/kcl-wasm-lib/src/context.rs index 9fc236254..411807715 100644 --- a/rust/kcl-wasm-lib/src/context.rs +++ b/rust/kcl-wasm-lib/src/context.rs @@ -85,6 +85,21 @@ impl Context { } } + /// Reset the scene and bust the cache. + /// ONLY use this if you absolutely need to reset the scene and bust the cache. + #[wasm_bindgen(js_name = bustCacheAndResetScene)] + pub async fn bust_cache_and_reset_scene(&self, settings: &str, path: Option) -> Result { + console_error_panic_hook::set_once(); + + let ctx = self.create_executor_ctx(settings, path, false)?; + match ctx.bust_cache_and_reset_scene().await { + // The serde-wasm-bindgen does not work here because of weird HashMap issues. + // DO NOT USE serde_wasm_bindgen::to_value it will break the frontend. + Ok(outcome) => JsValue::from_serde(&outcome).map_err(|e| e.to_string()), + Err(err) => Err(serde_json::to_string(&err).map_err(|serde_err| serde_err.to_string())?), + } + } + /// Execute a program in mock mode. #[wasm_bindgen(js_name = executeMock)] pub async fn execute_mock( diff --git a/rust/kcl-wasm-lib/src/lsp.rs b/rust/kcl-wasm-lib/src/lsp.rs index 1a5359c3d..79a5f807e 100644 --- a/rust/kcl-wasm-lib/src/lsp.rs +++ b/rust/kcl-wasm-lib/src/lsp.rs @@ -69,7 +69,6 @@ pub async fn lsp_run_kcl(config: LspServerConfig, token: String, baseurl: String let (service, socket) = LspService::build(|client| { kcl_lib::KclLspBackend::new_wasm(client, executor_ctx, fs, zoo_client, can_send_telemetry).unwrap() }) - .custom_method("kcl/updateUnits", kcl_lib::KclLspBackend::update_units) .custom_method("kcl/updateCanExecute", kcl_lib::KclLspBackend::update_can_execute) .finish(); diff --git a/rust/kcl-wasm-lib/src/wasm.rs b/rust/kcl-wasm-lib/src/wasm.rs index 74cc7f398..e9171e4fa 100644 --- a/rust/kcl-wasm-lib/src/wasm.rs +++ b/rust/kcl-wasm-lib/src/wasm.rs @@ -269,6 +269,17 @@ pub fn change_kcl_settings(code: &str, settings_str: &str) -> Result Result { + console_error_panic_hook::set_once(); + + let program = Program::parse_no_errs(code).map_err(|e| e.to_string())?; + + JsValue::from_serde(&program.is_empty_or_only_settings()).map_err(|e| e.to_string()) +} + /// Get the version of the kcl library. #[wasm_bindgen] pub fn get_kcl_version() -> String { diff --git a/src/App.tsx b/src/App.tsx index eb910ea68..d6a63dd45 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -30,6 +30,7 @@ import { commandBarActor } from 'machines/commandBarMachine' import { useToken } from 'machines/appMachine' import { useSettings } from 'machines/appMachine' import { rustContext } from 'lib/singletons' +import toast from 'react-hot-toast' maybeWriteToDisk() .then(() => {}) .catch(() => {}) @@ -98,6 +99,10 @@ export function App() { } ) + useHotkeyWrapper(['mod + s'], () => { + toast.success('Your work is auto-saved in real-time') + }) + const paneOpacity = [onboardingPaths.CAMERA, onboardingPaths.STREAMING].some( (p) => p === onboardingStatus.current ) diff --git a/src/Toolbar.tsx b/src/Toolbar.tsx index a0736af64..7a0aa1348 100644 --- a/src/Toolbar.tsx +++ b/src/Toolbar.tsx @@ -1,6 +1,6 @@ import { useRef, useMemo, memo, useCallback, useState } from 'react' import { isCursorInSketchCommandRange } from 'lang/util' -import { editorManager, engineCommandManager, kclManager } from 'lib/singletons' +import { editorManager, kclManager } from 'lib/singletons' import { useModelingContext } from 'hooks/useModelingContext' import { useNetworkContext } from 'hooks/useNetworkContext' import { NetworkHealthState } from 'hooks/useNetworkStatus' @@ -45,10 +45,10 @@ export function Toolbar({ ) return false return isCursorInSketchCommandRange( - engineCommandManager.artifactGraph, + kclManager.artifactGraph, context.selectionRanges ) - }, [engineCommandManager.artifactGraph, context.selectionRanges]) + }, [kclManager.artifactGraph, context.selectionRanges]) const toolbarButtonsRef = useRef(null) const { overallState } = useNetworkContext() diff --git a/src/clientSideScene/sceneEntities.ts b/src/clientSideScene/sceneEntities.ts index 521e3ab97..e2181ed94 100644 --- a/src/clientSideScene/sceneEntities.ts +++ b/src/clientSideScene/sceneEntities.ts @@ -3700,7 +3700,7 @@ function computeSelectionFromSourceRangeAndAST( sourceRange: SourceRange, ast: Node ): Selections { - const artifactGraph = engineCommandManager.artifactGraph + const artifactGraph = kclManager.artifactGraph const artifact = getArtifactFromRange(sourceRange, artifactGraph) || undefined const selection: Selections = { graphSelections: [ diff --git a/src/components/AstExplorer.tsx b/src/components/AstExplorer.tsx index 625036621..5d85ab7b4 100644 --- a/src/components/AstExplorer.tsx +++ b/src/components/AstExplorer.tsx @@ -1,5 +1,5 @@ import { useModelingContext } from 'hooks/useModelingContext' -import { editorManager, engineCommandManager, kclManager } from 'lib/singletons' +import { editorManager, kclManager } from 'lib/singletons' import { getNodeFromPath } from 'lang/queryAst' import { getNodePathFromSourceRange } from 'lang/queryAstNodePathUtils' import { useEffect, useRef, useState } from 'react' @@ -135,12 +135,10 @@ function DisplayObj({ const range = topLevelRange(obj?.start || 0, obj.end || 0) const idInfo = codeToIdSelections( [{ codeRef: codeRefFromRange(range, kclManager.ast) }], - engineCommandManager.artifactGraph, - engineCommandManager.artifactIndex + kclManager.artifactGraph, + kclManager.artifactIndex )[0] - const artifact = engineCommandManager.artifactGraph.get( - idInfo?.id || '' - ) + const artifact = kclManager.artifactGraph.get(idInfo?.id || '') if (!artifact) return send({ type: 'Set selection', diff --git a/src/components/CommandBarOverwriteWarning.tsx b/src/components/CommandBarOverwriteWarning.tsx index 9e9dd239f..1d5ac41f2 100644 --- a/src/components/CommandBarOverwriteWarning.tsx +++ b/src/components/CommandBarOverwriteWarning.tsx @@ -1,11 +1,11 @@ interface CommandBarOverwriteWarningProps { - heading?: string - message?: string + heading: string + message: string } export function CommandBarOverwriteWarning({ - heading = 'Overwrite current file and units?', - message = 'This will permanently replace the current code in the editor, and overwrite your current units.', + heading, + message, }: CommandBarOverwriteWarningProps) { return ( <> diff --git a/src/components/DebugArtifactGraph.tsx b/src/components/DebugArtifactGraph.tsx index b09f3485a..5436ab237 100644 --- a/src/components/DebugArtifactGraph.tsx +++ b/src/components/DebugArtifactGraph.tsx @@ -1,13 +1,13 @@ import { useMemo } from 'react' -import { engineCommandManager } from 'lib/singletons' +import { kclManager } from 'lib/singletons' import { expandPlane, PlaneArtifactRich } from 'lang/std/artifactGraph' import { ArtifactGraph } from 'lang/wasm' import { DebugDisplayArray, GenericObj } from './DebugDisplayObj' export function DebugArtifactGraph() { const artifactGraphTree = useMemo(() => { - return computeTree(engineCommandManager.artifactGraph) - }, [engineCommandManager.artifactGraph]) + return computeTree(kclManager.artifactGraph) + }, [kclManager.artifactGraph]) const filterKeys: string[] = ['codeRef', 'pathToNode'] return ( diff --git a/src/components/FileMachineProvider.tsx b/src/components/FileMachineProvider.tsx index 3d73b0ee4..1860d74d1 100644 --- a/src/components/FileMachineProvider.tsx +++ b/src/components/FileMachineProvider.tsx @@ -15,6 +15,7 @@ import { import { fileMachine } from 'machines/fileMachine' import { isDesktop } from 'lib/isDesktop' import { + DEFAULT_DEFAULT_LENGTH_UNIT, DEFAULT_FILE_NAME, DEFAULT_PROJECT_KCL_FILE, FILE_EXT, @@ -29,11 +30,12 @@ import { } from 'lib/getKclSamplesManifest' import { markOnce } from 'lib/performance' import { commandBarActor } from 'machines/commandBarMachine' -import { settingsActor, useSettings } from 'machines/appMachine' +import { useSettings } from 'machines/appMachine' import { createRouteCommands } from 'lib/commandBarConfigs/routeCommandConfig' import { useToken } from 'machines/appMachine' import { createNamedViewsCommand } from 'lib/commandBarConfigs/namedViewsConfig' -import { reportRejection } from 'lib/trap' +import { err, reportRejection } from 'lib/trap' +import { newKclFile } from 'lang/project' type MachineContext = { state: StateFrom @@ -237,7 +239,12 @@ export const FileMachineProvider = ({ createdPath ) } else { - await window.electron.writeFile(createdPath, input.content ?? '') + const codeToWrite = newKclFile( + input.content, + settings.modeling.defaultUnit.current + ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + await window.electron.writeFile(createdPath, codeToWrite) } } @@ -266,7 +273,12 @@ export const FileMachineProvider = ({ }) createdName = name createdPath = path - await window.electron.writeFile(createdPath, input.content ?? '') + const codeToWrite = newKclFile( + input.content, + settings.modeling.defaultUnit.current + ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + await window.electron.writeFile(createdPath, codeToWrite) } return { @@ -357,10 +369,16 @@ export const FileMachineProvider = ({ const hasKclEntries = entries.filter((e: string) => e.endsWith('.kcl')).length !== 0 if (!hasKclEntries) { - await window.electron.writeFile( - window.electron.path.join(project.path, DEFAULT_PROJECT_KCL_FILE), - '' + const codeToWrite = newKclFile( + undefined, + settings.modeling.defaultUnit.current ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + const path = window.electron.path.join( + project.path, + DEFAULT_PROJECT_KCL_FILE + ) + await window.electron.writeFile(path, codeToWrite) // Refresh the route selected above because it's possible we're on // the same path on the navigate, which doesn't cause anything to // refresh, leaving a stale execution state. @@ -401,7 +419,9 @@ export const FileMachineProvider = ({ authToken: token ?? '', projectData, settings: { - defaultUnit: settings.modeling.defaultUnit.current ?? 'mm', + defaultUnit: + settings.modeling.defaultUnit.current ?? + DEFAULT_DEFAULT_LENGTH_UNIT, }, specialPropsForSampleCommand: { onSubmit: async (data) => { @@ -419,18 +439,6 @@ export const FileMachineProvider = ({ }, }) } - - // Either way, we want to overwrite the defaultUnit project setting - // with the sample's setting. - if (data.sampleUnits) { - settingsActor.send({ - type: 'set.modeling.defaultUnit', - data: { - level: 'project', - value: data.sampleUnits, - }, - }) - } }, providedOptions: kclSamples.map((sample) => ({ value: sample.pathFromProjectDirectoryToFirstFile, diff --git a/src/components/ModelingMachineProvider.tsx b/src/components/ModelingMachineProvider.tsx index 9a8e0c93c..e26f67d23 100644 --- a/src/components/ModelingMachineProvider.tsx +++ b/src/components/ModelingMachineProvider.tsx @@ -566,7 +566,7 @@ export const ModelingMachineProvider = ({ // See if the selection is "close enough" to be coerced to the plane later const maybePlane = getPlaneFromArtifact( selectionRanges.graphSelections[0].artifact, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) return !err(maybePlane) } @@ -579,7 +579,7 @@ export const ModelingMachineProvider = ({ return false } return !!isCursorInSketchCommandRange( - engineCommandManager.artifactGraph, + kclManager.artifactGraph, selectionRanges ) }, @@ -841,7 +841,7 @@ export const ModelingMachineProvider = ({ const artifact = selectionRanges.graphSelections[0].artifact const plane = getPlaneFromArtifact( artifact, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(plane)) return Promise.reject(plane) // if the user selected a segment, make sure we enter the right sketch as there can be multiple on a plane @@ -917,14 +917,13 @@ export const ModelingMachineProvider = ({ info?.sketchDetails?.faceId || '' ) - const sketchArtifact = - engineCommandManager.artifactGraph.get(mainPath) + const sketchArtifact = kclManager.artifactGraph.get(mainPath) if (sketchArtifact?.type !== 'path') return Promise.reject(new Error('No sketch artifact')) const sketchPaths = getPathsFromArtifact({ - artifact: engineCommandManager.artifactGraph.get(plane.id), + artifact: kclManager.artifactGraph.get(plane.id), sketchPathToNode: sketchArtifact?.codeRef?.pathToNode, - artifactGraph: engineCommandManager.artifactGraph, + artifactGraph: kclManager.artifactGraph, ast: kclManager.ast, }) if (err(sketchPaths)) return Promise.reject(sketchPaths) @@ -1743,7 +1742,7 @@ export const ModelingMachineProvider = ({ prompt: input.prompt, selections: input.selection, token, - artifactGraph: engineCommandManager.artifactGraph, + artifactGraph: kclManager.artifactGraph, projectName: context.project.name, }) }), diff --git a/src/components/ModelingSidebar/ModelingPanes/FeatureTreePane.tsx b/src/components/ModelingSidebar/ModelingPanes/FeatureTreePane.tsx index 8d51b4401..ed0b90747 100644 --- a/src/components/ModelingSidebar/ModelingPanes/FeatureTreePane.tsx +++ b/src/components/ModelingSidebar/ModelingPanes/FeatureTreePane.tsx @@ -13,7 +13,7 @@ import { getOperationLabel, stdLibMap, } from 'lib/operations' -import { editorManager, engineCommandManager, kclManager } from 'lib/singletons' +import { editorManager, kclManager } from 'lib/singletons' import { ComponentProps, useEffect, useMemo, useRef, useState } from 'react' import { Operation } from '@rust/kcl-lib/bindings/Operation' import { Actor, Prop } from 'xstate' @@ -58,7 +58,7 @@ export const FeatureTreePane = () => { const artifact = context.targetSourceRange ? getArtifactFromRange( context.targetSourceRange, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) : null diff --git a/src/components/ProjectsContextProvider.tsx b/src/components/ProjectsContextProvider.tsx index 176934b67..0c6559f98 100644 --- a/src/components/ProjectsContextProvider.tsx +++ b/src/components/ProjectsContextProvider.tsx @@ -32,6 +32,8 @@ import { } from 'lib/constants' import { codeManager, kclManager } from 'lib/singletons' import { Project } from 'lib/project' +import { newKclFile } from 'lang/project' +import { err } from 'lib/trap' type MachineContext = { state?: StateFrom @@ -120,7 +122,13 @@ const ProjectsContextWeb = ({ children }: { children: React.ReactNode }) => { createFile: fromPromise(async ({ input }) => { // Browser version doesn't navigate, just overwrites the current file clearImportSearchParams() - codeManager.updateCodeStateEditor(input.code || '') + + const codeToWrite = newKclFile( + input.code, + settings.modeling.defaultUnit.current + ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + codeManager.updateCodeStateEditor(codeToWrite) await codeManager.writeToFile() await kclManager.executeCode(true) @@ -388,8 +396,10 @@ const ProjectsContextDesktop = ({ } // Create the project around the file if newProject + let fileLoaded = false if (input.method === 'newProject') { await createNewProjectDirectory(projectName, input.code) + fileLoaded = true message = `Project "${projectName}" created successfully with link contents` } else { message = `File "${fileName}" created successfully` @@ -406,8 +416,16 @@ const ProjectsContextDesktop = ({ }) fileName = name - await window.electron.writeFile(path, input.code || '') + if (!fileLoaded) { + const codeToWrite = newKclFile( + input.code, + settings.modeling.defaultUnit.current + ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + await window.electron.writeFile(path, codeToWrite) + } + // TODO: Return the project's file name if one was created. return { message, fileName, diff --git a/src/components/Stream.tsx b/src/components/Stream.tsx index 2057da33f..f64b45431 100644 --- a/src/components/Stream.tsx +++ b/src/components/Stream.tsx @@ -304,7 +304,7 @@ export const Stream = () => { } const path = getArtifactOfTypes( { key: entity_id, types: ['path', 'solid2d', 'segment', 'helix'] }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(path)) { return path diff --git a/src/components/Toolbar/Intersect.tsx b/src/components/Toolbar/Intersect.tsx index 88728bfee..762fd38cd 100644 --- a/src/components/Toolbar/Intersect.tsx +++ b/src/components/Toolbar/Intersect.tsx @@ -16,7 +16,7 @@ import { TransformInfo } from 'lang/std/stdTypes' import { GetInfoModal, createInfoModal } from '../SetHorVertDistanceModal' import { createVariableDeclaration } from '../../lang/modifyAst' import { removeDoubleNegatives } from '../AvailableVarsHelpers' -import { engineCommandManager, kclManager } from 'lib/singletons' +import { kclManager } from 'lib/singletons' import { err } from 'lib/trap' import { Node } from '@rust/kcl-lib/bindings/Node' @@ -45,7 +45,7 @@ export function intersectInfo({ selectionRanges.graphSelections.length > 1 && isLinesParallelAndConstrained( kclManager.ast, - engineCommandManager.artifactGraph, + kclManager.artifactGraph, kclManager.variables, selectionRanges.graphSelections[0], selectionRanges.graphSelections[1] diff --git a/src/components/Toolbar/SetAbsDistance.tsx b/src/components/Toolbar/SetAbsDistance.tsx index 57ed0609a..4efeb7fff 100644 --- a/src/components/Toolbar/SetAbsDistance.tsx +++ b/src/components/Toolbar/SetAbsDistance.tsx @@ -13,10 +13,7 @@ import { SetAngleLengthModal, createSetAngleLengthModal, } from '../SetAngleLengthModal' -import { - createLocalName, - createVariableDeclaration, -} from '../../lang/modifyAst' +import { createName, createVariableDeclaration } from '../../lang/modifyAst' import { removeDoubleNegatives } from '../AvailableVarsHelpers' import { kclManager } from 'lib/singletons' import { err } from 'lib/trap' @@ -169,7 +166,7 @@ export function applyConstraintAxisAlign({ if (err(info)) return info const transformInfos = info.transforms - let finalValue = createLocalName('ZERO') + let finalValue = createName(['turns'], 'ZERO') return transformAstSketchLines({ ast: structuredClone(kclManager.ast), diff --git a/src/components/Toolbar/setAngleLength.tsx b/src/components/Toolbar/setAngleLength.tsx index 30d72b7f4..ac04f093c 100644 --- a/src/components/Toolbar/setAngleLength.tsx +++ b/src/components/Toolbar/setAngleLength.tsx @@ -16,6 +16,7 @@ import { import { createBinaryExpressionWithUnary, createLocalName, + createName, createVariableDeclaration, } from '../../lang/modifyAst' import { removeDoubleNegatives } from '../AvailableVarsHelpers' @@ -167,14 +168,16 @@ export async function applyConstraintAngleLength({ isReferencingXAxis && angleOrLength === 'setAngle' let forceVal = valueUsedInTransform || 0 - let calcIdentifier = createLocalName('ZERO') + let calcIdentifier = createName(['turns'], 'ZERO') if (isReferencingYAxisAngle) { - calcIdentifier = createLocalName( + calcIdentifier = createName( + ['turns'], forceVal < 0 ? 'THREE_QUARTER_TURN' : 'QUARTER_TURN' ) forceVal = normaliseAngle(forceVal + (forceVal < 0 ? 90 : -90)) } else if (isReferencingXAxisAngle) { - calcIdentifier = createLocalName( + calcIdentifier = createName( + ['turns'], Math.abs(forceVal) > 90 ? 'HALF_TURN' : 'ZERO' ) forceVal = diff --git a/src/components/UnitsMenu.tsx b/src/components/UnitsMenu.tsx index 57b23c11b..6be30d721 100644 --- a/src/components/UnitsMenu.tsx +++ b/src/components/UnitsMenu.tsx @@ -1,6 +1,11 @@ import { Popover } from '@headlessui/react' -import { settingsActor, useSettings } from 'machines/appMachine' -import { changeKclSettings, unitLengthToUnitLen } from 'lang/wasm' +import { + changeKclSettings, + unitAngleToUnitAng, + unitLengthToUnitLen, +} from 'lang/wasm' +import { DEFAULT_DEFAULT_ANGLE_UNIT } from 'lib/constants' +import { DEFAULT_DEFAULT_LENGTH_UNIT } from 'lib/constants' import { baseUnitLabels, baseUnitsUnion } from 'lib/settings/settingsTypes' import { codeManager, kclManager } from 'lib/singletons' import { err, reportRejection } from 'lib/trap' @@ -8,24 +13,10 @@ import { useEffect, useState } from 'react' import toast from 'react-hot-toast' export function UnitsMenu() { - const settings = useSettings() - const [hasPerFileLengthUnit, setHasPerFileLengthUnit] = useState( - Boolean(kclManager.fileSettings.defaultLengthUnit) - ) - const [lengthSetting, setLengthSetting] = useState( - kclManager.fileSettings.defaultLengthUnit || - settings.modeling.defaultUnit.current - ) + const [fileSettings, setFileSettings] = useState(kclManager.fileSettings) useEffect(() => { - setHasPerFileLengthUnit(Boolean(kclManager.fileSettings.defaultLengthUnit)) - setLengthSetting( - kclManager.fileSettings.defaultLengthUnit || - settings.modeling.defaultUnit.current - ) - }, [ - kclManager.fileSettings.defaultLengthUnit, - settings.modeling.defaultUnit.current, - ]) + setFileSettings(kclManager.fileSettings) + }, [kclManager.fileSettings]) return ( @@ -41,7 +32,7 @@ export function UnitsMenu() {
Current units are:  - {lengthSetting} + {fileSettings.defaultLengthUnit ?? DEFAULT_DEFAULT_LENGTH_UNIT} { - if (hasPerFileLengthUnit) { - const newCode = changeKclSettings(codeManager.code, { - defaultLengthUnits: unitLengthToUnitLen(unit), - defaultAngleUnits: { type: 'Degrees' }, - }) - if (err(newCode)) { - toast.error( - `Failed to set per-file units: ${newCode.message}` - ) - } else { - codeManager.updateCodeStateEditor(newCode) - Promise.all([ - codeManager.writeToFile(), - kclManager.executeCode(), - ]) - .then(() => { - toast.success(`Updated per-file units to ${unit}`) - }) - .catch(reportRejection) - } + const newCode = changeKclSettings(codeManager.code, { + defaultLengthUnits: unitLengthToUnitLen(unit), + defaultAngleUnits: unitAngleToUnitAng( + fileSettings.defaultAngleUnit ?? + DEFAULT_DEFAULT_ANGLE_UNIT + ), + }) + if (err(newCode)) { + toast.error( + `Failed to set per-file units: ${newCode.message}` + ) } else { - settingsActor.send({ - type: 'set.modeling.defaultUnit', - data: { - level: 'project', - value: unit, - }, - }) + codeManager.updateCodeStateEditor(newCode) + Promise.all([ + codeManager.writeToFile(), + kclManager.executeCode(), + ]) + .then(() => { + toast.success(`Updated per-file units to ${unit}`) + }) + .catch(reportRejection) } close() }} > {baseUnitLabels[unit]} - {unit === lengthSetting && ( + {unit === + (fileSettings.defaultLengthUnit ?? + DEFAULT_DEFAULT_LENGTH_UNIT) && ( current )} diff --git a/src/editor/manager.ts b/src/editor/manager.ts index b7cfeb158..8b97d97cf 100644 --- a/src/editor/manager.ts +++ b/src/editor/manager.ts @@ -374,7 +374,7 @@ export default class EditorManager { selectionRanges: this._selectionRanges, isShiftDown: this._isShiftDown, ast: kclManager.ast, - artifactGraph: engineCommandManager.artifactGraph, + artifactGraph: kclManager.artifactGraph, }) if (!eventInfo) { diff --git a/src/hooks/useEngineConnectionSubscriptions.ts b/src/hooks/useEngineConnectionSubscriptions.ts index 196940a9b..ff7c94108 100644 --- a/src/hooks/useEngineConnectionSubscriptions.ts +++ b/src/hooks/useEngineConnectionSubscriptions.ts @@ -39,7 +39,7 @@ export function useEngineConnectionSubscriptions() { if (data?.entity_id) { const codeRefs = getCodeRefsByArtifactId( data.entity_id, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (codeRefs) { editorManager.setHighlightRange(codeRefs.map(({ range }) => range)) @@ -140,8 +140,7 @@ export function useEngineConnectionSubscriptions() { }) return } - const artifact = - engineCommandManager.artifactGraph.get(planeOrFaceId) + const artifact = kclManager.artifactGraph.get(planeOrFaceId) if (artifact?.type === 'plane') { const planeInfo = await getFaceDetails(planeOrFaceId) @@ -179,7 +178,7 @@ export function useEngineConnectionSubscriptions() { const faceId = planeOrFaceId const extrusion = getSweepFromSuspectedSweepSurface( faceId, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if ( @@ -193,9 +192,9 @@ export function useEngineConnectionSubscriptions() { const codeRef = artifact.type === 'cap' - ? getCapCodeRef(artifact, engineCommandManager.artifactGraph) + ? getCapCodeRef(artifact, kclManager.artifactGraph) : artifact.type === 'wall' - ? getWallCodeRef(artifact, engineCommandManager.artifactGraph) + ? getWallCodeRef(artifact, kclManager.artifactGraph) : artifact.codeRef const faceInfo = await getFaceDetails(faceId) @@ -221,7 +220,7 @@ export function useEngineConnectionSubscriptions() { key: artifact.consumedEdgeId, types: ['segment', 'sweepEdge'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(consumedArtifact)) return null if (consumedArtifact.type === 'segment') { @@ -232,7 +231,7 @@ export function useEngineConnectionSubscriptions() { } else { const segment = getArtifactOfTypes( { key: consumedArtifact.segId, types: ['segment'] }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(segment)) return null chamferInfo = { diff --git a/src/lang/KclSingleton.ts b/src/lang/KclSingleton.ts index 45def4d56..10d518866 100644 --- a/src/lang/KclSingleton.ts +++ b/src/lang/KclSingleton.ts @@ -5,10 +5,12 @@ import { compilationErrorsToDiagnostics, kclErrorsToDiagnostics, } from './errors' -import { uuidv4 } from 'lib/utils' +import { uuidv4, isOverlap, deferExecution } from 'lib/utils' import { EngineCommandManager } from './std/engineConnection' import { err, reportRejection } from 'lib/trap' import { EXECUTE_AST_INTERRUPT_ERROR_MESSAGE } from 'lib/constants' +import { buildArtifactIndex } from 'lib/artifactIndex' +import { ArtifactIndex } from 'lib/artifactIndex' import { emptyExecState, @@ -24,6 +26,7 @@ import { SourceRange, topLevelRange, VariableMap, + ArtifactGraph, } from 'lang/wasm' import { getNodeFromPath, getSettingsAnnotation } from './queryAst' import { @@ -53,6 +56,14 @@ interface ExecuteArgs { } export class KclManager { + /** + * The artifactGraph is a client-side representation of the commands that have been sent + * see: src/lang/std/artifactGraph-README.md for a full explanation. + */ + artifactGraph: ArtifactGraph = new Map() + artifactIndex: ArtifactIndex = [] + defaultPlanesShown: boolean = false + private _ast: Node = { body: [], shebang: null, @@ -289,6 +300,47 @@ export class KclManager { } } + private async updateArtifactGraph( + execStateArtifactGraph: ExecState['artifactGraph'] + ) { + this.artifactGraph = execStateArtifactGraph + this.artifactIndex = buildArtifactIndex(execStateArtifactGraph) + if (this.artifactGraph.size) { + // TODO: we wanna remove this logic from xstate, it is racey + // This defer is bullshit but playwright wants it + // It was like this in engineConnection.ts already + deferExecution((a?: null) => { + this.engineCommandManager.modelingSend({ + type: 'Artifact graph emptied', + }) + }, 200)(null) + } else { + deferExecution((a?: null) => { + this.engineCommandManager.modelingSend({ + type: 'Artifact graph populated', + }) + }, 200)(null) + } + } + + // Some "objects" have the same source range, such as sketch_mode_start and start_path. + // So when passing a range, we need to also specify the command type + private mapRangeToObjectId( + range: SourceRange, + commandTypeToTarget: string + ): string | undefined { + for (const [artifactId, artifact] of this.artifactGraph) { + if ( + 'codeRef' in artifact && + artifact.codeRef && + isOverlap(range, artifact.codeRef.range) + ) { + if (commandTypeToTarget === artifact.type) return artifactId + } + } + return undefined + } + async safeParse(code: string): Promise | null> { const result = parse(code) this.diagnostics = [] @@ -330,6 +382,7 @@ export class KclManager { } // eslint-disable-next-line @typescript-eslint/no-unused-vars } catch (e) { + console.error(e) this.wasmInitFailed = true } } @@ -370,12 +423,12 @@ export class KclManager { // Do not send send scene commands if the program was interrupted, go to clean up if (!isInterrupted) { this.addDiagnostics(await lintAst({ ast: ast })) - setSelectionFilterToDefault(this.engineCommandManager) + await setSelectionFilterToDefault(this.engineCommandManager) if (args.zoomToFit) { let zoomObjectId: string | undefined = '' if (args.zoomOnRangeAndType) { - zoomObjectId = this.engineCommandManager?.mapRangeToObjectId( + zoomObjectId = this.mapRangeToObjectId( args.zoomOnRangeAndType.range, args.zoomOnRangeAndType.type ) @@ -429,7 +482,7 @@ export class KclManager { } this.ast = { ...ast } // updateArtifactGraph relies on updated executeState/variables - this.engineCommandManager.updateArtifactGraph(execState.artifactGraph) + await this.updateArtifactGraph(execState.artifactGraph) this._executeCallback() if (!isInterrupted) { sceneInfra.modelingSend({ type: 'code edit during sketch' }) diff --git a/src/lang/modifyAst.ts b/src/lang/modifyAst.ts index 550bc4794..f7423c95a 100644 --- a/src/lang/modifyAst.ts +++ b/src/lang/modifyAst.ts @@ -1087,6 +1087,22 @@ export function createLocalName(name: string): Node { } } +export function createName(path: [string], name: string): Node { + return { + type: 'Name', + start: 0, + end: 0, + moduleId: 0, + outerAttrs: [], + preComments: [], + commentStart: 0, + + abs_path: false, + path: path.map(createIdentifier), + name: createIdentifier(name), + } +} + export function createPipeSubstitution(): Node { return { type: 'PipeSubstitution', diff --git a/src/lang/modifyAst/addEdgeTreatment.test.ts b/src/lang/modifyAst/addEdgeTreatment.test.ts index a4f387c6c..aa91f9389 100644 --- a/src/lang/modifyAst/addEdgeTreatment.test.ts +++ b/src/lang/modifyAst/addEdgeTreatment.test.ts @@ -139,7 +139,7 @@ const runGetPathToExtrudeForSegmentSelectionTest = async ( // executeAst and artifactGraph await kclManager.executeAst({ ast }) - const artifactGraph = engineCommandManager.artifactGraph + const artifactGraph = kclManager.artifactGraph // find artifact const maybeArtifact = [...artifactGraph].find(([, artifact]) => { @@ -348,7 +348,7 @@ const runModifyAstCloneWithEdgeTreatmentAndTag = async ( // executeAst await kclManager.executeAst({ ast }) - const artifactGraph = engineCommandManager.artifactGraph + const artifactGraph = kclManager.artifactGraph const selection: Selections = { graphSelections: segmentRanges.map((segmentRange) => { @@ -390,7 +390,7 @@ const runDeleteEdgeTreatmentTest = async ( // update artifact graph await kclManager.executeAst({ ast }) - const artifactGraph = engineCommandManager.artifactGraph + const artifactGraph = kclManager.artifactGraph // define snippet range const edgeTreatmentRange = topLevelRange( diff --git a/src/lang/modifyAst/addEdgeTreatment.ts b/src/lang/modifyAst/addEdgeTreatment.ts index 2b4e7de5c..5ad37acfe 100644 --- a/src/lang/modifyAst/addEdgeTreatment.ts +++ b/src/lang/modifyAst/addEdgeTreatment.ts @@ -118,7 +118,7 @@ export function modifyAstWithEdgeTreatmentAndTag( const astResult = insertParametersIntoAst(clonedAst, parameters) if (err(astResult)) return astResult - const artifactGraph = dependencies.engineCommandManager.artifactGraph + const artifactGraph = dependencies.kclManager.artifactGraph // Step 1: modify ast with tags and group them by extrude nodes (bodies) const extrudeToTagsMap: Map< diff --git a/src/lang/modifyAst/boolean.ts b/src/lang/modifyAst/boolean.ts index 28b547147..322907cc2 100644 --- a/src/lang/modifyAst/boolean.ts +++ b/src/lang/modifyAst/boolean.ts @@ -42,11 +42,11 @@ export async function applySubtractFromTargetOperatorSelections( } const orderedChildrenTarget = findAllChildrenAndOrderByPlaceInCode( target.artifact, - dependencies.engineCommandManager.artifactGraph + dependencies.kclManager.artifactGraph ) const orderedChildrenTool = findAllChildrenAndOrderByPlaceInCode( tool.artifact, - dependencies.engineCommandManager.artifactGraph + dependencies.kclManager.artifactGraph ) const lastVarTarget = getLastVariable(orderedChildrenTarget, ast) @@ -89,7 +89,7 @@ export async function applyUnionFromTargetOperatorSelections( const orderedChildrenEach = artifacts.map((artifact) => findAllChildrenAndOrderByPlaceInCode( artifact, - dependencies.engineCommandManager.artifactGraph + dependencies.kclManager.artifactGraph ) ) @@ -136,7 +136,7 @@ export async function applyIntersectFromTargetOperatorSelections( const orderedChildrenEach = artifacts.map((artifact) => findAllChildrenAndOrderByPlaceInCode( artifact, - dependencies.engineCommandManager.artifactGraph + dependencies.kclManager.artifactGraph ) ) diff --git a/src/lang/modifyAst/deleteSelection.ts b/src/lang/modifyAst/deleteSelection.ts index 5d09ec5db..95b46921b 100644 --- a/src/lang/modifyAst/deleteSelection.ts +++ b/src/lang/modifyAst/deleteSelection.ts @@ -4,7 +4,6 @@ import { deleteFromSelection } from 'lang/modifyAst' import { codeManager, editorManager, - engineCommandManager, kclManager, rustContext, } from 'lib/singletons' @@ -25,7 +24,7 @@ export async function deleteSelectionPromise( ast, selection, kclManager.variables, - engineCommandManager.artifactGraph, + kclManager.artifactGraph, getFaceDetails ) if (err(modifiedAst)) { diff --git a/src/lang/project.ts b/src/lang/project.ts new file mode 100644 index 000000000..17141a034 --- /dev/null +++ b/src/lang/project.ts @@ -0,0 +1,33 @@ +import { UnitLength } from '@rust/kcl-lib/bindings/ModelingCmd' +import { + changeKclSettings, + unitAngleToUnitAng, + unitLengthToUnitLen, +} from './wasm' +import { DEFAULT_DEFAULT_ANGLE_UNIT } from 'lib/constants' +import { DEFAULT_DEFAULT_LENGTH_UNIT } from 'lib/constants' + +/** + * Create a new KCL file with the given initial content and default length unit. + * @returns KCL string + */ +export function newKclFile( + initialContent: string | undefined, + defaultLengthUnit: UnitLength +): string | Error { + // If we're given initial content, we're loading a file that should already + // have units in it. Don't modify it. + if (initialContent !== undefined) { + return initialContent + } + // If the default length unit is the same as the default default length unit, + // there's no need to add the attribute. + if (defaultLengthUnit === DEFAULT_DEFAULT_LENGTH_UNIT) { + return '' + } + + return changeKclSettings('', { + defaultLengthUnits: unitLengthToUnitLen(defaultLengthUnit), + defaultAngleUnits: unitAngleToUnitAng(DEFAULT_DEFAULT_ANGLE_UNIT), + }) +} diff --git a/src/lang/std/engineConnection.ts b/src/lang/std/engineConnection.ts index a27d7ab06..e68cd924e 100644 --- a/src/lang/std/engineConnection.ts +++ b/src/lang/std/engineConnection.ts @@ -1,13 +1,8 @@ -import { - ArtifactGraph, - defaultSourceRange, - ExecState, - SourceRange, -} from 'lang/wasm' +import { defaultSourceRange, SourceRange } from 'lang/wasm' import { VITE_KC_API_WS_MODELING_URL, VITE_KC_DEV_TOKEN } from 'env' import { Models } from '@kittycad/lib' -import { deferExecution, isOverlap, uuidv4 } from 'lib/utils' -import { BSON, Binary as BSONBinary } from 'bson' +import { uuidv4, binaryToUuid } from 'lib/utils' +import { BSON } from 'bson' import { Themes, getThemeColorForEngine, @@ -22,8 +17,6 @@ import { KclManager } from 'lang/KclSingleton' import { reportRejection } from 'lib/trap' import { markOnce } from 'lib/performance' import { MachineManager } from 'components/MachineManagerProvider' -import { buildArtifactIndex } from 'lib/artifactIndex' -import { ArtifactIndex } from 'lib/artifactIndex' // TODO(paultag): This ought to be tweakable. const pingIntervalMs = 5_000 @@ -1047,11 +1040,9 @@ class EngineConnection extends EventTarget { }) .join('\n') if (message.request_id) { - const artifactThatFailed = - this.engineCommandManager.artifactGraph.get(message.request_id) console.error( `Error in response to request ${message.request_id}:\n${errorsString} - failed cmd type was ${artifactThatFailed?.type}` + failed` ) } else { console.error(`Error from server:\n${errorsString}`) @@ -1355,8 +1346,7 @@ export enum EngineCommandManagerEvents { * * As commands are send their state is tracked in {@link pendingCommands} and clear as soon as we receive a response. * - * Also all commands that are sent are kept track of in WASM artifactCommands and their responses are kept in {@link responseMap} - * Both of these data structures are used to process the {@link artifactGraph}. + * Also all commands that are sent are kept track of in WASM and their responses are kept in {@link responseMap} */ interface PendingMessage { @@ -1369,12 +1359,6 @@ interface PendingMessage { isSceneCommand: boolean } export class EngineCommandManager extends EventTarget { - /** - * The artifactGraph is a client-side representation of the commands that have been sent - * see: src/lang/std/artifactGraph-README.md for a full explanation. - */ - artifactGraph: ArtifactGraph = new Map() - artifactIndex: ArtifactIndex = [] /** * The pendingCommands object is a map of the commands that have been sent to the engine that are still waiting on a reply */ @@ -1382,7 +1366,7 @@ export class EngineCommandManager extends EventTarget { [commandId: string]: PendingMessage } = {} /** - * A map of the responses to the WASM artifactCommands, when processing the commands into the artifactGraph, this response map allow + * A map of the responses to the WASM, this response map allow * us to look up the response by command id */ responseMap: ResponseMap = {} @@ -1878,7 +1862,7 @@ export class EngineCommandManager extends EventTarget { registerCommandLogCallback(callback: (command: CommandLog[]) => void) { this._commandLogCallBack = callback } - sendSceneCommand( + async sendSceneCommand( command: EngineCommand, forceWebsocket = false ): Promise { @@ -2032,13 +2016,6 @@ export class EngineCommandManager extends EventTarget { return promise } - deferredArtifactPopulated = deferExecution((a?: null) => { - this.modelingSend({ type: 'Artifact graph populated' }) - }, 200) - deferredArtifactEmptied = deferExecution((a?: null) => { - this.modelingSend({ type: 'Artifact graph emptied' }) - }, 200) - /** * When an execution takes place we want to wait until we've got replies for all of the commands * When this is done when we build the artifact map synchronously. @@ -2048,16 +2025,6 @@ export class EngineCommandManager extends EventTarget { Object.values(this.pendingCommands).map((a) => a.promise) ) } - updateArtifactGraph(execStateArtifactGraph: ExecState['artifactGraph']) { - this.artifactGraph = execStateArtifactGraph - this.artifactIndex = buildArtifactIndex(execStateArtifactGraph) - // TODO check if these still need to be deferred once e2e tests are working again. - if (this.artifactGraph.size) { - this.deferredArtifactEmptied(null) - } else { - this.deferredArtifactPopulated(null) - } - } /** * Reject all of the modeling pendingCommands created from sendModelingCommandFromWasm @@ -2121,24 +2088,6 @@ export class EngineCommandManager extends EventTarget { }, }).catch(reportRejection) } - - // Some "objects" have the same source range, such as sketch_mode_start and start_path. - // So when passing a range, we need to also specify the command type - mapRangeToObjectId( - range: SourceRange, - commandTypeToTarget: string - ): string | undefined { - for (const [artifactId, artifact] of this.artifactGraph) { - if ( - 'codeRef' in artifact && - artifact.codeRef && - isOverlap(range, artifact.codeRef.range) - ) { - if (commandTypeToTarget === artifact.type) return artifactId - } - } - return undefined - } } function promiseFactory() { @@ -2150,65 +2099,3 @@ function promiseFactory() { }) return { promise, resolve, reject } } - -/** - * Converts a binary buffer to a UUID string. - * - * @param buffer - The binary buffer containing the UUID bytes. - * @returns A string representation of the UUID in the format 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'. - */ -function binaryToUuid( - binaryData: Buffer | Uint8Array | BSONBinary | string -): string { - if (typeof binaryData === 'string') { - return binaryData - } - - let buffer: Uint8Array - - // Handle MongoDB BSON Binary object - if ( - binaryData && - '_bsontype' in binaryData && - binaryData._bsontype === 'Binary' - ) { - // Extract the buffer from the BSON Binary object - buffer = binaryData.buffer - } - // Handle case where buffer property exists (some MongoDB drivers structure) - else if (binaryData && binaryData.buffer instanceof Uint8Array) { - buffer = binaryData.buffer - } - // Handle direct Buffer or Uint8Array - else if (binaryData instanceof Uint8Array || Buffer.isBuffer(binaryData)) { - buffer = binaryData - } else { - console.error( - 'Invalid input type: expected MongoDB BSON Binary, Buffer, or Uint8Array' - ) - return '' - } - - // Ensure we have exactly 16 bytes (128 bits) for a UUID - if (buffer.length !== 16) { - // For debugging - console.log('Buffer length:', buffer.length) - console.log('Buffer content:', Array.from(buffer)) - console.error('UUID must be exactly 16 bytes') - return '' - } - - // Convert each byte to a hex string and pad with zeros if needed - const hexValues = Array.from(buffer).map((byte) => - byte.toString(16).padStart(2, '0') - ) - - // Format into UUID structure (8-4-4-4-12 characters) - return [ - hexValues.slice(0, 4).join(''), - hexValues.slice(4, 6).join(''), - hexValues.slice(6, 8).join(''), - hexValues.slice(8, 10).join(''), - hexValues.slice(10, 16).join(''), - ].join('-') -} diff --git a/src/lang/std/sketchcombos.ts b/src/lang/std/sketchcombos.ts index ff750387b..a5ba6029a 100644 --- a/src/lang/std/sketchcombos.ts +++ b/src/lang/std/sketchcombos.ts @@ -35,6 +35,7 @@ import { createLabeledArg, createLiteral, createLocalName, + createName, createObjectExpression, createPipeSubstitution, createUnaryExpression, @@ -612,7 +613,7 @@ const setAngledIntersectLineForLines: CreateStdLibSketchCallExpr = ({ 270: 'THREE_QUARTER_TURN', } const angleVal = [0, 90, 180, 270].includes(angle) - ? createLocalName(varNamMap[angle]) + ? createName(['turns'], varNamMap[angle]) : createLiteral(angle) return intersectCallWrapper({ fnName: 'angledLineThatIntersects', @@ -665,7 +666,7 @@ const setAngleBetweenCreateNode = firstHalfValue = createBinaryExpression([ firstHalfValue, '+', - createLocalName('HALF_TURN'), + createName(['turns'], 'HALF_TURN'), ]) valueUsedInTransform = normaliseAngle(valueUsedInTransform - 180) } diff --git a/src/lang/wasm.ts b/src/lang/wasm.ts index 3cfe0950f..df3d6c235 100644 --- a/src/lang/wasm.ts +++ b/src/lang/wasm.ts @@ -18,6 +18,7 @@ import { serialize_project_configuration, serialize_configuration, reloadModule, + is_kcl_empty_or_only_settings, } from 'lib/wasm_lib_wrapper' import { KCLError } from './errors' @@ -55,6 +56,10 @@ import { UnitAngle as UnitAng } from '@rust/kcl-lib/bindings/UnitAngle' import { ModulePath } from '@rust/kcl-lib/bindings/ModulePath' import { DefaultPlanes } from '@rust/kcl-lib/bindings/DefaultPlanes' import { isArray } from 'lib/utils' +import { + DEFAULT_DEFAULT_ANGLE_UNIT, + DEFAULT_DEFAULT_LENGTH_UNIT, +} from 'lib/constants' export type { Artifact } from '@rust/kcl-lib/bindings/Artifact' export type { ArtifactCommand } from '@rust/kcl-lib/bindings/Artifact' @@ -607,7 +612,27 @@ export function changeKclSettings( } /** - * Convert a `UnitLength_type` to a `UnitLen` + * Returns true if the given KCL is empty or only contains settings that would + * be auto-generated. + */ +export function isKclEmptyOrOnlySettings(kcl: string): boolean { + if (kcl === '') { + // Fast path. + return true + } + + try { + return is_kcl_empty_or_only_settings(kcl) + } catch (e) { + console.debug('Caught error checking if KCL is empty', e) + // If there's a parse error, it can't be empty or auto-generated. + return false + } +} + +/** + * Convert a `UnitLength` (used in settings and modeling commands) to a + * `UnitLen` (used in execution). */ export function unitLengthToUnitLen(input: UnitLength): UnitLen { switch (input) { @@ -627,7 +652,8 @@ export function unitLengthToUnitLen(input: UnitLength): UnitLen { } /** - * Convert `UnitLen` to `UnitLength_type`. + * Convert `UnitLen` (used in execution) to `UnitLength` (used in settings + * and modeling commands). */ export function unitLenToUnitLength(input: UnitLen): UnitLength { switch (input.type) { @@ -642,19 +668,33 @@ export function unitLenToUnitLength(input: UnitLen): UnitLength { case 'Inches': return 'in' default: - return 'mm' + return DEFAULT_DEFAULT_LENGTH_UNIT } } /** - * Convert `UnitAngle` to `UnitAngle_type`. + * Convert a `UnitAngle` (used in modeling commands) to a `UnitAng` (used in + * execution). + */ +export function unitAngleToUnitAng(input: UnitAngle): UnitAng { + switch (input) { + case 'radians': + return { type: 'Radians' } + default: + return { type: 'Degrees' } + } +} + +/** + * Convert `UnitAng` (used in execution) to `UnitAngle` (used in modeling + * commands). */ export function unitAngToUnitAngle(input: UnitAng): UnitAngle { switch (input.type) { case 'Radians': return 'radians' default: - return 'degrees' + return DEFAULT_DEFAULT_ANGLE_UNIT } } diff --git a/src/lib/commandBarConfigs/validators.ts b/src/lib/commandBarConfigs/validators.ts index 2a7192717..b199ced47 100644 --- a/src/lib/commandBarConfigs/validators.ts +++ b/src/lib/commandBarConfigs/validators.ts @@ -1,5 +1,5 @@ import { Models } from '@kittycad/lib' -import { engineCommandManager } from 'lib/singletons' +import { engineCommandManager, kclManager } from 'lib/singletons' import { uuidv4 } from 'lib/utils' import { CommandBarContext } from 'machines/commandBarMachine' import { Selections } from 'lib/selections' @@ -188,7 +188,7 @@ export const shellValidator = async ({ // So we're listing out the sweeps as if they were solids and taking the first one, just like in Rust for Shell: // https://github.com/KittyCAD/modeling-app/blob/e61fff115b9fa94aaace6307b1842cc15d41655e/src/wasm-lib/kcl/src/std/shell.rs#L237-L238 // TODO: This is one cheap way to make sketch-on-face supported now but will likely fail multiple solids - const object_id = engineCommandManager.artifactGraph + const object_id = kclManager.artifactGraph .values() .find((v) => v.type === 'sweep')?.pathId diff --git a/src/lib/constants.ts b/src/lib/constants.ts index 2007ba35b..3731990b0 100644 --- a/src/lib/constants.ts +++ b/src/lib/constants.ts @@ -1,4 +1,5 @@ import { Models } from '@kittycad/lib/dist/types/src' +import { UnitAngle, UnitLength } from '@rust/kcl-lib/bindings/ModelingCmd' export const APP_NAME = 'Modeling App' /** Search string in new project names to increment as an index */ @@ -168,6 +169,18 @@ export const ZOO_STUDIO_PROTOCOL = 'zoo-studio' */ export const ASK_TO_OPEN_QUERY_PARAM = 'ask-open-desktop' +/** + * When no annotation is in the KCL file to specify the defaults, we use these + * default units. + */ +export const DEFAULT_DEFAULT_ANGLE_UNIT: UnitAngle = 'degrees' + +/** + * When no annotation is in the KCL file to specify the defaults, we use these + * default units. + */ +export const DEFAULT_DEFAULT_LENGTH_UNIT: UnitLength = 'mm' + /** Real execution. */ export const EXECUTION_TYPE_REAL = 'real' /** Mock execution. */ diff --git a/src/lib/coredump.ts b/src/lib/coredump.ts index 9d05c5147..326cd4871 100644 --- a/src/lib/coredump.ts +++ b/src/lib/coredump.ts @@ -200,17 +200,6 @@ export class CoreDumpManager { // engine_command_manager debugLog('CoreDump: engineCommandManager', this.engineCommandManager) - // artifact map - this.engineCommandManager.artifactGraph - if (this.engineCommandManager?.artifactGraph) { - debugLog( - 'CoreDump: Engine Command Manager artifact map', - this.engineCommandManager.artifactGraph - ) - clientState.engine_command_manager.artifact_map = structuredClone( - this.engineCommandManager.artifactGraph - ) - } - // command logs - this.engineCommandManager.commandLogs if (this.engineCommandManager?.commandLogs) { debugLog( @@ -274,6 +263,21 @@ export class CoreDumpManager { clientState.kcl_manager.ast = structuredClone(kclManager.ast) } + // artifact map - this.kclManager.artifactGraph + debugLog( + 'CoreDump: KCL Manager artifact map', + kclManager?.artifactGraph + ) + if (kclManager.artifactGraph) { + debugLog( + 'CoreDump: Engine Command Manager artifact map', + kclManager.artifactGraph + ) + clientState.engine_command_manager.artifact_map = structuredClone( + kclManager.artifactGraph + ) + } + // KCL Errors debugLog('CoreDump: KCL Errors', kclManager?.kclErrors) if (kclManager?.kclErrors) { diff --git a/src/lib/desktop.ts b/src/lib/desktop.ts index f154b9308..0b591d117 100644 --- a/src/lib/desktop.ts +++ b/src/lib/desktop.ts @@ -9,6 +9,7 @@ import { parseProjectSettings, } from 'lang/wasm' import { + DEFAULT_DEFAULT_LENGTH_UNIT, PROJECT_ENTRYPOINT, PROJECT_FOLDER, PROJECT_IMAGE_NAME, @@ -21,6 +22,7 @@ import { import { DeepPartial } from './types' import { ProjectConfiguration } from '@rust/kcl-lib/bindings/ProjectConfiguration' import { Configuration } from '@rust/kcl-lib/bindings/Configuration' +import { newKclFile } from 'lang/project' export async function renameProjectDirectory( projectPath: string, @@ -113,7 +115,15 @@ export async function createNewProjectDirectory( } const projectFile = window.electron.path.join(projectDir, PROJECT_ENTRYPOINT) - await window.electron.writeFile(projectFile, initialCode ?? '') + // When initialCode is present, we're loading existing code. If it's not + // present, we're creating a new project, and we want to incorporate the + // user's settings. + const codeToWrite = newKclFile( + initialCode, + configuration?.settings?.modeling?.base_unit ?? DEFAULT_DEFAULT_LENGTH_UNIT + ) + if (err(codeToWrite)) return Promise.reject(codeToWrite) + await window.electron.writeFile(projectFile, codeToWrite) const metadata = await window.electron.stat(projectFile) return { diff --git a/src/lib/kclCommands.ts b/src/lib/kclCommands.ts index f8c478627..923c24202 100644 --- a/src/lib/kclCommands.ts +++ b/src/lib/kclCommands.ts @@ -2,11 +2,22 @@ import { CommandBarOverwriteWarning } from 'components/CommandBarOverwriteWarnin import { Command, CommandArgumentOption } from './commandTypes' import { codeManager, kclManager } from './singletons' import { isDesktop } from './isDesktop' -import { FILE_EXT } from './constants' +import { + DEFAULT_DEFAULT_ANGLE_UNIT, + DEFAULT_DEFAULT_LENGTH_UNIT, + FILE_EXT, +} from './constants' import { UnitLength_type } from '@kittycad/lib/dist/types/src/models' -import { reportRejection } from './trap' +import { err, reportRejection } from './trap' import { IndexLoaderData } from './types' import { copyFileShareLink } from './links' +import { baseUnitsUnion } from './settings/settingsTypes' +import toast from 'react-hot-toast' +import { + changeKclSettings, + unitLengthToUnitLen, + unitAngleToUnitAng, +} from 'lang/wasm' interface OnSubmitProps { sampleName: string @@ -31,6 +42,59 @@ interface KclCommandConfig { export function kclCommands(commandProps: KclCommandConfig): Command[] { return [ + { + name: 'set-file-units', + displayName: 'Set file units', + description: + 'Set the length unit for all dimensions not given explicit units in the current file.', + needsReview: false, + groupId: 'code', + icon: 'code', + args: { + unit: { + required: true, + inputType: 'options', + defaultValue: + kclManager.fileSettings.defaultLengthUnit || + DEFAULT_DEFAULT_LENGTH_UNIT, + options: () => + Object.values(baseUnitsUnion).map((v) => { + return { + name: v, + value: v, + isCurrent: kclManager.fileSettings.defaultLengthUnit + ? v === kclManager.fileSettings.defaultLengthUnit + : v === DEFAULT_DEFAULT_LENGTH_UNIT, + } + }), + }, + }, + onSubmit: (data) => { + if (typeof data === 'object' && 'unit' in data) { + const newCode = changeKclSettings(codeManager.code, { + defaultLengthUnits: unitLengthToUnitLen(data.unit), + defaultAngleUnits: unitAngleToUnitAng( + kclManager.fileSettings.defaultAngleUnit ?? + DEFAULT_DEFAULT_ANGLE_UNIT + ), + }) + if (err(newCode)) { + toast.error(`Failed to set per-file units: ${newCode.message}`) + } else { + codeManager.updateCodeStateEditor(newCode) + Promise.all([codeManager.writeToFile(), kclManager.executeCode()]) + .then(() => { + toast.success(`Updated per-file units to ${data.unit}`) + }) + .catch(reportRejection) + } + } else { + toast.error( + 'Failed to set per-file units: no value provided to submit function. This is a bug.' + ) + } + }, + }, { name: 'format-code', displayName: 'Format Code', @@ -49,12 +113,18 @@ export function kclCommands(commandProps: KclCommandConfig): Command[] { needsReview: true, icon: 'code', reviewMessage: ({ argumentsToSubmit }) => - argumentsToSubmit.method === 'newFile' - ? CommandBarOverwriteWarning({ - heading: 'Create a new file, overwrite project units?', - message: `This will add the sample as a new file to your project, and replace your current project units with the sample's units.`, - }) - : CommandBarOverwriteWarning({}), + CommandBarOverwriteWarning({ + heading: + 'method' in argumentsToSubmit && + argumentsToSubmit.method === 'newFile' + ? 'Create a new file from sample?' + : 'Overwrite current file with sample?', + message: + 'method' in argumentsToSubmit && + argumentsToSubmit.method === 'newFile' + ? 'This will create a new file in the current project and open it.' + : 'This will erase your current file and load the sample part.', + }), groupId: 'code', onSubmit(data) { if (!data?.sample) { diff --git a/src/lib/operations.ts b/src/lib/operations.ts index a348fc167..f41359ea7 100644 --- a/src/lib/operations.ts +++ b/src/lib/operations.ts @@ -8,7 +8,7 @@ import { getWallCodeRef, } from 'lang/std/artifactGraph' import { Operation } from '@rust/kcl-lib/bindings/Operation' -import { codeManager, engineCommandManager, kclManager } from './singletons' +import { codeManager, kclManager, rustContext } from './singletons' import { err } from './trap' import { getNodePathFromSourceRange } from 'lang/queryAstNodePathUtils' import { sourceRangeFromRust } from 'lang/wasm' @@ -20,7 +20,6 @@ import { } from './commandBarConfigs/modelingCommandConfig' import { isDefaultPlaneStr } from './planes' import { Selection, Selections } from './selections' -import { rustContext } from './singletons' import { KclExpression } from './commandTypes' type ExecuteCommandEvent = CommandBarMachineEvent & { @@ -73,7 +72,7 @@ const prepareToEditExtrude: PrepareToEditCallback = key: artifact.pathId, types: ['path'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if ( err(pathArtifact) || @@ -86,7 +85,7 @@ const prepareToEditExtrude: PrepareToEditCallback = key: pathArtifact.solid2dId, types: ['solid2d'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(solid2DArtifact) || solid2DArtifact.type !== 'solid2d') { return baseCommand @@ -157,7 +156,7 @@ const prepareToEditEdgeTreatment: PrepareToEditCallback = async ({ key: artifact.consumedEdgeId, types: ['segment', 'sweepEdge'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(edgeArtifact)) { return { reason: "Couldn't find edge artifact" } @@ -165,7 +164,7 @@ const prepareToEditEdgeTreatment: PrepareToEditCallback = async ({ let edgeCodeRef = getEdgeCutConsumedCodeRef( artifact, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(edgeCodeRef)) { return { reason: "Couldn't find edge coderef" } @@ -272,16 +271,13 @@ const prepareToEditShell: PrepareToEditCallback = // that we can query in another loop later const sweepId = operation.unlabeledArg.value.value.artifactId const candidates: Map = new Map() - for (const artifact of engineCommandManager.artifactGraph.values()) { + for (const artifact of kclManager.artifactGraph.values()) { if ( artifact.type === 'cap' && artifact.sweepId === sweepId && artifact.subType ) { - const codeRef = getCapCodeRef( - artifact, - engineCommandManager.artifactGraph - ) + const codeRef = getCapCodeRef(artifact, kclManager.artifactGraph) if (err(codeRef)) { return baseCommand } @@ -297,7 +293,7 @@ const prepareToEditShell: PrepareToEditCallback = ) { const segArtifact = getArtifactOfTypes( { key: artifact.segId, types: ['segment'] }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(segArtifact)) { return baseCommand @@ -461,7 +457,7 @@ const prepareToEditSweep: PrepareToEditCallback = async ({ key: artifact.pathId, types: ['path'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if ( @@ -477,7 +473,7 @@ const prepareToEditSweep: PrepareToEditCallback = async ({ key: pathArtifact.solid2dId, types: ['solid2d'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(targetArtifact) || targetArtifact.type !== 'solid2d') { @@ -508,7 +504,7 @@ const prepareToEditSweep: PrepareToEditCallback = async ({ key: operation.labeledArgs.path.value.value.artifactId, types: ['path'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(trajectoryPathArtifact) || trajectoryPathArtifact.type !== 'path') { @@ -520,7 +516,7 @@ const prepareToEditSweep: PrepareToEditCallback = async ({ key: trajectoryPathArtifact.segIds[0], types: ['segment'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(trajectoryArtifact) || trajectoryArtifact.type !== 'segment') { @@ -607,7 +603,7 @@ const prepareToEditHelix: PrepareToEditCallback = async ({ operation }) => { key: axisValue.artifact_id, types: ['segment'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(artifact)) { return { reason: "Couldn't find related edge artifact" } @@ -630,16 +626,13 @@ const prepareToEditHelix: PrepareToEditCallback = async ({ operation }) => { key: axisValue.value, types: ['sweepEdge'], }, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(artifact)) { return { reason: "Couldn't find related edge artifact" } } - const codeRef = getSweepEdgeCodeRef( - artifact, - engineCommandManager.artifactGraph - ) + const codeRef = getSweepEdgeCodeRef(artifact, kclManager.artifactGraph) if (err(codeRef)) { return { reason: "Couldn't find related edge code ref" } } @@ -667,7 +660,7 @@ const prepareToEditHelix: PrepareToEditCallback = async ({ operation }) => { } const sweepId = operation.labeledArgs.cylinder.value.value.artifactId - const wallArtifact = [...engineCommandManager.artifactGraph.values()].find( + const wallArtifact = [...kclManager.artifactGraph.values()].find( (p) => p.type === 'wall' && p.sweepId === sweepId ) if (!wallArtifact || wallArtifact.type !== 'wall') { @@ -676,10 +669,7 @@ const prepareToEditHelix: PrepareToEditCallback = async ({ operation }) => { } } - const wallCodeRef = getWallCodeRef( - wallArtifact, - engineCommandManager.artifactGraph - ) + const wallCodeRef = getWallCodeRef(wallArtifact, kclManager.artifactGraph) if (err(wallCodeRef)) { return { reason: "Cylinder arg found doesn't point to a valid sweep code ref", diff --git a/src/lib/rustContext.ts b/src/lib/rustContext.ts index 765090d1c..4f29bc3cf 100644 --- a/src/lib/rustContext.ts +++ b/src/lib/rustContext.ts @@ -146,16 +146,13 @@ export default class RustContext { return this._defaultPlanes } - // Clear the scene and bust the cache. + // Clear/reset the scene and bust the cache. async clearSceneAndBustCache( settings: DeepPartial, path?: string - ) { - // Send through and empty ast to clear the scene. - // This will also bust the cache and reset the default planes. - // We do it like this so it works better with adding stuff later and the - // cache. - // It also works better with the id generator. + ): Promise { + const instance = await this._checkInstance() + const ast: Node = { body: [], shebang: null, @@ -172,7 +169,23 @@ export default class RustContext { commentStart: 0, } - await this.execute(ast, settings, path) + try { + const result = await instance.bustCacheAndResetScene( + JSON.stringify(settings), + path + ) + /* Set the default planes, safe to call after execute. */ + const outcome = execStateFromRust(result, ast) + + this._defaultPlanes = outcome.defaultPlanes + + // Return the result. + return outcome + } catch (e: any) { + const err = errFromErrWithOutputs(e) + this._defaultPlanes = err.defaultPlanes + return Promise.reject(err) + } } getDefaultPlaneId(name: DefaultPlaneStr): string | Error { diff --git a/src/lib/selections.ts b/src/lib/selections.ts index cb28f32d8..0fb624f17 100644 --- a/src/lib/selections.ts +++ b/src/lib/selections.ts @@ -102,10 +102,10 @@ export async function getEventForSelectWithPoint({ } } - let _artifact = engineCommandManager.artifactGraph.get(data.entity_id) + let _artifact = kclManager.artifactGraph.get(data.entity_id) const codeRefs = getCodeRefsByArtifactId( data.entity_id, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (_artifact && codeRefs) { return { @@ -140,15 +140,15 @@ export function getEventForSegmentSelection( // id does not match up with the artifact graph when in sketch mode, because mock executions // do not update the artifact graph, therefore we match up the pathToNode instead // we can reliably use `type === 'segment'` since it's in sketch mode and we're concerned with segments - const segWithMatchingPathToNode__Id = [ - ...engineCommandManager.artifactGraph, - ].find((entry) => { - return ( - entry[1].type === 'segment' && - JSON.stringify(entry[1].codeRef.pathToNode) === - JSON.stringify(group?.userData?.pathToNode) - ) - })?.[0] + const segWithMatchingPathToNode__Id = [...kclManager.artifactGraph].find( + (entry) => { + return ( + entry[1].type === 'segment' && + JSON.stringify(entry[1].codeRef.pathToNode) === + JSON.stringify(group?.userData?.pathToNode) + ) + } + )?.[0] const id = segWithMatchingPathToNode__Id @@ -172,7 +172,7 @@ export function getEventForSegmentSelection( } } if (!id || !group) return null - const artifact = engineCommandManager.artifactGraph.get(id) + const artifact = kclManager.artifactGraph.get(id) if (!artifact) return null const node = getNodeFromPath(kclManager.ast, group.userData.pathToNode) if (err(node)) return null @@ -208,10 +208,8 @@ export function handleSelectionBatch({ selectionToEngine.push({ id: artifact?.id, range: - getCodeRefsByArtifactId( - artifact.id, - engineCommandManager.artifactGraph - )?.[0].range || defaultSourceRange(), + getCodeRefsByArtifactId(artifact.id, kclManager.artifactGraph)?.[0] + .range || defaultSourceRange(), }) }) const engineEvents: Models['WebSocketRequest_type'][] = @@ -291,7 +289,7 @@ export function processCodeMirrorRanges({ const idBasedSelections: SelectionToEngine[] = codeToIdSelections( codeBasedSelections, artifactGraph, - engineCommandManager.artifactIndex + kclManager.artifactIndex ) const selections: Selection[] = [] for (const { id, range } of idBasedSelections) { @@ -396,10 +394,7 @@ function resetAndSetEngineEntitySelectionCmds( */ export function isSketchPipe(selectionRanges: Selections) { if (!isSingleCursorInPipe(selectionRanges, kclManager.ast)) return false - return isCursorInSketchCommandRange( - engineCommandManager.artifactGraph, - selectionRanges - ) + return isCursorInSketchCommandRange(kclManager.artifactGraph, selectionRanges) } // This accounts for non-geometry selections under "other" @@ -692,12 +687,9 @@ export function updateSelections( if (err(nodeMeta)) return undefined const node = nodeMeta.node let artifact: Artifact | null = null - for (const [id, a] of engineCommandManager.artifactGraph) { + for (const [id, a] of kclManager.artifactGraph) { if (previousSelection?.artifact?.type === a.type) { - const codeRefs = getCodeRefsByArtifactId( - id, - engineCommandManager.artifactGraph - ) + const codeRefs = getCodeRefsByArtifactId(id, kclManager.artifactGraph) if (!codeRefs) continue if ( JSON.stringify(codeRefs[0].pathToNode) === diff --git a/src/lib/settings/initialSettings.tsx b/src/lib/settings/initialSettings.tsx index f266612f3..21bccdb79 100644 --- a/src/lib/settings/initialSettings.tsx +++ b/src/lib/settings/initialSettings.tsx @@ -22,6 +22,7 @@ import { CameraProjectionType } from '@rust/kcl-lib/bindings/CameraProjectionTyp import { OnboardingStatus } from '@rust/kcl-lib/bindings/OnboardingStatus' import { NamedView } from '@rust/kcl-lib/bindings/NamedView' import { CameraOrbitType } from '@rust/kcl-lib/bindings/CameraOrbitType' +import { DEFAULT_DEFAULT_LENGTH_UNIT } from 'lib/constants' /** * A setting that can be set at the user or project level @@ -300,8 +301,9 @@ export function createSettings() { * The default unit to use in modeling dimensions */ defaultUnit: new Setting({ - defaultValue: 'mm', - description: 'The default unit to use in modeling dimensions', + defaultValue: DEFAULT_DEFAULT_LENGTH_UNIT, + description: + 'Set the default length unit setting value to give any new files.', validate: (v) => baseUnitsUnion.includes(v), commandConfig: { inputType: 'options', diff --git a/src/lib/settings/settingsTypes.ts b/src/lib/settings/settingsTypes.ts index 5dc4c1eca..bbf17ec4a 100644 --- a/src/lib/settings/settingsTypes.ts +++ b/src/lib/settings/settingsTypes.ts @@ -145,7 +145,7 @@ export type SaveSettingsPayload = RecursiveSettingsPayloads /** * Annotation names for default units are defined on rust side in - * src/wasm-lib/kcl/src/execution/annotations.rs + * rust/kcl-lib/src/execution/annotations.rs */ export interface KclSettingsAnnotation { defaultLengthUnit?: UnitLength_type diff --git a/src/lib/utils.ts b/src/lib/utils.ts index f41c77756..94ec96d5d 100644 --- a/src/lib/utils.ts +++ b/src/lib/utils.ts @@ -4,6 +4,7 @@ import { v4 } from 'uuid' import { isDesktop } from './isDesktop' import { AnyMachineSnapshot } from 'xstate' import { AsyncFn } from './types' +import { Binary as BSONBinary } from 'bson' export const uuidv4 = v4 @@ -406,3 +407,65 @@ export function isClockwise(points: [number, number][]): boolean { // If sum is positive, the points are in clockwise order return sum > 0 } + +/** + * Converts a binary buffer to a UUID string. + * + * @param buffer - The binary buffer containing the UUID bytes. + * @returns A string representation of the UUID in the format 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'. + */ +export function binaryToUuid( + binaryData: Buffer | Uint8Array | BSONBinary | string +): string { + if (typeof binaryData === 'string') { + return binaryData + } + + let buffer: Uint8Array + + // Handle MongoDB BSON Binary object + if ( + binaryData && + '_bsontype' in binaryData && + binaryData._bsontype === 'Binary' + ) { + // Extract the buffer from the BSON Binary object + buffer = binaryData.buffer + } + // Handle case where buffer property exists (some MongoDB drivers structure) + else if (binaryData && binaryData.buffer instanceof Uint8Array) { + buffer = binaryData.buffer + } + // Handle direct Buffer or Uint8Array + else if (binaryData instanceof Uint8Array || Buffer.isBuffer(binaryData)) { + buffer = binaryData + } else { + console.error( + 'Invalid input type: expected MongoDB BSON Binary, Buffer, or Uint8Array' + ) + return '' + } + + // Ensure we have exactly 16 bytes (128 bits) for a UUID + if (buffer.length !== 16) { + // For debugging + console.log('Buffer length:', buffer.length) + console.log('Buffer content:', Array.from(buffer)) + console.error('UUID must be exactly 16 bytes') + return '' + } + + // Convert each byte to a hex string and pad with zeros if needed + const hexValues = Array.from(buffer).map((byte) => + byte.toString(16).padStart(2, '0') + ) + + // Format into UUID structure (8-4-4-4-12 characters) + return [ + hexValues.slice(0, 4).join(''), + hexValues.slice(4, 6).join(''), + hexValues.slice(6, 8).join(''), + hexValues.slice(8, 10).join(''), + hexValues.slice(10, 16).join(''), + ].join('-') +} diff --git a/src/lib/wasm_lib_wrapper.ts b/src/lib/wasm_lib_wrapper.ts index 6b972e01b..8dbddd847 100644 --- a/src/lib/wasm_lib_wrapper.ts +++ b/src/lib/wasm_lib_wrapper.ts @@ -22,6 +22,7 @@ import { base64_decode as Base64Decode, kcl_settings as KclSettings, change_kcl_settings as ChangeKclSettings, + is_kcl_empty_or_only_settings as IsKclEmptyOrOnlySettings, get_kcl_version as GetKclVersion, serialize_configuration as SerializeConfiguration, serialize_project_configuration as SerializeProjectConfiguration, @@ -93,6 +94,11 @@ export const kcl_settings: typeof KclSettings = (...args) => { export const change_kcl_settings: typeof ChangeKclSettings = (...args) => { return getModule().change_kcl_settings(...args) } +export const is_kcl_empty_or_only_settings: typeof IsKclEmptyOrOnlySettings = ( + ...args +) => { + return getModule().is_kcl_empty_or_only_settings(...args) +} export const get_kcl_version: typeof GetKclVersion = () => { return getModule().get_kcl_version() } diff --git a/src/machines/featureTreeMachine.ts b/src/machines/featureTreeMachine.ts index c69cd3f71..b436a2a38 100644 --- a/src/machines/featureTreeMachine.ts +++ b/src/machines/featureTreeMachine.ts @@ -5,7 +5,7 @@ import { enterEditFlow, EnterEditFlowProps, } from 'lib/operations' -import { engineCommandManager, kclManager } from 'lib/singletons' +import { kclManager } from 'lib/singletons' import { err } from 'lib/trap' import toast from 'react-hot-toast' import { Operation } from '@rust/kcl-lib/bindings/Operation' @@ -275,7 +275,7 @@ export const featureTreeMachine = setup({ const artifact = context.targetSourceRange ? getArtifactFromRange( context.targetSourceRange, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) ?? undefined : undefined return { @@ -329,7 +329,7 @@ export const featureTreeMachine = setup({ const artifact = context.targetSourceRange ? getArtifactFromRange( context.targetSourceRange, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) ?? undefined : undefined return { @@ -383,7 +383,7 @@ export const featureTreeMachine = setup({ const artifact = context.targetSourceRange ? getArtifactFromRange( context.targetSourceRange, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) ?? undefined : undefined return { diff --git a/src/machines/fileMachine.ts b/src/machines/fileMachine.ts index e067d85dc..f628ed643 100644 --- a/src/machines/fileMachine.ts +++ b/src/machines/fileMachine.ts @@ -126,7 +126,7 @@ export const fileMachine = setup({ makeDir: boolean selectedDirectory: FileEntry targetPathToClone?: string - content: string + content?: string shouldSetToRename: boolean } }) => Promise.resolve({ message: '', path: '' }) @@ -152,7 +152,7 @@ export const fileMachine = setup({ name: string makeDir: boolean selectedDirectory: FileEntry - content: string + content?: string } }) => Promise.resolve({ path: '' }) ), @@ -238,7 +238,7 @@ export const fileMachine = setup({ makeDir: event.data.makeDir, selectedDirectory: context.selectedDirectory, targetPathToClone: event.data.targetPathToClone, - content: event.data.content ?? '', + content: event.data.content, shouldSetToRename: event.data.shouldSetToRename ?? false, } }, @@ -417,7 +417,7 @@ export const fileMachine = setup({ name: event.data.name, makeDir: event.data.makeDir, selectedDirectory: context.selectedDirectory, - content: event.data.content ?? '', + content: event.data.content, } }, onDone: 'Reading files', diff --git a/src/machines/modelingMachine.ts b/src/machines/modelingMachine.ts index 89df9db32..f9681abc4 100644 --- a/src/machines/modelingMachine.ts +++ b/src/machines/modelingMachine.ts @@ -766,7 +766,7 @@ export const modelingMachine = setup({ axisOrEdge, axis, edge, - engineCommandManager.artifactGraph, + kclManager.artifactGraph, selection.graphSelections[0]?.artifact ) if (trap(revolveSketchRes)) return @@ -1123,9 +1123,7 @@ export const modelingMachine = setup({ }), 're-eval nodePaths': assign(({ context: { sketchDetails } }) => { if (!sketchDetails) return {} - const planeArtifact = [ - ...engineCommandManager.artifactGraph.values(), - ].find( + const planeArtifact = [...kclManager.artifactGraph.values()].find( (artifact) => artifact.type === 'plane' && stringifyPathToNode(artifact.codeRef.pathToNode) === @@ -1134,7 +1132,7 @@ export const modelingMachine = setup({ if (planeArtifact?.type !== 'plane') return {} const newPaths = getPathsFromPlaneArtifact( planeArtifact, - engineCommandManager.artifactGraph, + kclManager.artifactGraph, kclManager.ast ) return { @@ -1794,7 +1792,7 @@ export const modelingMachine = setup({ node: ast, pathToNode, artifact: selection.graphSelections[0].artifact, - artifactGraph: engineCommandManager.artifactGraph, + artifactGraph: kclManager.artifactGraph, distance: 'variableName' in distance ? distance.variableIdentifierAst @@ -1987,7 +1985,7 @@ export const modelingMachine = setup({ const extrudeLookupResult = getPathToExtrudeForSegmentSelection( clonedAstForGetExtrude, cylinder.graphSelections[0], - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(extrudeLookupResult)) { return extrudeLookupResult @@ -2249,7 +2247,7 @@ export const modelingMachine = setup({ const extrudeLookupResult = getPathToExtrudeForSegmentSelection( clonedAstForGetExtrude, graphSelection, - engineCommandManager.artifactGraph + kclManager.artifactGraph ) if (err(extrudeLookupResult)) { return new Error( diff --git a/src/routes/Onboarding/Introduction.tsx b/src/routes/Onboarding/Introduction.tsx index b4a9e052e..c3103d12c 100644 --- a/src/routes/Onboarding/Introduction.tsx +++ b/src/routes/Onboarding/Introduction.tsx @@ -14,6 +14,7 @@ import { useFileContext } from 'hooks/useFileContext' import { useLspContext } from 'components/LspProvider' import { reportRejection } from 'lib/trap' import { useSettings } from 'machines/appMachine' +import { isKclEmptyOrOnlySettings } from 'lang/wasm' /** * Show either a welcome screen or a warning screen @@ -21,7 +22,7 @@ import { useSettings } from 'machines/appMachine' */ export default function OnboardingIntroduction() { const [shouldShowWarning, setShouldShowWarning] = useState( - codeManager.code !== '' && codeManager.code !== bracket + !isKclEmptyOrOnlySettings(codeManager.code) && codeManager.code !== bracket ) return shouldShowWarning ? ( diff --git a/src/routes/SignIn.tsx b/src/routes/SignIn.tsx index 50088f929..3b3710f6e 100644 --- a/src/routes/SignIn.tsx +++ b/src/routes/SignIn.tsx @@ -104,21 +104,11 @@ const SignIn = () => {

- Thank you for using our hardware design application. It is built - on a novel CAD engine and crafted to help you create parametric, - version-controlled, and accurate parts ready for manufacturing. -

-

- As alpha software, Zoo Modeling App is still in heavy development. - We encourage feedback and feature requests that align with{' '} - - our roadmap to v1.0 - - . + Thank you for using our CAD application. It is built on a novel + geometry engine and crafted to help you create robust parametric + designs. It represents your models as code, making it easy to + collaborate with ML tools like Zoo Text-To-CAD to design parts and + libraries fast.

{isDesktop() ? (
@@ -206,7 +196,7 @@ const SignIn = () => {
-

Built in the open

+

Built in the open

Open-source and open discussions. Check our public code base and join our Discord. @@ -215,23 +205,26 @@ const SignIn = () => { Read our source code Join our community

-

Ready for the future

+

Ready for the future

Modern software ideas being brought together to create a familiar modeling experience with new superpowers. @@ -240,8 +233,11 @@ const SignIn = () => { Parametric design with KCL @@ -250,15 +246,18 @@ const SignIn = () => { AI-unlocked CAD

-

+

Built on the first infrastructure for hardware design

@@ -270,16 +269,19 @@ const SignIn = () => { KittyCAD Design API ML-ephant Machine Learning API diff --git a/yarn.lock b/yarn.lock index d94de67f3..102b37a20 100644 --- a/yarn.lock +++ b/yarn.lock @@ -47,21 +47,21 @@ resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.26.8.tgz#821c1d35641c355284d4a870b8a4a7b0c141e367" integrity sha512-oH5UPLMWR3L2wEFLnFJ1TZXqHufiTKAiLfqw5zkhS4dKXLJ10yVztfil/twG8EDTA4F/tvVNw9nOl4ZMslB8rQ== -"@babel/core@^7.21.4", "@babel/core@^7.24.5": - version "7.25.2" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.25.2.tgz#ed8eec275118d7613e77a352894cd12ded8eba77" - integrity sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA== +"@babel/core@^7.21.4", "@babel/core@^7.26.0": + version "7.26.10" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.26.10.tgz#5c876f83c8c4dcb233ee4b670c0606f2ac3000f9" + integrity sha512-vMqyb7XCDMPvJFFOaT9kxtiRh42GwlZEg1/uIgtZshS5a/8OaduUfCi7kynKgc3Tw/6Uo2D+db9qBttghhmxwQ== dependencies: "@ampproject/remapping" "^2.2.0" - "@babel/code-frame" "^7.24.7" - "@babel/generator" "^7.25.0" - "@babel/helper-compilation-targets" "^7.25.2" - "@babel/helper-module-transforms" "^7.25.2" - "@babel/helpers" "^7.25.0" - "@babel/parser" "^7.25.0" - "@babel/template" "^7.25.0" - "@babel/traverse" "^7.25.2" - "@babel/types" "^7.25.2" + "@babel/code-frame" "^7.26.2" + "@babel/generator" "^7.26.10" + "@babel/helper-compilation-targets" "^7.26.5" + "@babel/helper-module-transforms" "^7.26.0" + "@babel/helpers" "^7.26.10" + "@babel/parser" "^7.26.10" + "@babel/template" "^7.26.9" + "@babel/traverse" "^7.26.10" + "@babel/types" "^7.26.10" convert-source-map "^2.0.0" debug "^4.1.0" gensync "^1.0.0-beta.2" @@ -89,6 +89,17 @@ "@jridgewell/trace-mapping" "^0.3.25" jsesc "^3.0.2" +"@babel/generator@^7.27.0": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.27.0.tgz#764382b5392e5b9aff93cadb190d0745866cbc2c" + integrity sha512-VybsKvpiN1gU1sdMZIp7FcqphVVKEwcuj02x73uvcHE0PTihx1nlBcowYWhDwjpoAXRv43+gDzyggGnn1XZhVw== + dependencies: + "@babel/parser" "^7.27.0" + "@babel/types" "^7.27.0" + "@jridgewell/gen-mapping" "^0.3.5" + "@jridgewell/trace-mapping" "^0.3.25" + jsesc "^3.0.2" + "@babel/helper-annotate-as-pure@^7.18.6", "@babel/helper-annotate-as-pure@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.7.tgz#5373c7bc8366b12a033b4be1ac13a206c6656aab" @@ -103,7 +114,7 @@ dependencies: "@babel/types" "^7.25.9" -"@babel/helper-compilation-targets@^7.22.6", "@babel/helper-compilation-targets@^7.25.2", "@babel/helper-compilation-targets@^7.25.9", "@babel/helper-compilation-targets@^7.26.5": +"@babel/helper-compilation-targets@^7.22.6", "@babel/helper-compilation-targets@^7.25.9", "@babel/helper-compilation-targets@^7.26.5": version "7.26.5" resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.26.5.tgz#75d92bb8d8d51301c0d49e52a65c9a7fe94514d8" integrity sha512-IXuyn5EkouFJscIDuFF5EsiSolseme1s0CZB+QxVugqJLYmKdxI1VfIBOst0SUu4rnk2Z7kqTwmoO1lp3HIfnA== @@ -196,14 +207,6 @@ "@babel/traverse" "^7.25.9" "@babel/types" "^7.25.9" -"@babel/helper-module-imports@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz#f2f980392de5b84c3328fc71d38bd81bbb83042b" - integrity sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA== - dependencies: - "@babel/traverse" "^7.24.7" - "@babel/types" "^7.24.7" - "@babel/helper-module-imports@^7.25.9": version "7.25.9" resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz#e7f8d20602ebdbf9ebbea0a0751fb0f2a4141715" @@ -212,16 +215,6 @@ "@babel/traverse" "^7.25.9" "@babel/types" "^7.25.9" -"@babel/helper-module-transforms@^7.25.2": - version "7.25.2" - resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz#ee713c29768100f2776edf04d4eb23b8d27a66e6" - integrity sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ== - dependencies: - "@babel/helper-module-imports" "^7.24.7" - "@babel/helper-simple-access" "^7.24.7" - "@babel/helper-validator-identifier" "^7.24.7" - "@babel/traverse" "^7.25.2" - "@babel/helper-module-transforms@^7.25.9", "@babel/helper-module-transforms@^7.26.0": version "7.26.0" resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz#8ce54ec9d592695e58d84cd884b7b5c6a2fdeeae" @@ -245,7 +238,7 @@ dependencies: "@babel/types" "^7.25.9" -"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.20.2", "@babel/helper-plugin-utils@^7.22.5", "@babel/helper-plugin-utils@^7.24.7", "@babel/helper-plugin-utils@^7.25.9", "@babel/helper-plugin-utils@^7.26.5": +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.20.2", "@babel/helper-plugin-utils@^7.22.5", "@babel/helper-plugin-utils@^7.25.9", "@babel/helper-plugin-utils@^7.26.5": version "7.26.5" resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.26.5.tgz#18580d00c9934117ad719392c4f6585c9333cc35" integrity sha512-RS+jZcRdZdRFzMyr+wcsaqOmld1/EqTghfaBGQQd/WnRdzdlvSZ//kF7U8VQTxf1ynZ4cjUcYgjVGx13ewNPMg== @@ -277,14 +270,6 @@ "@babel/helper-optimise-call-expression" "^7.25.9" "@babel/traverse" "^7.26.5" -"@babel/helper-simple-access@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz#bcade8da3aec8ed16b9c4953b74e506b51b5edb3" - integrity sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg== - dependencies: - "@babel/traverse" "^7.24.7" - "@babel/types" "^7.24.7" - "@babel/helper-skip-transparent-expression-wrappers@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.24.7.tgz#5f8fa83b69ed5c27adc56044f8be2b3ea96669d9" @@ -335,13 +320,13 @@ "@babel/traverse" "^7.25.9" "@babel/types" "^7.25.9" -"@babel/helpers@^7.25.0": - version "7.26.10" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.26.10.tgz#6baea3cd62ec2d0c1068778d63cb1314f6637384" - integrity sha512-UPYc3SauzZ3JGgj87GgZ89JVdC5dj0AoetR5Bw6wj4niittNyFh6+eOGonYvJ1ao6B8lEa3Q3klS7ADZ53bc5g== +"@babel/helpers@^7.26.10": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.27.0.tgz#53d156098defa8243eab0f32fa17589075a1b808" + integrity sha512-U5eyP/CTFPuNE3qk+WZMxFkp/4zUzdceQlfzf7DdGdhp+Fezd7HD+i8Y24ZuTMKX3wQBld449jijbGq6OdGNQg== dependencies: - "@babel/template" "^7.26.9" - "@babel/types" "^7.26.10" + "@babel/template" "^7.27.0" + "@babel/types" "^7.27.0" "@babel/highlight@^7.24.7": version "7.24.7" @@ -367,6 +352,13 @@ dependencies: "@babel/types" "^7.26.10" +"@babel/parser@^7.27.0": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.27.0.tgz#3d7d6ee268e41d2600091cbd4e145ffee85a44ec" + integrity sha512-iaepho73/2Pz7w2eMS0Q5f83+0RKI7i4xmiYeBmDzfRVbQtTOG7Ts0S4HzJVsTMGI9keU8rNfuZr8DKfSt7Yyg== + dependencies: + "@babel/types" "^7.27.0" + "@babel/plugin-bugfix-firefox-class-in-computed-class-key@^7.25.9": version "7.25.9" resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.25.9.tgz#cc2e53ebf0a0340777fff5ed521943e253b4d8fe" @@ -747,19 +739,19 @@ dependencies: "@babel/helper-plugin-utils" "^7.25.9" -"@babel/plugin-transform-react-jsx-self@^7.24.5": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.24.7.tgz#66bff0248ea0b549972e733516ffad577477bdab" - integrity sha512-fOPQYbGSgH0HUp4UJO4sMBFjY6DuWq+2i8rixyUMb3CdGixs/gccURvYOAhajBdKDoGajFr3mUq5rH3phtkGzw== +"@babel/plugin-transform-react-jsx-self@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.25.9.tgz#c0b6cae9c1b73967f7f9eb2fca9536ba2fad2858" + integrity sha512-y8quW6p0WHkEhmErnfe58r7x0A70uKphQm8Sp8cV7tjNQwK56sNVK0M73LK3WuYmsuyrftut4xAkjjgU0twaMg== dependencies: - "@babel/helper-plugin-utils" "^7.24.7" + "@babel/helper-plugin-utils" "^7.25.9" -"@babel/plugin-transform-react-jsx-source@^7.24.1": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.24.7.tgz#1198aab2548ad19582013815c938d3ebd8291ee3" - integrity sha512-J2z+MWzZHVOemyLweMqngXrgGC42jQ//R0KdxqkIz/OrbVIIlhFI3WigZ5fO+nwFvBlncr4MGapd8vTyc7RPNQ== +"@babel/plugin-transform-react-jsx-source@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.25.9.tgz#4c6b8daa520b5f155b5fb55547d7c9fa91417503" + integrity sha512-+iqjT8xmXhhYv4/uiYd8FNQsraMFZIfxVSqxxVSZP0WbbSAWvBXAul0m/zu+7Vv4O/3WtApy9pmaTMiumEZgfg== dependencies: - "@babel/helper-plugin-utils" "^7.24.7" + "@babel/helper-plugin-utils" "^7.25.9" "@babel/plugin-transform-regenerator@^7.25.9": version "7.25.9" @@ -965,7 +957,16 @@ "@babel/parser" "^7.26.9" "@babel/types" "^7.26.9" -"@babel/traverse@^7.21.4", "@babel/traverse@^7.24.7", "@babel/traverse@^7.24.8", "@babel/traverse@^7.25.0", "@babel/traverse@^7.25.2": +"@babel/template@^7.27.0": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.27.0.tgz#b253e5406cc1df1c57dcd18f11760c2dbf40c0b4" + integrity sha512-2ncevenBqXI6qRMukPlXwHKHchC7RyMuu4xv5JBXRfOGVcTy1mXCD12qrp7Jsoxll1EV3+9sE4GugBVRjT2jFA== + dependencies: + "@babel/code-frame" "^7.26.2" + "@babel/parser" "^7.27.0" + "@babel/types" "^7.27.0" + +"@babel/traverse@^7.21.4", "@babel/traverse@^7.24.7", "@babel/traverse@^7.24.8", "@babel/traverse@^7.25.0": version "7.25.3" resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.25.3.tgz#f1b901951c83eda2f3e29450ce92743783373490" integrity sha512-HefgyP1x754oGCsKmV5reSmtV7IXj/kpaE1XYY+D9G5PvKKoFfSbiS4M77MdjuwlZKDIKFCffq9rPU+H/s3ZdQ== @@ -991,6 +992,19 @@ debug "^4.3.1" globals "^11.1.0" +"@babel/traverse@^7.26.10": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.27.0.tgz#11d7e644779e166c0442f9a07274d02cd91d4a70" + integrity sha512-19lYZFzYVQkkHkl4Cy4WrAVcqBkgvV2YM2TU3xG6DIwO7O3ecbDPfW3yM3bjAGcqcQHi+CCtjMR3dIEHxsd6bA== + dependencies: + "@babel/code-frame" "^7.26.2" + "@babel/generator" "^7.27.0" + "@babel/parser" "^7.27.0" + "@babel/template" "^7.27.0" + "@babel/types" "^7.27.0" + debug "^4.3.1" + globals "^11.1.0" + "@babel/types@^7.0.0", "@babel/types@^7.20.7", "@babel/types@^7.21.4", "@babel/types@^7.24.7", "@babel/types@^7.24.8", "@babel/types@^7.25.0", "@babel/types@^7.25.2", "@babel/types@^7.4.4": version "7.25.2" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.25.2.tgz#55fb231f7dc958cd69ea141a4c2997e819646125" @@ -1008,6 +1022,14 @@ "@babel/helper-string-parser" "^7.25.9" "@babel/helper-validator-identifier" "^7.25.9" +"@babel/types@^7.27.0": + version "7.27.0" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.27.0.tgz#ef9acb6b06c3173f6632d993ecb6d4ae470b4559" + integrity sha512-H45s8fVLYjbhFH62dIJ3WtmJ6RSPt/3DRO0ZcT2SUiYiQyz3BLVb9ADEnLl91m74aQPS3AzzeajZHYOalWe3bg== + dependencies: + "@babel/helper-string-parser" "^7.25.9" + "@babel/helper-validator-identifier" "^7.25.9" + "@codemirror/autocomplete@^6.0.0", "@codemirror/autocomplete@^6.18.6": version "6.18.6" resolved "https://registry.yarnpkg.com/@codemirror/autocomplete/-/autocomplete-6.18.6.tgz#de26e864a1ec8192a1b241eb86addbb612964ddb" @@ -1018,10 +1040,10 @@ "@codemirror/view" "^6.17.0" "@lezer/common" "^1.0.0" -"@codemirror/commands@^6.0.0", "@codemirror/commands@^6.8.0": - version "6.8.0" - resolved "https://registry.yarnpkg.com/@codemirror/commands/-/commands-6.8.0.tgz#92f200b66f852939bd6ebb90d48c2d9e9c813d64" - integrity sha512-q8VPEFaEP4ikSlt6ZxjB3zW72+7osfAYW9i8Zu943uqbKuz6utc1+F170hyLUCUltXORjQXRyYQNfkckzA/bPQ== +"@codemirror/commands@^6.0.0", "@codemirror/commands@^6.8.1": + version "6.8.1" + resolved "https://registry.yarnpkg.com/@codemirror/commands/-/commands-6.8.1.tgz#639f5559d2f33f2582a2429c58cb0c1b925c7a30" + integrity sha512-KlGVYufHMQzxbdQONiLyGQDUW0itrLZwq3CcY7xpv9ZLRHqzkBSoteocBHtMCoY7/Ci4xhzSrToIeLg7FxHuaw== dependencies: "@codemirror/language" "^6.0.0" "@codemirror/state" "^6.4.0" @@ -1040,10 +1062,10 @@ "@lezer/lr" "^1.0.0" style-mod "^4.0.0" -"@codemirror/lint@^6.0.0", "@codemirror/lint@^6.8.4": - version "6.8.4" - resolved "https://registry.yarnpkg.com/@codemirror/lint/-/lint-6.8.4.tgz#7d8aa5d1a6dec89ffcc23ad45ddca2e12e90982d" - integrity sha512-u4q7PnZlJUojeRe8FJa/njJcMctISGgPQ4PnWsd9268R4ZTtU+tfFYmwkBvgcrK2+QQ8tYFVALVb5fVJykKc5A== +"@codemirror/lint@^6.0.0", "@codemirror/lint@^6.8.5": + version "6.8.5" + resolved "https://registry.yarnpkg.com/@codemirror/lint/-/lint-6.8.5.tgz#9edaa808e764e28e07665b015951934c8ec3a418" + integrity sha512-s3n3KisH7dx3vsoeGMxsbRAgKe4O1vbrnKBClm99PU0fWxmxsx5rR2PfqQgIt+2MMJBHbiJ5rfIdLYfB9NNvsA== dependencies: "@codemirror/state" "^6.0.0" "@codemirror/view" "^6.35.0" @@ -1058,10 +1080,10 @@ "@codemirror/view" "^6.0.0" crelt "^1.0.5" -"@codemirror/state@^6.0.0", "@codemirror/state@^6.2.1", "@codemirror/state@^6.4.0", "@codemirror/state@^6.4.1", "@codemirror/state@^6.5.0": - version "6.5.0" - resolved "https://registry.yarnpkg.com/@codemirror/state/-/state-6.5.0.tgz#e98dde85620618651543152fe1c2483300a0ccc9" - integrity sha512-MwBHVK60IiIHDcoMet78lxt6iw5gJOGSbNbOIVBHWVXIH4/Nq1+GQgLLGgI1KlnN86WDXsPudVaqYHKBIx7Eyw== +"@codemirror/state@^6.0.0", "@codemirror/state@^6.2.1", "@codemirror/state@^6.4.0", "@codemirror/state@^6.5.0", "@codemirror/state@^6.5.2": + version "6.5.2" + resolved "https://registry.yarnpkg.com/@codemirror/state/-/state-6.5.2.tgz#8eca3a64212a83367dc85475b7d78d5c9b7076c6" + integrity sha512-FVqsPqtPWKVVL3dPSxy8wEF/ymIEuVzF1PK3VbUgrxXpJUSHQWWZz4JMToquRxnkw+36LTamCZG2iua2Ptq0fA== dependencies: "@marijn/find-cluster-break" "^1.0.0" @@ -1091,23 +1113,23 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" -"@csstools/color-helpers@^5.0.1": - version "5.0.1" - resolved "https://registry.yarnpkg.com/@csstools/color-helpers/-/color-helpers-5.0.1.tgz#829f1c76f5800b79c51c709e2f36821b728e0e10" - integrity sha512-MKtmkA0BX87PKaO1NFRTFH+UnkgnmySQOvNxJubsadusqPEC2aJ9MOQiMceZJJ6oitUl/i0L6u0M1IrmAOmgBA== +"@csstools/color-helpers@^5.0.2": + version "5.0.2" + resolved "https://registry.yarnpkg.com/@csstools/color-helpers/-/color-helpers-5.0.2.tgz#82592c9a7c2b83c293d9161894e2a6471feb97b8" + integrity sha512-JqWH1vsgdGcw2RR6VliXXdA0/59LttzlU8UlRT/iUUsEeWfYq8I+K0yhihEUTTHLRm1EXvpsCx3083EU15ecsA== -"@csstools/css-calc@^2.1.1": - version "2.1.1" - resolved "https://registry.yarnpkg.com/@csstools/css-calc/-/css-calc-2.1.1.tgz#a7dbc66627f5cf458d42aed14bda0d3860562383" - integrity sha512-rL7kaUnTkL9K+Cvo2pnCieqNpTKgQzy5f+N+5Iuko9HAoasP+xgprVh7KN/MaJVvVL1l0EzQq2MoqBHKSrDrag== +"@csstools/css-calc@^2.1.2": + version "2.1.2" + resolved "https://registry.yarnpkg.com/@csstools/css-calc/-/css-calc-2.1.2.tgz#bffd55f002dab119b76d4023f95cd943e6c8c11e" + integrity sha512-TklMyb3uBB28b5uQdxjReG4L80NxAqgrECqLZFQbyLekwwlcDDS8r3f07DKqeo8C4926Br0gf/ZDe17Zv4wIuw== -"@csstools/css-color-parser@^3.0.7": - version "3.0.7" - resolved "https://registry.yarnpkg.com/@csstools/css-color-parser/-/css-color-parser-3.0.7.tgz#442d61d58e54ad258d52c309a787fceb33906484" - integrity sha512-nkMp2mTICw32uE5NN+EsJ4f5N+IGFeCFu4bGpiKgb2Pq/7J/MpyLBeQ5ry4KKtRFZaYs6sTmcMYrSRIyj5DFKA== +"@csstools/css-color-parser@^3.0.8": + version "3.0.8" + resolved "https://registry.yarnpkg.com/@csstools/css-color-parser/-/css-color-parser-3.0.8.tgz#5fe9322920851450bf5e065c2b0e731b9e165394" + integrity sha512-pdwotQjCCnRPuNi06jFuP68cykU1f3ZWExLe/8MQ1LOs8Xq+fTkYgd+2V8mWUWMrOn9iS2HftPVaMZDaXzGbhQ== dependencies: - "@csstools/color-helpers" "^5.0.1" - "@csstools/css-calc" "^2.1.1" + "@csstools/color-helpers" "^5.0.2" + "@csstools/css-calc" "^2.1.2" "@csstools/css-parser-algorithms@^3.0.4": version "3.0.4" @@ -1119,12 +1141,12 @@ resolved "https://registry.yarnpkg.com/@csstools/css-tokenizer/-/css-tokenizer-3.0.3.tgz#a5502c8539265fecbd873c1e395a890339f119c2" integrity sha512-UJnjoFsmxfKUdNYdWgOB0mWUypuLvAfQPH1+pyvRJs6euowbFkFC6P13w1l8mJyi3vxYMxc9kld5jZEGRQs6bw== -"@csstools/postcss-oklab-function@^4.0.7": - version "4.0.7" - resolved "https://registry.yarnpkg.com/@csstools/postcss-oklab-function/-/postcss-oklab-function-4.0.7.tgz#33b3322dfb27b0b5eb83a7ad36e67f08bc4e66cd" - integrity sha512-I6WFQIbEKG2IO3vhaMGZDkucbCaUSXMxvHNzDdnfsTCF5tc0UlV3Oe2AhamatQoKFjBi75dSEMrgWq3+RegsOQ== +"@csstools/postcss-oklab-function@^4.0.8": + version "4.0.8" + resolved "https://registry.yarnpkg.com/@csstools/postcss-oklab-function/-/postcss-oklab-function-4.0.8.tgz#9d723e0db69703f3df549ebedfd605f849217fff" + integrity sha512-+5aPsNWgxohXoYNS1f+Ys0x3Qnfehgygv3qrPyv+Y25G0yX54/WlVB+IXprqBLOXHM1gsVF+QQSjlArhygna0Q== dependencies: - "@csstools/css-color-parser" "^3.0.7" + "@csstools/css-color-parser" "^3.0.8" "@csstools/css-parser-algorithms" "^3.0.4" "@csstools/css-tokenizer" "^3.0.3" "@csstools/postcss-progressive-custom-properties" "^4.0.0" @@ -1737,10 +1759,10 @@ "@tanstack/react-virtual" "^3.0.0-beta.60" client-only "^0.0.1" -"@headlessui/tailwindcss@^0.2.0": - version "0.2.1" - resolved "https://registry.yarnpkg.com/@headlessui/tailwindcss/-/tailwindcss-0.2.1.tgz#1becc201f69358a40e08bd676acc234b2cabe6e4" - integrity sha512-2+5+NZ+RzMyrVeCZOxdbvkUSssSxGvcUxphkIfSVLpRiKsj+/63T2TOL9dBYMXVfj/CGr6hMxSRInzXv6YY7sA== +"@headlessui/tailwindcss@^0.2.2": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@headlessui/tailwindcss/-/tailwindcss-0.2.2.tgz#8ebde73fabca72d48636ea56ae790209dc5f0d49" + integrity sha512-xNe42KjdyA4kfUKLLPGzME9zkH7Q3rOZ5huFihWNWOQFxnItxPB3/67yBI8/qBfY8nwBRx5GHn4VprsoluVMGw== "@humanwhocodes/config-array@^0.11.14": version "0.11.14" @@ -1844,10 +1866,10 @@ "@jridgewell/resolve-uri" "^3.1.0" "@jridgewell/sourcemap-codec" "^1.4.14" -"@kittycad/lib@2.0.21": - version "2.0.21" - resolved "https://registry.yarnpkg.com/@kittycad/lib/-/lib-2.0.21.tgz#b5ccb03367f4478896e5ef14221a8512d15ea4d4" - integrity sha512-JK2lAJm22GEVKX1Q57M2Pbnqzt8vmaXHec/9MDGIodnzWB36QEEs4VVVTIlJNbjoYoa+au5feakjTXUiuLu2cg== +"@kittycad/lib@2.0.23": + version "2.0.23" + resolved "https://registry.yarnpkg.com/@kittycad/lib/-/lib-2.0.23.tgz#0d215d458b35f6d207eeb90443889fa77b21b913" + integrity sha512-5T7+gHB21RX5bE7ILp3TnLzp0rA7CP1BucNctHynANG/sXV44tD7U8YEcQsi+/ZmMkvrxmZ/3r/UQjgzhQUh7w== dependencies: openapi-types "^12.0.0" ts-node "^10.9.1" @@ -1958,12 +1980,12 @@ resolved "https://registry.yarnpkg.com/@pkgjs/parseargs/-/parseargs-0.11.0.tgz#a77ea742fab25775145434eb1d2328cf5013ac33" integrity sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg== -"@playwright/test@^1.51.0": - version "1.51.0" - resolved "https://registry.yarnpkg.com/@playwright/test/-/test-1.51.0.tgz#8d5c8400b465a0bfdbcf993e390ceecb903ea6d2" - integrity sha512-dJ0dMbZeHhI+wb77+ljx/FeC8VBP6j/rj9OAojO08JI80wTZy6vRk9KvHKiDCUh4iMpEiseMgqRBIeW+eKX6RA== +"@playwright/test@^1.51.1": + version "1.51.1" + resolved "https://registry.yarnpkg.com/@playwright/test/-/test-1.51.1.tgz#75357d513221a7be0baad75f01e966baf9c41a2e" + integrity sha512-nM+kEaTSAoVlXmMPH10017vn3FSiFqr/bh4fKg9vmAdMfd9SDqRZNvPSiAHADc/itWak+qPvMPZQOPwCBW7k7Q== dependencies: - playwright "1.51.0" + playwright "1.51.1" "@react-hook/latest@^1.0.2": version "1.0.3" @@ -2340,10 +2362,10 @@ dependencies: "@types/ms" "*" -"@types/diff@^7.0.1": - version "7.0.1" - resolved "https://registry.yarnpkg.com/@types/diff/-/diff-7.0.1.tgz#acc505eb2e8337ca400503283a6ab44a59906d9f" - integrity sha512-R/BHQFripuhW6XPXy05hIvXJQdQ4540KnTvEFHSLjXfHYM41liOLKgIJEyYYiQe796xpaMHfe4Uj/p7Uvng2vA== +"@types/diff@^7.0.2": + version "7.0.2" + resolved "https://registry.yarnpkg.com/@types/diff/-/diff-7.0.2.tgz#d638edebf3c97aa4962b6f1164a7921ab3de9f83" + integrity sha512-JSWRMozjFKsGlEjiiKajUjIJVKuKdE3oVy2DNtK+fUo8q82nhFZ2CPQwicAIkXrofahDXrWJ7mjelvZphMS98Q== "@types/electron@^1.6.10": version "1.6.10" @@ -2446,10 +2468,10 @@ resolved "https://registry.yarnpkg.com/@types/ms/-/ms-0.7.34.tgz#10964ba0dee6ac4cd462e2795b6bebd407303433" integrity sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g== -"@types/node@*", "@types/node@^22.13.9": - version "22.13.9" - resolved "https://registry.yarnpkg.com/@types/node/-/node-22.13.9.tgz#5d9a8f7a975a5bd3ef267352deb96fb13ec02eca" - integrity sha512-acBjXdRJ3A6Pb3tqnw9HZmyR3Fiol3aGxRCK1x3d+6CDAMjl7I649wpSd+yNURCjbOUGu9tqtLKnTGxmK6CyGw== +"@types/node@*", "@types/node@^22.13.14": + version "22.13.14" + resolved "https://registry.yarnpkg.com/@types/node/-/node-22.13.14.tgz#70d84ec91013dcd2ba2de35532a5a14c2b4cc912" + integrity sha512-Zs/Ollc1SJ8nKUAgc7ivOEdIBM8JAKgrqqUYi2J997JuKO7/tpQC+WCetQ1sypiKCQWHdvdg9wBNpUPEWZae7w== dependencies: undici-types "~6.20.0" @@ -2570,10 +2592,10 @@ resolved "https://registry.yarnpkg.com/@types/wicg-file-system-access/-/wicg-file-system-access-2023.10.5.tgz#14b3c25eb4d914b5734795bdea71da229f918b9d" integrity sha512-e9kZO9kCdLqT2h9Tw38oGv9UNzBBWaR1MzuAavxPcsV/7FJ3tWbU6RI3uB+yKIDPGLkGVbplS52ub0AcRLvrhA== -"@types/ws@^8.5.13": - version "8.5.13" - resolved "https://registry.yarnpkg.com/@types/ws/-/ws-8.5.13.tgz#6414c280875e2691d0d1e080b05addbf5cb91e20" - integrity sha512-osM/gWBTPKgHV8XkTunnegTRIsvF6owmf5w+JtAfOw472dptdm0dlGv4xCt6GwQRcC2XVOvvRE/0bAoQcL2QkA== +"@types/ws@^8.18.0": + version "8.18.0" + resolved "https://registry.yarnpkg.com/@types/ws/-/ws-8.18.0.tgz#8a2ec491d6f0685ceaab9a9b7ff44146236993b5" + integrity sha512-8svvI3hMyvN0kKCJMvTJP/x6Y/EoQbepff882wL+Sn5QsXb3etnamgrJq4isrBxSJj5L2AuXcI0+bgkoAXGUJw== dependencies: "@types/node" "*" @@ -2703,14 +2725,14 @@ resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== -"@vitejs/plugin-react@^4.3.0": - version "4.3.1" - resolved "https://registry.yarnpkg.com/@vitejs/plugin-react/-/plugin-react-4.3.1.tgz#d0be6594051ded8957df555ff07a991fb618b48e" - integrity sha512-m/V2syj5CuVnaxcUJOQRel/Wr31FFXRFlnOoq1TVtkCxsY5veGMTEmpWHndrhB2U8ScHtCQB1e+4hWYExQc6Lg== +"@vitejs/plugin-react@^4.3.4": + version "4.3.4" + resolved "https://registry.yarnpkg.com/@vitejs/plugin-react/-/plugin-react-4.3.4.tgz#c64be10b54c4640135a5b28a2432330e88ad7c20" + integrity sha512-SCCPBJtYLdE8PX/7ZQAs1QAZ8Jqwih+0VBLum1EGqmCCQal+MIUqLCzj3ZUy8ufbC0cAM4LRlSTm7IQJwWT4ug== dependencies: - "@babel/core" "^7.24.5" - "@babel/plugin-transform-react-jsx-self" "^7.24.5" - "@babel/plugin-transform-react-jsx-source" "^7.24.1" + "@babel/core" "^7.26.0" + "@babel/plugin-transform-react-jsx-self" "^7.25.9" + "@babel/plugin-transform-react-jsx-source" "^7.25.9" "@types/babel__core" "^7.20.5" react-refresh "^0.14.2" @@ -2954,10 +2976,10 @@ app-builder-bin@5.0.0-alpha.12: resolved "https://registry.yarnpkg.com/app-builder-bin/-/app-builder-bin-5.0.0-alpha.12.tgz#2daf82f8badc698e0adcc95ba36af4ff0650dc80" integrity sha512-j87o0j6LqPL3QRr8yid6c+Tt5gC7xNfYo6uQIQkorAC6MpeayVMZrEDzKmJJ/Hlv7EnOQpaRm53k6ktDYZyB6w== -app-builder-lib@26.0.7: - version "26.0.7" - resolved "https://registry.yarnpkg.com/app-builder-lib/-/app-builder-lib-26.0.7.tgz#c930a624c8184b39c1974b27505f84eaf89d17b7" - integrity sha512-Sa6qGtt2l9of+KEA2fxdRBNLcWld74xgaP+U3Zr3A0R529Z2jPfUTmLi0dDY3jwRF6uOrsQAEkN+JWWvw5WpPw== +app-builder-lib@26.0.12: + version "26.0.12" + resolved "https://registry.yarnpkg.com/app-builder-lib/-/app-builder-lib-26.0.12.tgz#2e33df936e0f78d4266b058ece90308ea981eefb" + integrity sha512-+/CEPH1fVKf6HowBUs6LcAIoRcjeqgvAeoSE+cl7Y7LndyQ9ViGPYibNk7wmhMHzNgHIuIbw4nWADPO+4mjgWw== dependencies: "@develar/schema-utils" "~2.6.5" "@electron/asar" "3.2.18" @@ -2969,7 +2991,7 @@ app-builder-lib@26.0.7: "@malept/flatpak-bundler" "^0.4.0" "@types/fs-extra" "9.0.13" async-exit-hook "^2.0.1" - builder-util "26.0.7" + builder-util "26.0.11" builder-util-runtime "9.3.1" chromium-pickle-js "^0.2.0" config-file-ts "0.2.8-rc1" @@ -2977,7 +2999,7 @@ app-builder-lib@26.0.7: dotenv "^16.4.5" dotenv-expand "^11.0.6" ejs "^3.1.8" - electron-publish "26.0.7" + electron-publish "26.0.11" fs-extra "^10.1.0" hosted-git-info "^4.1.0" is-ci "^3.0.0" @@ -2986,6 +3008,7 @@ app-builder-lib@26.0.7: json5 "^2.2.3" lazy-val "^1.0.5" minimatch "^10.0.0" + plist "3.1.0" resedit "^1.7.0" semver "^7.3.8" tar "^6.1.12" @@ -3198,16 +3221,16 @@ author-regex@^1.0.0: resolved "https://registry.yarnpkg.com/author-regex/-/author-regex-1.0.0.tgz#d08885be6b9bbf9439fe087c76287245f0a81450" integrity sha512-KbWgR8wOYRAPekEmMXrYYdc7BRyhn2Ftk7KWfMUnQ43hFdojWEFRxhhRUm3/OFEdPa1r0KAvTTg9YQK57xTe0g== -autoprefixer@^10.4.19: - version "10.4.19" - resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.19.tgz#ad25a856e82ee9d7898c59583c1afeb3fa65f89f" - integrity sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew== +autoprefixer@^10.4.21: + version "10.4.21" + resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.21.tgz#77189468e7a8ad1d9a37fbc08efc9f480cf0a95d" + integrity sha512-O+A6LWV5LDHSJD3LjHYoNi4VLsj/Whi7k6zG12xTYaU4cQ8oxQGckXNX8cRHK5yOZ/ppVHe0ZBXGzSV9jXdVbQ== dependencies: - browserslist "^4.23.0" - caniuse-lite "^1.0.30001599" + browserslist "^4.24.4" + caniuse-lite "^1.0.30001702" fraction.js "^4.3.7" normalize-range "^0.1.2" - picocolors "^1.0.0" + picocolors "^1.1.1" postcss-value-parser "^4.2.0" available-typed-arrays@^1.0.7: @@ -3350,16 +3373,6 @@ braces@^3.0.3, braces@~3.0.2: dependencies: fill-range "^7.1.1" -browserslist@^4.23.0: - version "4.23.2" - resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.23.2.tgz#244fe803641f1c19c28c48c4b6ec9736eb3d32ed" - integrity sha512-qkqSyistMYdxAcw+CzbZwlBy8AGmS/eEWs+sEV5TnLRGDOL+C5M2EnH6tlZyg0YoAxGJAFKh61En9BR941GnHA== - dependencies: - caniuse-lite "^1.0.30001640" - electron-to-chromium "^1.4.820" - node-releases "^2.0.14" - update-browserslist-db "^1.1.0" - browserslist@^4.24.0, browserslist@^4.24.4: version "4.24.4" resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.24.4.tgz#c6b2865a3f08bcb860a0e827389003b9fe686e4b" @@ -3401,10 +3414,10 @@ builder-util-runtime@9.3.1: debug "^4.3.4" sax "^1.2.4" -builder-util@26.0.7: - version "26.0.7" - resolved "https://registry.yarnpkg.com/builder-util/-/builder-util-26.0.7.tgz#ca420095038d30bd60c4bb1bc3c6879334b0f6cd" - integrity sha512-rZL8wTMtpAM8CZO4l6eIM36oie95LP7de4nEp7ZhQ94JsL7kKT4orPwp6weRzxldXPzNyalUPkhCxJcFDanFIg== +builder-util@26.0.11: + version "26.0.11" + resolved "https://registry.yarnpkg.com/builder-util/-/builder-util-26.0.11.tgz#ad85b92c93f2b976b973e1d87337e0c6813fcb8f" + integrity sha512-xNjXfsldUEe153h1DraD0XvDOpqGR0L5eKFkdReB7eFW5HqysDZFfly4rckda6y9dF39N3pkPlOblcfHKGw+uA== dependencies: "7zip-bin" "~5.2.0" "@types/debug" "^4.1.6" @@ -3523,15 +3536,10 @@ camelcase-css@^2.0.1: resolved "https://registry.yarnpkg.com/camelcase-css/-/camelcase-css-2.0.1.tgz#ee978f6947914cc30c6b44741b6ed1df7f043fd5" integrity sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA== -caniuse-lite@^1.0.30001599, caniuse-lite@^1.0.30001640: - version "1.0.30001646" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001646.tgz#d472f2882259ba032dd73ee069ff01bfd059b25d" - integrity sha512-dRg00gudiBDDTmUhClSdv3hqRfpbOnU28IpI1T6PBTLWa+kOj0681C8uML3PifYfREuBrVjDGhL3adYpBT6spw== - -caniuse-lite@^1.0.30001688: - version "1.0.30001705" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001705.tgz#dc3510bcdef261444ca944b7be9c8d0bb7fafeef" - integrity sha512-S0uyMMiYvA7CxNgomYBwwwPUnWzFD83f3B1ce5jHUfHTH//QL6hHsreI8RVC5606R4ssqravelYO5TU6t8sEyg== +caniuse-lite@^1.0.30001688, caniuse-lite@^1.0.30001702: + version "1.0.30001707" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001707.tgz#c5e104d199e6f4355a898fcd995a066c7eb9bf41" + integrity sha512-3qtRjw/HQSMlDWf+X79N206fepf4SOOU6SQLMaq/0KkZLmSjPxAkBOQQ+FxbHKfHmYLZFfdWsO3KA90ceHPSnw== chai@^4.3.10: version "4.5.0" @@ -3593,10 +3601,10 @@ chokidar@^3.5.3, chokidar@^3.6.0: optionalDependencies: fsevents "~2.3.2" -chokidar@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-4.0.1.tgz#4a6dff66798fb0f72a94f616abbd7e1a19f31d41" - integrity sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA== +chokidar@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-4.0.3.tgz#7be37a4c03c9aee1ecfe862a4a23b2c70c205d30" + integrity sha512-Qgzu8kfBvo+cA4962jnP1KkS6Dop5NS6g7R5LFYJr4b8Ub94PPQXUksCw9PvXoeXPRRddRNC5C1JQUR2SMGtnA== dependencies: readdirp "^4.0.1" @@ -4124,13 +4132,13 @@ dlv@^1.1.3: resolved "https://registry.yarnpkg.com/dlv/-/dlv-1.1.3.tgz#5c198a8a11453596e751494d49874bc7732f2e79" integrity sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA== -dmg-builder@26.0.7: - version "26.0.7" - resolved "https://registry.yarnpkg.com/dmg-builder/-/dmg-builder-26.0.7.tgz#f1a2d7dcfd7cfdc143cabdaf78e9f94df9ce98a3" - integrity sha512-fsMjG/TmwcC7HzjSNi+3mlEUgo0RrWwq44VB9XKcGtTPPfqfSi3JvhWCCsAWzElZ0OtSO/DnK/TNgSqyaG/Ajw== +dmg-builder@26.0.12: + version "26.0.12" + resolved "https://registry.yarnpkg.com/dmg-builder/-/dmg-builder-26.0.12.tgz#6996ad0bab80a861c9a7b33ee9734d4f60566b46" + integrity sha512-59CAAjAhTaIMCN8y9kD573vDkxbs1uhDcrFLHSgutYdPcGOU35Rf95725snvzEOy4BFB7+eLJ8djCNPmGwG67w== dependencies: - app-builder-lib "26.0.7" - builder-util "26.0.7" + app-builder-lib "26.0.12" + builder-util "26.0.11" builder-util-runtime "9.3.1" fs-extra "^10.1.0" iconv-lite "^0.6.2" @@ -4221,29 +4229,29 @@ ejs@^3.1.8: dependencies: jake "^10.8.5" -electron-builder@^26.0.6: - version "26.0.7" - resolved "https://registry.yarnpkg.com/electron-builder/-/electron-builder-26.0.7.tgz#4f6724f41735b919514cd1b7462be7eb2d37078a" - integrity sha512-nVSaWw3dMLGGLrI/7WSifYzNGNseIpvmFwBRwi2E8tOUkcqN+em+3qYeRq8k/AYHRDcrmj6UCJJT6rBo+bikfw== +electron-builder@^26.0.12: + version "26.0.12" + resolved "https://registry.yarnpkg.com/electron-builder/-/electron-builder-26.0.12.tgz#797af2e70efdd96c9ea5d8a8164b8728c90d65ff" + integrity sha512-cD1kz5g2sgPTMFHjLxfMjUK5JABq3//J4jPswi93tOPFz6btzXYtK5NrDt717NRbukCUDOrrvmYVOWERlqoiXA== dependencies: - app-builder-lib "26.0.7" - builder-util "26.0.7" + app-builder-lib "26.0.12" + builder-util "26.0.11" builder-util-runtime "9.3.1" chalk "^4.1.2" - dmg-builder "26.0.7" + dmg-builder "26.0.12" fs-extra "^10.1.0" is-ci "^3.0.0" lazy-val "^1.0.5" simple-update-notifier "2.0.0" yargs "^17.6.2" -electron-publish@26.0.7: - version "26.0.7" - resolved "https://registry.yarnpkg.com/electron-publish/-/electron-publish-26.0.7.tgz#b16cd31122233c228c4459cc7ab8dc25c67b6cb3" - integrity sha512-zSCBtAXnLi1QhCDEomIEu22mjKgsf17VYW3fMyZ4Y9Q7s+Ftu9dqbTMaM/e/FBCn9VthnG7C/zPCr1yKpkI+dg== +electron-publish@26.0.11: + version "26.0.11" + resolved "https://registry.yarnpkg.com/electron-publish/-/electron-publish-26.0.11.tgz#92c9329a101af2836d9d228c82966eca1eee9a7b" + integrity sha512-a8QRH0rAPIWH9WyyS5LbNvW9Ark6qe63/LqDB7vu2JXYpi0Gma5Q60Dh4tmTqhOBQt0xsrzD8qE7C+D7j+B24A== dependencies: "@types/fs-extra" "^9.0.11" - builder-util "26.0.7" + builder-util "26.0.11" builder-util-runtime "9.3.1" chalk "^4.1.2" form-data "^4.0.0" @@ -4251,20 +4259,15 @@ electron-publish@26.0.7: lazy-val "^1.0.5" mime "^2.5.2" -electron-to-chromium@^1.4.820: - version "1.5.4" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.4.tgz#cd477c830dd6fca41fbd5465c1ff6ce08ac22343" - integrity sha512-orzA81VqLyIGUEA77YkVA1D+N+nNfl2isJVjjmOyrlxuooZ19ynb+dOlaDTqd/idKRS9lDCSBmtzM+kyCsMnkA== - electron-to-chromium@^1.5.73: version "1.5.119" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.119.tgz#4e105e419209b33e1c44b4d1b5fc6fb27fac0209" integrity sha512-Ku4NMzUjz3e3Vweh7PhApPrZSS4fyiCIbcIrG9eKrriYVLmbMepETR/v6SU7xPm98QTqMSYiCwfO89QNjXLkbQ== -electron-updater@^6.6.0: - version "6.6.0" - resolved "https://registry.yarnpkg.com/electron-updater/-/electron-updater-6.6.0.tgz#0fa8c08f301cb95065284c61b27023c19c7f37f8" - integrity sha512-+aa4P73EU94yYetJOmf2+22ZCrQ3MA4C5HWqFbV1XdSSv2B82lzEg/IZyQw+H5ziUn8V7jrU+AP4zJPdxD74fg== +electron-updater@^6.6.2: + version "6.6.2" + resolved "https://registry.yarnpkg.com/electron-updater/-/electron-updater-6.6.2.tgz#3e65e044f1a99b00d61e200e24de8e709c69ce99" + integrity sha512-Cr4GDOkbAUqRHP5/oeOmH/L2Bn6+FQPxVLZtPbcmKZC63a1F3uu5EefYOssgZXG3u/zBlubbJ5PJdITdMVggbw== dependencies: builder-util-runtime "9.3.1" fs-extra "^10.1.0" @@ -4577,7 +4580,7 @@ esbuild@^0.21.3: "@esbuild/win32-ia32" "0.21.5" "@esbuild/win32-x64" "0.21.5" -escalade@^3.1.1, escalade@^3.1.2: +escalade@^3.1.1: version "3.1.2" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.2.tgz#54076e9ab29ea5bf3d8f1ed62acffbb88272df27" integrity sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA== @@ -6994,11 +6997,6 @@ node-fetch@^3.3.2: fetch-blob "^3.1.4" formdata-polyfill "^4.0.10" -node-releases@^2.0.14: - version "2.0.18" - resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.18.tgz#f010e8d35e2fe8d6b2944f03f70213ecedc4ca3f" - integrity sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g== - node-releases@^2.0.19: version "2.0.19" resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.19.tgz#9e445a52950951ec4d177d843af370b411caf314" @@ -7419,7 +7417,7 @@ pend@~1.2.0: resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" integrity sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg== -picocolors@^1.0.0, picocolors@^1.0.1, picocolors@^1.1.1: +picocolors@^1.0.0, picocolors@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.1.1.tgz#3d321af3eab939b083c8f929a1d12cda81c26b6b" integrity sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA== @@ -7455,21 +7453,21 @@ pkg-types@^1.0.3, pkg-types@^1.1.1: mlly "^1.7.1" pathe "^1.1.2" -playwright-core@1.51.0: - version "1.51.0" - resolved "https://registry.yarnpkg.com/playwright-core/-/playwright-core-1.51.0.tgz#bb23ea6bb6298242d088ae5e966ffcf8dc9827e8" - integrity sha512-x47yPE3Zwhlil7wlNU/iktF7t2r/URR3VLbH6EknJd/04Qc/PSJ0EY3CMXipmglLG+zyRxW6HNo2EGbKLHPWMg== +playwright-core@1.51.1: + version "1.51.1" + resolved "https://registry.yarnpkg.com/playwright-core/-/playwright-core-1.51.1.tgz#d57f0393e02416f32a47cf82b27533656a8acce1" + integrity sha512-/crRMj8+j/Nq5s8QcvegseuyeZPxpQCZb6HNk3Sos3BlZyAknRjoyJPFWkpNn8v0+P3WiwqFF8P+zQo4eqiNuw== -playwright@1.51.0: - version "1.51.0" - resolved "https://registry.yarnpkg.com/playwright/-/playwright-1.51.0.tgz#9ba154497ba62bc6dc199c58ee19295eb35a4707" - integrity sha512-442pTfGM0xxfCYxuBa/Pu6B2OqxqqaYq39JS8QDMGThUvIOCd6s0ANDog3uwA0cHavVlnTQzGCN7Id2YekDSXA== +playwright@1.51.1: + version "1.51.1" + resolved "https://registry.yarnpkg.com/playwright/-/playwright-1.51.1.tgz#ae1467ee318083968ad28d6990db59f47a55390f" + integrity sha512-kkx+MB2KQRkyxjYPc3a0wLZZoDczmppyGJIvQ43l+aZihkaVvmu/21kiyaHeHjiFxjxNNFnUncKmcGIyOojsaw== dependencies: - playwright-core "1.51.0" + playwright-core "1.51.1" optionalDependencies: fsevents "2.3.2" -plist@^3.0.0, plist@^3.0.4, plist@^3.0.5, plist@^3.1.0: +plist@3.1.0, plist@^3.0.0, plist@^3.0.4, plist@^3.0.5, plist@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/plist/-/plist-3.1.0.tgz#797a516a93e62f5bde55e0b9cc9c967f860893c9" integrity sha512-uysumyrvkUX0rX/dEVqt8gC3sTBzd4zoWfLeS29nb53imdaXVvLINYXTI2GNqzaMuvacNx4uJQ8+b3zXR0pkgQ== @@ -9260,14 +9258,6 @@ unpipe@1.0.0, unpipe@~1.0.0: resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== -update-browserslist-db@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz#7ca61c0d8650766090728046e416a8cde682859e" - integrity sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ== - dependencies: - escalade "^3.1.2" - picocolors "^1.0.1" - update-browserslist-db@^1.1.1: version "1.1.3" resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz#348377dd245216f9e7060ff50b15a1b740b75420" @@ -9686,10 +9676,10 @@ ws@^7.4.6: resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.10.tgz#58b5c20dc281633f6c19113f39b349bd8bd558d9" integrity sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ== -ws@^8.17.0: - version "8.18.0" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.18.0.tgz#0d7505a6eafe2b0e712d232b42279f53bc289bbc" - integrity sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw== +ws@^8.18.1: + version "8.18.1" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.18.1.tgz#ea131d3784e1dfdff91adb0a4a116b127515e3cb" + integrity sha512-RKW2aJZMXeMxVpnZ6bck+RswznaxmzdULiBr6KY7XkTnW8uvt0iT9H5DkHUChXrc+uurzwa0rVI16n/Xzjdz1w== xmlbuilder@>=11.0.1, xmlbuilder@^15.1.1: version "15.1.1"