diff --git a/docs/kcl/abs.md b/docs/kcl/abs.md index 21e399c7c..49e0cd1e1 100644 --- a/docs/kcl/abs.md +++ b/docs/kcl/abs.md @@ -34,7 +34,7 @@ abs(num: number): number myAngle = -120 sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [8, 0]) |> angledLine(angle = abs(myAngle), length = 5) |> line(end = [-5, 0]) diff --git a/docs/kcl/acos.md b/docs/kcl/acos.md index 45a26465b..300415b8f 100644 --- a/docs/kcl/acos.md +++ b/docs/kcl/acos.md @@ -32,7 +32,7 @@ acos(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = toDegrees(acos(0.5)), length = 10) |> line(end = [5, 0]) |> line(endAbsolute = [12, 0]) diff --git a/docs/kcl/angleToMatchLengthX.md b/docs/kcl/angleToMatchLengthX.md index 70efebdbf..e1deaa3a8 100644 --- a/docs/kcl/angleToMatchLengthX.md +++ b/docs/kcl/angleToMatchLengthX.md @@ -34,7 +34,7 @@ angleToMatchLengthX( ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [2, 5], tag = $seg01) |> angledLine(angle = -angleToMatchLengthX(seg01, 7, %), endAbsoluteX = 10) |> close() diff --git a/docs/kcl/angleToMatchLengthY.md b/docs/kcl/angleToMatchLengthY.md index 154892d57..b40daee2a 100644 --- a/docs/kcl/angleToMatchLengthY.md +++ b/docs/kcl/angleToMatchLengthY.md @@ -34,7 +34,7 @@ angleToMatchLengthY( ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [1, 2], tag = $seg01) |> angledLine(angle = angleToMatchLengthY(seg01, 15, %), length = 5) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/angledLine.md b/docs/kcl/angledLine.md index d70629bbf..61c58102c 100644 --- a/docs/kcl/angledLine.md +++ b/docs/kcl/angledLine.md @@ -44,7 +44,7 @@ angledLine( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(endAbsolute = 15) |> angledLine(angle = 30, length = 15) |> line(end = [8, -10]) diff --git a/docs/kcl/angledLineThatIntersects.md b/docs/kcl/angledLineThatIntersects.md index 3f7a3c1b4..002a6e47a 100644 --- a/docs/kcl/angledLineThatIntersects.md +++ b/docs/kcl/angledLineThatIntersects.md @@ -38,7 +38,7 @@ angledLineThatIntersects( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [5, 10]) |> line(endAbsolute = [-10, 10], tag = $lineToIntersect) |> line(endAbsolute = [0, 20]) diff --git a/docs/kcl/appearance.md b/docs/kcl/appearance.md index a92ff2513..b6d1a4911 100644 --- a/docs/kcl/appearance.md +++ b/docs/kcl/appearance.md @@ -37,7 +37,7 @@ appearance( ```js // Add color to an extruded solid. exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [10, 0]) |> line(endAbsolute = [0, 10]) |> line(endAbsolute = [-10, 0]) @@ -64,7 +64,7 @@ sketch001 = startSketchOn(XY) // Add color to different solids. fn cube(center) { return startSketchOn(XY) - |> startProfileAt([center[0] - 10, center[1] - 10], %) + |> startProfile(at = [center[0] - 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) |> line(endAbsolute = [center[0] - 10, center[1] + 10]) @@ -96,7 +96,7 @@ appearance( // You can set the appearance before or after you shell it will yield the same result. // This example shows setting the appearance _after_ the shell. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -113,7 +113,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) // You can set the appearance before or after you shell it will yield the same result. // This example shows setting the appearance _before_ the shell. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -130,7 +130,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. // This example shows _before_ the pattern. exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) @@ -147,7 +147,7 @@ example = extrude(exampleSketch, length = 1) // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. // This example shows _after_ the pattern. exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) @@ -163,7 +163,7 @@ example = extrude(exampleSketch, length = 1) ```js // Color the result of a 2D pattern that was extruded. exampleSketch = startSketchOn(XZ) - |> startProfileAt([.5, 25], %) + |> startProfile(at = [.5, 25]) |> line(end = [0, 5]) |> line(end = [-1, 0]) |> line(end = [0, -5]) @@ -186,7 +186,7 @@ example = extrude(exampleSketch, length = 1) // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) diff --git a/docs/kcl/arc.md b/docs/kcl/arc.md index 6252581bc..2f2a2136f 100644 --- a/docs/kcl/arc.md +++ b/docs/kcl/arc.md @@ -44,7 +44,7 @@ arc( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> arc(angleStart = 0, angleEnd = 280, radius = 16) |> close() @@ -55,7 +55,7 @@ example = extrude(exampleSketch, length = 10) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> arc(endAbsolute = [10, 0], interiorAbsolute = [5, 5]) |> close() example = extrude(exampleSketch, length = 10) diff --git a/docs/kcl/asin.md b/docs/kcl/asin.md index 2ceeab762..f33607297 100644 --- a/docs/kcl/asin.md +++ b/docs/kcl/asin.md @@ -32,7 +32,7 @@ asin(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = toDegrees(asin(0.5)), length = 20) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/atan.md b/docs/kcl/atan.md index ae16b2221..cc8a9234b 100644 --- a/docs/kcl/atan.md +++ b/docs/kcl/atan.md @@ -32,7 +32,7 @@ atan(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = toDegrees(atan(1.25)), length = 20) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/atan2.md b/docs/kcl/atan2.md index 1a31c08c4..cbc19b23a 100644 --- a/docs/kcl/atan2.md +++ b/docs/kcl/atan2.md @@ -36,7 +36,7 @@ atan2( ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = toDegrees(atan2(y = 1.25, x = 2)), length = 20) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/bezierCurve.md b/docs/kcl/bezierCurve.md index 1665f1ac0..0fee6d023 100644 --- a/docs/kcl/bezierCurve.md +++ b/docs/kcl/bezierCurve.md @@ -38,7 +38,7 @@ bezierCurve( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> bezierCurve(control1 = [5, 0], control2 = [5, 10], end = [10, 10]) |> line(endAbsolute = [10, 0]) diff --git a/docs/kcl/ceil.md b/docs/kcl/ceil.md index 75fa09657..47807dae5 100644 --- a/docs/kcl/ceil.md +++ b/docs/kcl/ceil.md @@ -32,7 +32,7 @@ ceil(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [12, 10]) |> line(end = [ceil(7.02986), 0]) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/chamfer.md b/docs/kcl/chamfer.md index e7552be83..699a53559 100644 --- a/docs/kcl/chamfer.md +++ b/docs/kcl/chamfer.md @@ -42,7 +42,7 @@ thickness = 1 chamferLength = 2 mountingPlateSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) @@ -66,7 +66,7 @@ mountingPlate = extrude(mountingPlateSketch, length = thickness) // Sketch on the face of a chamfer. fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -81,7 +81,7 @@ part001 = cube([0, 0], 20) |> chamfer(length = 10, tags = [getOppositeEdge(line1)], tag = $chamfer1) sketch001 = startSketchOn(part001, face = chamfer1) - |> startProfileAt([10, 10], %) + |> startProfile(at = [10, 10]) |> line(end = [2, 0]) |> line(end = [0, 2]) |> line(end = [-2, 0]) diff --git a/docs/kcl/clone.md b/docs/kcl/clone.md index 52f1248f6..38fcb6376 100644 --- a/docs/kcl/clone.md +++ b/docs/kcl/clone.md @@ -33,7 +33,7 @@ clone(geometry: GeometryWithImportedGeometry): GeometryWithImportedGeometry ```js // Clone a basic sketch and move it and extrude it. exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -52,7 +52,7 @@ clonedSketch = clone(exampleSketch) exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -70,7 +70,7 @@ clonedPart = clone(myPart) sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> xLine(length = 20) |> yLine(length = -20) |> xLine(length = -20) @@ -90,7 +90,7 @@ loft([sketch001, sketch002]) sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> xLine(length = 20) |> yLine(length = -20) |> xLine(length = -20, tag = $filletTag) @@ -109,7 +109,7 @@ sketch002 = clone(sketch001) sketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10], tag = $sketchingFace) |> line(end = [-10, 0]) @@ -120,7 +120,7 @@ sketch002 = clone(sketch001) |> extrude(length = 5) startSketchOn(sketch002, face = sketchingFace) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> line(end = [8, 0]) |> line(end = [0, 8]) |> line(end = [-8, 0]) @@ -140,7 +140,7 @@ thickness = 1 filletRadius = 2 mountingPlateSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) @@ -205,7 +205,7 @@ sketch002 = clone(sketch001) exampleSketch = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -228,7 +228,7 @@ example001 = revolve( // Sketch on the cloned face. // exampleSketch002 = startSketchOn(example002, face = end01) -// |> startProfileAt([4.5, -5], %) +// |> startProfile(at = [4.5, -5]) // |> line(end = [0, 5]) // |> line(end = [5, 0]) // |> line(end = [0, -5]) diff --git a/docs/kcl/close.md b/docs/kcl/close.md index 5d680cdcd..8ce57c07c 100644 --- a/docs/kcl/close.md +++ b/docs/kcl/close.md @@ -32,7 +32,7 @@ close( ```js startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 10]) |> line(end = [10, 0]) |> close() @@ -43,7 +43,7 @@ startSketchOn(XZ) ```js exampleSketch = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> close() diff --git a/docs/kcl/consts/std-math-E.md b/docs/kcl/consts/std-math-E.md index 636d755a8..255df2a0d 100644 --- a/docs/kcl/consts/std-math-E.md +++ b/docs/kcl/consts/std-math-E.md @@ -16,7 +16,7 @@ std::math::E: number = 2.71828182845904523536028747135266250_ ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 30, length = 2 * E ^ 2, diff --git a/docs/kcl/consts/std-math-TAU.md b/docs/kcl/consts/std-math-TAU.md index 03e09365c..521edbe3f 100644 --- a/docs/kcl/consts/std-math-TAU.md +++ b/docs/kcl/consts/std-math-TAU.md @@ -16,7 +16,7 @@ std::math::TAU: number = 6.28318530717958647692528676655900577_ ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 50, length = 10 * TAU, diff --git a/docs/kcl/e.md b/docs/kcl/e.md index 1c86a2aa2..7ae401b60 100644 --- a/docs/kcl/e.md +++ b/docs/kcl/e.md @@ -29,7 +29,7 @@ e(): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 30, length = 2 * e() ^ 2) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/extrude.md b/docs/kcl/extrude.md index bd2ffde71..43250b12c 100644 --- a/docs/kcl/extrude.md +++ b/docs/kcl/extrude.md @@ -40,7 +40,7 @@ extrude( ```js example = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> arc(angleStart = 120, angleEnd = 0, radius = 5) |> line(end = [5, 0]) @@ -55,7 +55,7 @@ example = startSketchOn(XZ) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([-10, 0], %) + |> startProfile(at = [-10, 0]) |> arc(angleStart = 120, angleEnd = -60, radius = 5) |> line(end = [10, 0]) |> line(end = [5, 0]) @@ -71,7 +71,7 @@ example = extrude(exampleSketch, length = 10) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([-10, 0], %) + |> startProfile(at = [-10, 0]) |> arc(angleStart = 120, angleEnd = -60, radius = 5) |> line(end = [10, 0]) |> line(end = [5, 0]) @@ -87,7 +87,7 @@ example = extrude(exampleSketch, length = 20, symmetric = true) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([-10, 0], %) + |> startProfile(at = [-10, 0]) |> arc(angleStart = 120, angleEnd = -60, radius = 5) |> line(end = [10, 0]) |> line(end = [5, 0]) diff --git a/docs/kcl/fillet.md b/docs/kcl/fillet.md index ccc49958e..3377ac5ec 100644 --- a/docs/kcl/fillet.md +++ b/docs/kcl/fillet.md @@ -43,7 +43,7 @@ thickness = 1 filletRadius = 2 mountingPlateSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) @@ -70,7 +70,7 @@ thickness = 1 filletRadius = 1 mountingPlateSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) diff --git a/docs/kcl/floor.md b/docs/kcl/floor.md index ba23ae654..07224d361 100644 --- a/docs/kcl/floor.md +++ b/docs/kcl/floor.md @@ -32,7 +32,7 @@ floor(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [12, 10]) |> line(end = [floor(7.02986), 0]) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/getCommonEdge.md b/docs/kcl/getCommonEdge.md index 421e2b384..1390f7873 100644 --- a/docs/kcl/getCommonEdge.md +++ b/docs/kcl/getCommonEdge.md @@ -32,7 +32,7 @@ getCommonEdge(faces: [TagIdentifier]): Uuid scale = 20 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/docs/kcl/getNextAdjacentEdge.md b/docs/kcl/getNextAdjacentEdge.md index f09e1bff0..423856a6b 100644 --- a/docs/kcl/getNextAdjacentEdge.md +++ b/docs/kcl/getNextAdjacentEdge.md @@ -28,7 +28,7 @@ getNextAdjacentEdge(edge: TagIdentifier): Uuid ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = 60, length = 10) |> angledLine(angle = 120, length = 10) diff --git a/docs/kcl/getOppositeEdge.md b/docs/kcl/getOppositeEdge.md index f879fdf13..3a0014361 100644 --- a/docs/kcl/getOppositeEdge.md +++ b/docs/kcl/getOppositeEdge.md @@ -28,7 +28,7 @@ getOppositeEdge(edge: TagIdentifier): Uuid ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = 60, length = 10) |> angledLine(angle = 120, length = 10) diff --git a/docs/kcl/getPreviousAdjacentEdge.md b/docs/kcl/getPreviousAdjacentEdge.md index 75d28bcb6..dfac3c76b 100644 --- a/docs/kcl/getPreviousAdjacentEdge.md +++ b/docs/kcl/getPreviousAdjacentEdge.md @@ -28,7 +28,7 @@ getPreviousAdjacentEdge(edge: TagIdentifier): Uuid ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = 60, length = 10) |> angledLine(angle = 120, length = 10) diff --git a/docs/kcl/hole.md b/docs/kcl/hole.md index 7dd404d78..dcb940db2 100644 --- a/docs/kcl/hole.md +++ b/docs/kcl/hole.md @@ -32,7 +32,7 @@ hole( ```js exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -48,7 +48,7 @@ example = extrude(exampleSketch, length = 1) ```js fn squareHoleSketch() { squareSketch = startSketchOn(-XZ) - |> startProfileAt([-1, -1], %) + |> startProfile(at = [-1, -1]) |> line(end = [2, 0]) |> line(end = [0, 2]) |> line(end = [-2, 0]) diff --git a/docs/kcl/hollow.md b/docs/kcl/hollow.md index e39a6f118..5f7b8040c 100644 --- a/docs/kcl/hollow.md +++ b/docs/kcl/hollow.md @@ -33,7 +33,7 @@ hollow( ```js // Hollow a basic sketch. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -47,7 +47,7 @@ firstSketch = startSketchOn(XY) ```js // Hollow a basic sketch. firstSketch = startSketchOn(-XZ) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -62,7 +62,7 @@ firstSketch = startSketchOn(-XZ) // Hollow a sketch on face object. size = 100 case = startSketchOn(-XZ) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) diff --git a/docs/kcl/index.md b/docs/kcl/index.md index f8a5f6f1d..dbd0c10eb 100644 --- a/docs/kcl/index.md +++ b/docs/kcl/index.md @@ -103,7 +103,7 @@ layout: manual * [`segStartY`](kcl/segStartY) * [`shell`](kcl/shell) * [`sqrt`](kcl/sqrt) - * [`startProfileAt`](kcl/startProfileAt) + * [`startProfile`](kcl/startProfile) * [`startSketchOn`](kcl/startSketchOn) * [`subtract`](kcl/subtract) * [`sweep`](kcl/sweep) diff --git a/docs/kcl/intersect.md b/docs/kcl/intersect.md index 26c0e9c67..4f4ade569 100644 --- a/docs/kcl/intersect.md +++ b/docs/kcl/intersect.md @@ -36,7 +36,7 @@ intersect( fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -61,7 +61,7 @@ intersectedPart = intersect([part001, part002]) fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/docs/kcl/involuteCircular.md b/docs/kcl/involuteCircular.md index 72ec5516d..e29ae0a3c 100644 --- a/docs/kcl/involuteCircular.md +++ b/docs/kcl/involuteCircular.md @@ -42,7 +42,7 @@ involuteCircular( a = 10 b = 14 startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> involuteCircular(startRadius = a, endRadius = b, angle = 60) |> involuteCircular( startRadius = a, diff --git a/docs/kcl/lastSegX.md b/docs/kcl/lastSegX.md index 6c07d6a66..42b014ffb 100644 --- a/docs/kcl/lastSegX.md +++ b/docs/kcl/lastSegX.md @@ -28,7 +28,7 @@ lastSegX(sketch: Sketch): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 0]) |> line(end = [20, 5]) |> line(end = [lastSegX(%), 0]) diff --git a/docs/kcl/lastSegY.md b/docs/kcl/lastSegY.md index b03537a08..c28a294d6 100644 --- a/docs/kcl/lastSegY.md +++ b/docs/kcl/lastSegY.md @@ -28,7 +28,7 @@ lastSegY(sketch: Sketch): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 0]) |> line(end = [20, 5]) |> line(end = [0, lastSegY(%)]) diff --git a/docs/kcl/line.md b/docs/kcl/line.md index 970066a5f..a72a20d0b 100644 --- a/docs/kcl/line.md +++ b/docs/kcl/line.md @@ -36,7 +36,7 @@ line( ```js triangle = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // The END argument means it ends at exactly [10, 0]. // This is an absolute measurement, it is NOT relative to // the start of the sketch. @@ -47,7 +47,7 @@ triangle = startSketchOn(XZ) |> extrude(length = 5) box = startSketchOn(XZ) - |> startProfileAt([10, 10], %) + |> startProfile(at = [10, 10]) // The 'to' argument means move the pen this much. // So, [10, 0] is a relative distance away from the current point. |> line(end = [10, 0]) diff --git a/docs/kcl/ln.md b/docs/kcl/ln.md index dea61a80f..8b5f917bc 100644 --- a/docs/kcl/ln.md +++ b/docs/kcl/ln.md @@ -32,7 +32,7 @@ ln(num: number): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [ln(100), 15]) |> line(end = [5, -6]) |> line(end = [-10, -10]) diff --git a/docs/kcl/loft.md b/docs/kcl/loft.md index f48a36757..86b93d8c2 100644 --- a/docs/kcl/loft.md +++ b/docs/kcl/loft.md @@ -43,7 +43,7 @@ loft( ```js // Loft a square and a triangle. squareSketch = startSketchOn(XY) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -51,7 +51,7 @@ squareSketch = startSketchOn(XY) |> close() triangleSketch = startSketchOn(offsetPlane(XY, offset = 75)) - |> startProfileAt([0, 125], %) + |> startProfile(at = [0, 125]) |> line(end = [-15, -30]) |> line(end = [30, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -65,7 +65,7 @@ loft([squareSketch, triangleSketch]) ```js // Loft a square, a circle, and another circle. squareSketch = startSketchOn(XY) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -90,7 +90,7 @@ loft([ ```js // Loft a square, a circle, and another circle with options. squareSketch = startSketchOn(XY) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) diff --git a/docs/kcl/log.md b/docs/kcl/log.md index 6f0d9599e..d0a45c6a4 100644 --- a/docs/kcl/log.md +++ b/docs/kcl/log.md @@ -36,7 +36,7 @@ log( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [log(100, 5), 0]) |> line(end = [5, 8]) |> line(end = [-10, 0]) diff --git a/docs/kcl/log10.md b/docs/kcl/log10.md index c45649bd4..8703167b9 100644 --- a/docs/kcl/log10.md +++ b/docs/kcl/log10.md @@ -32,7 +32,7 @@ log10(num: number): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [log10(100), 0]) |> line(end = [5, 8]) |> line(end = [-10, 0]) diff --git a/docs/kcl/log2.md b/docs/kcl/log2.md index 302510721..7178c02bb 100644 --- a/docs/kcl/log2.md +++ b/docs/kcl/log2.md @@ -32,7 +32,7 @@ log2(num: number): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [log2(100), 0]) |> line(end = [5, 8]) |> line(end = [-10, 0]) diff --git a/docs/kcl/max.md b/docs/kcl/max.md index 2e4cb7629..990aa09aa 100644 --- a/docs/kcl/max.md +++ b/docs/kcl/max.md @@ -32,7 +32,7 @@ max(args: [number]): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 70, length = max(15, 31, 4, 13, 22)) |> line(end = [20, 0]) |> close() diff --git a/docs/kcl/min.md b/docs/kcl/min.md index efdb4daab..2a32b4605 100644 --- a/docs/kcl/min.md +++ b/docs/kcl/min.md @@ -32,7 +32,7 @@ min(args: [number]): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 70, length = min(15, 31, 4, 13, 22)) |> line(end = [20, 0]) |> close() diff --git a/docs/kcl/modules.md b/docs/kcl/modules.md index 313996aec..7cbfb5f5e 100644 --- a/docs/kcl/modules.md +++ b/docs/kcl/modules.md @@ -73,7 +73,7 @@ There are two common patterns for re‑using geometry: ```kcl fn cube(center) { return startSketchOn(XY) - |> startProfileAt([center[0] - 10, center[1] - 10], %) + |> startProfile(at = [center[0] - 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) |> line(endAbsolute = [center[0] - 10, center[1] + 10]) diff --git a/docs/kcl/offsetPlane.md b/docs/kcl/offsetPlane.md new file mode 100644 index 000000000..03964f5b3 --- /dev/null +++ b/docs/kcl/offsetPlane.md @@ -0,0 +1,121 @@ +--- +title: "offsetPlane" +excerpt: "Offset a plane by a distance along its normal." +layout: manual +--- + +Offset a plane by a distance along its normal. + +For example, if you offset the 'XZ' plane by 10, the new plane will be parallel to the 'XZ' plane and 10 units away from it. + +```js +offsetPlane( + plane: PlaneData, + offset: number, +): Plane +``` + + +### Arguments + +| Name | Type | Description | Required | +|----------|------|-------------|----------| +| `plane` | [`PlaneData`](/docs/kcl/types/PlaneData) | The plane (e.g. XY) which this new plane is created from. | Yes | +| `offset` | [`number`](/docs/kcl/types/number) | Distance from the standard plane this new plane will be created at. | Yes | + +### Returns + +[`Plane`](/docs/kcl/types/Plane) + + +### Examples + +```js +// Loft a square and a circle on the `XY` plane using offset. +squareSketch = startSketchOn(XY) + |> startProfile(at = [-100, 200]) + |> line(end = [200, 0]) + |> line(end = [0, -200]) + |> line(end = [-200, 0]) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() + +circleSketch = startSketchOn(offsetPlane(XY, offset = 150)) + |> circle(center = [0, 100], radius = 50) + +loft([squareSketch, circleSketch]) +``` + +![Rendered example of offsetPlane 0]() + +```js +// Loft a square and a circle on the `XZ` plane using offset. +squareSketch = startSketchOn(XZ) + |> startProfile(at = [-100, 200]) + |> line(end = [200, 0]) + |> line(end = [0, -200]) + |> line(end = [-200, 0]) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() + +circleSketch = startSketchOn(offsetPlane(XZ, offset = 150)) + |> circle(center = [0, 100], radius = 50) + +loft([squareSketch, circleSketch]) +``` + +![Rendered example of offsetPlane 1]() + +```js +// Loft a square and a circle on the `YZ` plane using offset. +squareSketch = startSketchOn(YZ) + |> startProfile(at = [-100, 200]) + |> line(end = [200, 0]) + |> line(end = [0, -200]) + |> line(end = [-200, 0]) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() + +circleSketch = startSketchOn(offsetPlane(YZ, offset = 150)) + |> circle(center = [0, 100], radius = 50) + +loft([squareSketch, circleSketch]) +``` + +![Rendered example of offsetPlane 2]() + +```js +// Loft a square and a circle on the `-XZ` plane using offset. +squareSketch = startSketchOn(-XZ) + |> startProfile(at = [-100, 200]) + |> line(end = [200, 0]) + |> line(end = [0, -200]) + |> line(end = [-200, 0]) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() + +circleSketch = startSketchOn(offsetPlane(-XZ, offset = -150)) + |> circle(center = [0, 100], radius = 50) + +loft([squareSketch, circleSketch]) +``` + +![Rendered example of offsetPlane 3]() + +```js +// A circle on the XY plane +startSketchOn(XY) + |> startProfile(at = [0, 0]) + |> circle(radius = 10, center = [0, 0]) + +// Triangle on the plane 4 units above +startSketchOn(offsetPlane(XY, offset = 4)) + |> startProfile(at = [0, 0]) + |> line(end = [10, 0]) + |> line(end = [0, 10]) + |> close() +``` + +![Rendered example of offsetPlane 4]() + + diff --git a/docs/kcl/patternCircular2d.md b/docs/kcl/patternCircular2d.md index 76acda360..78f9afdab 100644 --- a/docs/kcl/patternCircular2d.md +++ b/docs/kcl/patternCircular2d.md @@ -40,7 +40,7 @@ patternCircular2d( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([.5, 25], %) + |> startProfile(at = [.5, 25]) |> line(end = [0, 5]) |> line(end = [-1, 0]) |> line(end = [0, -5]) diff --git a/docs/kcl/patternLinear3d.md b/docs/kcl/patternLinear3d.md index 8d8cec6b9..cfd2258ec 100644 --- a/docs/kcl/patternLinear3d.md +++ b/docs/kcl/patternLinear3d.md @@ -38,7 +38,7 @@ patternLinear3d( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) @@ -54,7 +54,7 @@ example = extrude(exampleSketch, length = 1) // Pattern a whole sketch on face. size = 100 case = startSketchOn(XY) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) @@ -85,7 +85,7 @@ patternLinear3d( // Pattern an object on a face. size = 100 case = startSketchOn(XY) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) diff --git a/docs/kcl/patternTransform.md b/docs/kcl/patternTransform.md index c04ec1744..ca9f60c89 100644 --- a/docs/kcl/patternTransform.md +++ b/docs/kcl/patternTransform.md @@ -102,7 +102,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) @@ -140,7 +140,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) @@ -204,7 +204,7 @@ fn transform(i) { ] } startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> polygon( radius = 10, numSides = 4, diff --git a/docs/kcl/pow.md b/docs/kcl/pow.md index 410a206aa..262afdf9c 100644 --- a/docs/kcl/pow.md +++ b/docs/kcl/pow.md @@ -36,7 +36,7 @@ pow( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 50, length = pow(5, 2)) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/profileStart.md b/docs/kcl/profileStart.md index 7674019c2..0b8e93e6d 100644 --- a/docs/kcl/profileStart.md +++ b/docs/kcl/profileStart.md @@ -28,7 +28,7 @@ profileStart(profile: Sketch): [number] ```js sketch001 = startSketchOn(XY) - |> startProfileAt([5, 2], %) + |> startProfile(at = [5, 2]) |> angledLine(angle = 120, length = 50, tag = $seg01) |> angledLine(angle = segAng(seg01) + 120, length = 50) |> line(end = profileStart(%)) diff --git a/docs/kcl/profileStartX.md b/docs/kcl/profileStartX.md index 120bdbdab..573f7a1d1 100644 --- a/docs/kcl/profileStartX.md +++ b/docs/kcl/profileStartX.md @@ -28,7 +28,7 @@ profileStartX(profile: Sketch): number ```js sketch001 = startSketchOn(XY) - |> startProfileAt([5, 2], %) + |> startProfile(at = [5, 2]) |> angledLine(angle = -26.6, length = 50) |> angledLine(angle = 90, length = 50) |> angledLine(angle = 30, endAbsoluteX = profileStartX(%)) diff --git a/docs/kcl/profileStartY.md b/docs/kcl/profileStartY.md index 808fc9f0b..7766edfc9 100644 --- a/docs/kcl/profileStartY.md +++ b/docs/kcl/profileStartY.md @@ -28,7 +28,7 @@ profileStartY(profile: Sketch): number ```js sketch001 = startSketchOn(XY) - |> startProfileAt([5, 2], %) + |> startProfile(at = [5, 2]) |> angledLine(angle = -60, length = 14) |> angledLine(angle = 30, endAbsoluteY = profileStartY(%)) ``` diff --git a/docs/kcl/reduce.md b/docs/kcl/reduce.md index 72daa620d..7175fa17c 100644 --- a/docs/kcl/reduce.md +++ b/docs/kcl/reduce.md @@ -93,7 +93,7 @@ fn decagon(radius) { // Start the decagon sketch at this point. startOfDecagonSketch = startSketchOn(XY) - |> startProfileAt([cos(0) * radius, sin(0) * radius], %) + |> startProfile(at = [cos(0) * radius, sin(0) * radius]) // Use a `reduce` to draw the remaining decagon sides. // For each number in the array 1..10, run the given function, @@ -112,7 +112,7 @@ fn decagon(radius) { fn decagon(radius): stepAngle = (1/10) * TAU plane = startSketchOn('XY') - startOfDecagonSketch = startProfileAt([(cos(0)*radius), (sin(0) * radius)], plane) + startOfDecagonSketch = startProfile(plane, at = [(cos(0)*radius), (sin(0) * radius)]) // Here's the reduce part. partialDecagon = startOfDecagonSketch diff --git a/docs/kcl/rotate.md b/docs/kcl/rotate.md index 82ac771b8..778b0c70d 100644 --- a/docs/kcl/rotate.md +++ b/docs/kcl/rotate.md @@ -63,7 +63,7 @@ rotate( // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -88,7 +88,7 @@ sweepSketch = startSketchOn(XY) // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -113,7 +113,7 @@ sweepSketch = startSketchOn(XY) // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -150,7 +150,7 @@ cube sketch001 = startSketchOn(XY) -rectangleSketch = startProfileAt([-200, 23.86], sketch001) +rectangleSketch = startProfile(sketch001, at = [-200, 23.86]) |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -160,7 +160,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) sketch002 = startSketchOn(YZ) -sweepPath = startProfileAt([0, 0], sketch002) +sweepPath = startProfile(sketch002, at = [0, 0]) |> yLine(length = 231.81) |> tangentialArc(radius = 80, angle = -90) |> xLine(length = 384.93) @@ -178,7 +178,7 @@ rotate(parts, axis = [0, 0, 1.0], angle = 90) sketch001 = startSketchOn(XY) fn square() { - return startProfileAt([-10, 10], sketch001) + return startProfile(sketch001, at = [-10, 10]) |> xLine(length = 20) |> yLine(length = -20) |> xLine(length = -20) diff --git a/docs/kcl/round.md b/docs/kcl/round.md index d1b03e5d3..9d7a6f9c9 100644 --- a/docs/kcl/round.md +++ b/docs/kcl/round.md @@ -32,7 +32,7 @@ round(num: number): number ```js sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [12, 10]) |> line(end = [round(7.02986), 0]) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/scale.md b/docs/kcl/scale.md index ed3196a30..c8be9dceb 100644 --- a/docs/kcl/scale.md +++ b/docs/kcl/scale.md @@ -47,7 +47,7 @@ scale( // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -84,7 +84,7 @@ cube sketch001 = startSketchOn(XY) -rectangleSketch = startProfileAt([-200, 23.86], sketch001) +rectangleSketch = startProfile(sketch001, at = [-200, 23.86]) |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -94,7 +94,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) sketch002 = startSketchOn(YZ) -sweepPath = startProfileAt([0, 0], sketch002) +sweepPath = startProfile(sketch002, at = [0, 0]) |> yLine(length = 231.81) |> tangentialArc(radius = 80, angle = -90) |> xLine(length = 384.93) diff --git a/docs/kcl/segAng.md b/docs/kcl/segAng.md index f3a9051f5..d2a8e8d3c 100644 --- a/docs/kcl/segAng.md +++ b/docs/kcl/segAng.md @@ -28,7 +28,7 @@ segAng(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [5, 10], tag = $seg01) |> line(end = [-10, 0]) diff --git a/docs/kcl/segEnd.md b/docs/kcl/segEnd.md index a9f0925a8..f7458ba65 100644 --- a/docs/kcl/segEnd.md +++ b/docs/kcl/segEnd.md @@ -29,7 +29,7 @@ segEnd(tag: TagIdentifier): [number] ```js w = 15 cube = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [w, 0], tag = $line1) |> line(end = [0, w], tag = $line2) |> line(end = [-w, 0], tag = $line3) @@ -39,7 +39,7 @@ cube = startSketchOn(XY) fn cylinder(radius, tag) { return startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle(radius = radius, center = segEnd(tag)) |> extrude(length = radius) } diff --git a/docs/kcl/segEndX.md b/docs/kcl/segEndX.md index 01f623a77..853c8c5b6 100644 --- a/docs/kcl/segEndX.md +++ b/docs/kcl/segEndX.md @@ -28,7 +28,7 @@ segEndX(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [20, 0], tag = $thing) |> line(end = [0, 5]) |> line(end = [segEndX(thing), 0]) diff --git a/docs/kcl/segEndY.md b/docs/kcl/segEndY.md index 01788f8f0..6949947c7 100644 --- a/docs/kcl/segEndY.md +++ b/docs/kcl/segEndY.md @@ -28,7 +28,7 @@ segEndY(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [20, 0]) |> line(end = [0, 3], tag = $thing) |> line(end = [-10, 0]) diff --git a/docs/kcl/segLen.md b/docs/kcl/segLen.md index 8387ad564..a059a1ab4 100644 --- a/docs/kcl/segLen.md +++ b/docs/kcl/segLen.md @@ -28,7 +28,7 @@ segLen(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = 10, tag = $thing) |> tangentialArc(angle = -120, radius = 5) |> angledLine(angle = -60, length = segLen(thing)) diff --git a/docs/kcl/segStart.md b/docs/kcl/segStart.md index 73a4b7f04..e7ac4e07b 100644 --- a/docs/kcl/segStart.md +++ b/docs/kcl/segStart.md @@ -29,7 +29,7 @@ segStart(tag: TagIdentifier): [number] ```js w = 15 cube = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [w, 0], tag = $line1) |> line(end = [0, w], tag = $line2) |> line(end = [-w, 0], tag = $line3) @@ -39,7 +39,7 @@ cube = startSketchOn(XY) fn cylinder(radius, tag) { return startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle(radius = radius, center = segStart(tag)) |> extrude(length = radius) } diff --git a/docs/kcl/segStartX.md b/docs/kcl/segStartX.md index b897155c4..685f732ae 100644 --- a/docs/kcl/segStartX.md +++ b/docs/kcl/segStartX.md @@ -28,7 +28,7 @@ segStartX(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [20, 0], tag = $thing) |> line(end = [0, 5]) |> line(end = [20 - segStartX(thing), 0]) diff --git a/docs/kcl/segStartY.md b/docs/kcl/segStartY.md index 4e2d7d664..3056bca85 100644 --- a/docs/kcl/segStartY.md +++ b/docs/kcl/segStartY.md @@ -28,7 +28,7 @@ segStartY(tag: TagIdentifier): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [20, 0]) |> line(end = [0, 3], tag = $thing) |> line(end = [-10, 0]) diff --git a/docs/kcl/shell.md b/docs/kcl/shell.md index f0e999664..314b66f1c 100644 --- a/docs/kcl/shell.md +++ b/docs/kcl/shell.md @@ -35,7 +35,7 @@ shell( ```js // Remove the end face for the extrusion. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -51,7 +51,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) ```js // Remove the start face for the extrusion. firstSketch = startSketchOn(-XZ) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -67,7 +67,7 @@ shell(firstSketch, faces = [START], thickness = 0.25) ```js // Remove a tagged face and the end face for the extrusion. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0], tag = $myTag) @@ -83,7 +83,7 @@ shell(firstSketch, faces = [myTag], thickness = 0.25) ```js // Remove multiple faces at once. firstSketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0], tag = $myTag) @@ -100,7 +100,7 @@ shell(firstSketch, faces = [myTag, END], thickness = 0.25) // Shell a sketch on face. size = 100 case = startSketchOn(-XZ) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) @@ -125,7 +125,7 @@ shell(case, faces = [START], thickness = 5) // Shell a sketch on face object on the end face. size = 100 case = startSketchOn(XY) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) @@ -153,7 +153,7 @@ shell(thing1, faces = [END], thickness = 5) size = 100 case = startSketchOn(XY) - |> startProfileAt([-size, -size], %) + |> startProfile(at = [-size, -size]) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) |> tangentialArc(endAbsolute = [-size, size]) diff --git a/docs/kcl/sqrt.md b/docs/kcl/sqrt.md index 81d05b9e0..8bba0f94a 100644 --- a/docs/kcl/sqrt.md +++ b/docs/kcl/sqrt.md @@ -32,7 +32,7 @@ sqrt(num: number): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 50, length = sqrt(2500)) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/startProfile.md b/docs/kcl/startProfile.md new file mode 100644 index 000000000..dc5291ec6 --- /dev/null +++ b/docs/kcl/startProfile.md @@ -0,0 +1,74 @@ +--- +title: "startProfile" +excerpt: "Start a new profile at a given point." +layout: manual +--- + +Start a new profile at a given point. + + + +```js +startProfile( + sketchSurface: SketchSurface, + at: [number], + tag?: TagDeclarator, +): Sketch +``` + + +### Arguments + +| Name | Type | Description | Required | +|----------|------|-------------|----------| +| `sketchSurface` | [`SketchSurface`](/docs/kcl/types/SketchSurface) | What to start the profile on | Yes | +| `at` | [`[number]`](/docs/kcl/types/number) | Where to start the profile. An absolute point. | Yes | +| [`tag`](/docs/kcl/types/tag) | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Tag this first starting point | No | + +### Returns + +[`Sketch`](/docs/kcl/types/Sketch) + + +### Examples + +```js +exampleSketch = startSketchOn(XZ) + |> startProfile(at = [0, 0]) + |> line(end = [10, 0]) + |> line(end = [0, 10]) + |> line(end = [-10, 0]) + |> close() + +example = extrude(exampleSketch, length = 5) +``` + +![Rendered example of startProfile 0]() + +```js +exampleSketch = startSketchOn(-XZ) + |> startProfile(at = [10, 10]) + |> line(end = [10, 0]) + |> line(end = [0, 10]) + |> line(end = [-10, 0]) + |> close() + +example = extrude(exampleSketch, length = 5) +``` + +![Rendered example of startProfile 1]() + +```js +exampleSketch = startSketchOn(-XZ) + |> startProfile(at = [-10, 23]) + |> line(end = [10, 0]) + |> line(end = [0, 10]) + |> line(end = [-10, 0]) + |> close() + +example = extrude(exampleSketch, length = 5) +``` + +![Rendered example of startProfile 2]() + + diff --git a/docs/kcl/startProfileAt.md b/docs/kcl/startProfileAt.md deleted file mode 100644 index 6bff891f9..000000000 --- a/docs/kcl/startProfileAt.md +++ /dev/null @@ -1,74 +0,0 @@ ---- -title: "startProfileAt" -excerpt: "Start a new profile at a given point." -layout: manual ---- - -Start a new profile at a given point. - - - -```js -startProfileAt( - to: [number], - sketchSurface: SketchSurface, - tag?: TagDeclarator, -): Sketch -``` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `to` | [`[number]`](/docs/kcl/types/number) | | Yes | -| `sketchSurface` | [`SketchSurface`](/docs/kcl/types/SketchSurface) | A sketch type. | Yes | -| [`tag`](/docs/kcl/types/tag) | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | | No | - -### Returns - -[`Sketch`](/docs/kcl/types/Sketch) - - -### Examples - -```js -exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) - |> line(end = [10, 0]) - |> line(end = [0, 10]) - |> line(end = [-10, 0]) - |> close() - -example = extrude(exampleSketch, length = 5) -``` - -![Rendered example of startProfileAt 0]() - -```js -exampleSketch = startSketchOn(-XZ) - |> startProfileAt([10, 10], %) - |> line(end = [10, 0]) - |> line(end = [0, 10]) - |> line(end = [-10, 0]) - |> close() - -example = extrude(exampleSketch, length = 5) -``` - -![Rendered example of startProfileAt 1]() - -```js -exampleSketch = startSketchOn(-XZ) - |> startProfileAt([-10, 23], %) - |> line(end = [10, 0]) - |> line(end = [0, 10]) - |> line(end = [-10, 0]) - |> close() - -example = extrude(exampleSketch, length = 5) -``` - -![Rendered example of startProfileAt 2]() - - diff --git a/docs/kcl/startSketchOn.md b/docs/kcl/startSketchOn.md index 5de8dac39..39f9ec281 100644 --- a/docs/kcl/startSketchOn.md +++ b/docs/kcl/startSketchOn.md @@ -40,7 +40,7 @@ startSketchOn( ```js exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -49,7 +49,7 @@ exampleSketch = startSketchOn(XY) example = extrude(exampleSketch, length = 5) exampleSketch002 = startSketchOn(example, face = END) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> line(end = [8, 0]) |> line(end = [0, 8]) |> line(end = [-8, 0]) @@ -58,7 +58,7 @@ exampleSketch002 = startSketchOn(example, face = END) example002 = extrude(exampleSketch002, length = 5) exampleSketch003 = startSketchOn(example002, face = END) - |> startProfileAt([2, 2], %) + |> startProfile(at = [2, 2]) |> line(end = [6, 0]) |> line(end = [0, 6]) |> line(end = [-6, 0]) @@ -74,7 +74,7 @@ example003 = extrude(exampleSketch003, length = 5) exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -83,7 +83,7 @@ exampleSketch = startSketchOn(XY) example = extrude(exampleSketch, length = 5, tagEnd = $end01) exampleSketch002 = startSketchOn(example, face = end01) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> line(end = [8, 0]) |> line(end = [0, 8]) |> line(end = [-8, 0]) @@ -92,7 +92,7 @@ exampleSketch002 = startSketchOn(example, face = end01) example002 = extrude(exampleSketch002, length = 5, tagEnd = $end02) exampleSketch003 = startSketchOn(example002, face = end02) - |> startProfileAt([2, 2], %) + |> startProfile(at = [2, 2]) |> line(end = [6, 0]) |> line(end = [0, 6]) |> line(end = [-6, 0]) @@ -105,7 +105,7 @@ example003 = extrude(exampleSketch003, length = 5) ```js exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10], tag = $sketchingFace) |> line(end = [-10, 0]) @@ -114,7 +114,7 @@ exampleSketch = startSketchOn(XY) example = extrude(exampleSketch, length = 10) exampleSketch002 = startSketchOn(example, face = sketchingFace) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> line(end = [8, 0]) |> line(end = [0, 8]) |> line(end = [-8, 0]) @@ -123,7 +123,7 @@ exampleSketch002 = startSketchOn(example, face = sketchingFace) example002 = extrude(exampleSketch002, length = 10) exampleSketch003 = startSketchOn(example002, face = sketchingFace002) - |> startProfileAt([-8, 12], %) + |> startProfile(at = [-8, 12]) |> line(end = [0, 6]) |> line(end = [6, 0]) |> line(end = [0, -6]) @@ -136,7 +136,7 @@ example003 = extrude(exampleSketch003, length = 5) ```js exampleSketch = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -149,7 +149,7 @@ exampleSketch = startSketchOn(XY) example = revolve(exampleSketch, axis = Y, angle = 180) exampleSketch002 = startSketchOn(example, face = END) - |> startProfileAt([4.5, -5], %) + |> startProfile(at = [4.5, -5]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -165,7 +165,7 @@ example002 = extrude(exampleSketch002, length = 5) exampleSketch = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -183,7 +183,7 @@ example = revolve( ) exampleSketch002 = startSketchOn(example, face = end01) - |> startProfileAt([4.5, -5], %) + |> startProfile(at = [4.5, -5]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -201,7 +201,7 @@ a1 = startSketchOn({ yAxis = { x = 0, y = 1, z = 0 }, zAxis = { x = 0, y = 0, z = 1 } }) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [100.0, 0]) |> yLine(length = -100.0) |> xLine(length = -100.0) diff --git a/docs/kcl/std-helix.md b/docs/kcl/std-helix.md index 8924150e9..fd0058632 100644 --- a/docs/kcl/std-helix.md +++ b/docs/kcl/std-helix.md @@ -62,7 +62,7 @@ springSketch = startSketchOn(YZ) ```js // Create a helix around an edge. helper001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $edge001) helixPath = helix( diff --git a/docs/kcl/std-math-cos.md b/docs/kcl/std-math-cos.md index b66777c18..01bb55d08 100644 --- a/docs/kcl/std-math-cos.md +++ b/docs/kcl/std-math-cos.md @@ -28,7 +28,7 @@ cos(@num: number(Angle)): number(_) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 30, length = 3 / cos(30deg), diff --git a/docs/kcl/std-math-polar.md b/docs/kcl/std-math-polar.md index 007847eb7..fc6d4d1d6 100644 --- a/docs/kcl/std-math-polar.md +++ b/docs/kcl/std-math-polar.md @@ -33,7 +33,7 @@ polar( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = polar(angle = 30, length = 5), tag = $thing) |> line(end = [0, 5]) |> line(end = [segEndX(thing), 0]) diff --git a/docs/kcl/std-math-sin.md b/docs/kcl/std-math-sin.md index f152443be..56cdaaacd 100644 --- a/docs/kcl/std-math-sin.md +++ b/docs/kcl/std-math-sin.md @@ -28,7 +28,7 @@ sin(@num: number(Angle)): number(_) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 50, length = 15 / sin(135deg), diff --git a/docs/kcl/std-math-tan.md b/docs/kcl/std-math-tan.md index b684285fe..cc7e90f26 100644 --- a/docs/kcl/std-math-tan.md +++ b/docs/kcl/std-math-tan.md @@ -28,7 +28,7 @@ tan(@num: number(Angle)): number(_) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 50, length = 50 * tan((1/2): number(rad)), diff --git a/docs/kcl/std-offsetPlane.md b/docs/kcl/std-offsetPlane.md index 4187950db..820e6be25 100644 --- a/docs/kcl/std-offsetPlane.md +++ b/docs/kcl/std-offsetPlane.md @@ -34,7 +34,7 @@ offsetPlane( ```js // Loft a square and a circle on the `XY` plane using offset. squareSketch = startSketchOn(XY) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -52,7 +52,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `XZ` plane using offset. squareSketch = startSketchOn(XZ) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -70,7 +70,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `YZ` plane using offset. squareSketch = startSketchOn(YZ) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -88,7 +88,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `-XZ` plane using offset. squareSketch = startSketchOn(-XZ) - |> startProfileAt([-100, 200], %) + |> startProfile(at = [-100, 200]) |> line(end = [200, 0]) |> line(end = [0, -200]) |> line(end = [-200, 0]) @@ -106,12 +106,12 @@ loft([squareSketch, circleSketch]) ```js // A circle on the XY plane startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle( radius = 10, center = [0, 0] ) // Triangle on the plane 4 units above startSketchOn(offsetPlane(XY, offset = 4)) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> close() diff --git a/docs/kcl/std-revolve.md b/docs/kcl/std-revolve.md index 9e2d51dcb..eca37c700 100644 --- a/docs/kcl/std-revolve.md +++ b/docs/kcl/std-revolve.md @@ -53,7 +53,7 @@ revolve( ```js part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -81,7 +81,7 @@ sketch001 = startSketchOn(XY) ```js part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -97,7 +97,7 @@ part001 = startSketchOn(XY) ```js part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -109,7 +109,7 @@ part001 = startSketchOn(XY) |> revolve(axis = Y, angle = 180) part002 = startSketchOn(part001, face = END) - |> startProfileAt([4.5, -5], %) + |> startProfile(at = [4.5, -5]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -121,7 +121,7 @@ part002 = startSketchOn(part001, face = END) ```js box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -140,7 +140,7 @@ sketch001 = startSketchOn(box, face = END) ```js box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $revolveAxis) @@ -159,7 +159,7 @@ sketch001 = startSketchOn(box, face = END) ```js box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $revolveAxis) @@ -179,7 +179,7 @@ sketch001 = startSketchOn(box, face = END) ```js sketch001 = startSketchOn(XY) - |> startProfileAt([10, 0], %) + |> startProfile(at = [10, 0]) |> line(end = [5, -5]) |> line(end = [5, 5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -200,14 +200,14 @@ part001 = revolve( // Revolve two sketches around the same axis. sketch001 = startSketchOn(XY) -profile001 = startProfileAt([4, 8], sketch001) +profile001 = startProfile(sketch001, at = [4, 8]) |> xLine(length = 3) |> yLine(length = -3) |> xLine(length = -3) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile002 = startProfileAt([-5, 8], sketch001) +profile002 = startProfile(sketch001, at = [-5, 8]) |> xLine(length = 3) |> yLine(length = -3) |> xLine(length = -3) @@ -226,7 +226,7 @@ revolve( // Revolve around a path that has not been extruded. profile001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -243,7 +243,7 @@ sketch001 = startSketchOn(XY) // Revolve around a path that has not been extruded or closed. profile001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) @@ -258,7 +258,7 @@ sketch001 = startSketchOn(XY) // Symmetrically revolve around a path. profile001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) @@ -273,7 +273,7 @@ sketch001 = startSketchOn(XY) // Bidirectional revolve around a path. profile001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) diff --git a/docs/kcl/std-sketch-circle.md b/docs/kcl/std-sketch-circle.md index 6999cbaf9..9c47159ee 100644 --- a/docs/kcl/std-sketch-circle.md +++ b/docs/kcl/std-sketch-circle.md @@ -46,7 +46,7 @@ example = extrude(exampleSketch, length = 5) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([-15, 0], %) + |> startProfile(at = [-15, 0]) |> line(end = [30, 0]) |> line(end = [0, 30]) |> line(end = [-30, 0]) diff --git a/docs/kcl/std-sketch-mirror2d.md b/docs/kcl/std-sketch-mirror2d.md index 7055b6a67..966816aaa 100644 --- a/docs/kcl/std-sketch-mirror2d.md +++ b/docs/kcl/std-sketch-mirror2d.md @@ -35,7 +35,7 @@ mirror2d( ```js // Mirror an un-closed sketch across the Y axis. sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 10], %) + |> startProfile(at = [0, 10]) |> line(end = [15, 0]) |> line(end = [-7, -3]) |> line(end = [9, -1]) @@ -54,7 +54,7 @@ example = extrude(sketch001, length = 10) ```js // Mirror a un-closed sketch across the Y axis. sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 8.5], %) + |> startProfile(at = [0, 8.5]) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) |> mirror2d(axis = Y) @@ -67,11 +67,11 @@ example = extrude(sketch001, length = 10) ```js // Mirror a un-closed sketch across an edge. helper001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $edge001) sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 8.5], %) + |> startProfile(at = [0, 8.5]) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) |> mirror2d(axis = edge001) @@ -84,7 +84,7 @@ sketch001 = startSketchOn(XZ) ```js // Mirror an un-closed sketch across a custom axis. sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 8.5], %) + |> startProfile(at = [0, 8.5]) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) |> mirror2d( @@ -101,7 +101,7 @@ example = extrude(sketch001, length = 10) ```js // Sketch on the face of a mirrored sketch, that has been extruded. sketch0011 = startSketchOn(XY) - |> startProfileAt([6.77, 0], %) + |> startProfile(at = [6.77, 0]) |> yLine(length = 1.27) |> tangentialArc(endAbsolute = [5.96, 2.37]) |> tangentialArc(endAbsolute = [-6.2, 2.44]) diff --git a/docs/kcl/std-toDegrees.md b/docs/kcl/std-toDegrees.md index c8c95b878..53a7d393f 100644 --- a/docs/kcl/std-toDegrees.md +++ b/docs/kcl/std-toDegrees.md @@ -28,7 +28,7 @@ toDegrees(@num: number(deg)): number(deg) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 50, length = 70 * cos(toDegrees((PI/4): number(rad))), diff --git a/docs/kcl/std-toRadians.md b/docs/kcl/std-toRadians.md index 8301d00d4..6a2164b84 100644 --- a/docs/kcl/std-toRadians.md +++ b/docs/kcl/std-toRadians.md @@ -28,7 +28,7 @@ toRadians(@num: number(rad)): number(rad) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine( angle = 50, length = 70 * cos(toRadians(45)), diff --git a/docs/kcl/std.json b/docs/kcl/std.json index 172043112..6f87323c6 100644 --- a/docs/kcl/std.json +++ b/docs/kcl/std.json @@ -38,7 +38,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "myAngle = -120\n\nsketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [8, 0])\n |> angledLine(angle = abs(myAngle), length = 5)\n |> line(end = [-5, 0])\n |> angledLine(angle = myAngle, length = 5)\n |> close()\n\nbaseExtrusion = extrude(sketch001, length = 5)" + "myAngle = -120\n\nsketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [8, 0])\n |> angledLine(angle = abs(myAngle), length = 5)\n |> line(end = [-5, 0])\n |> angledLine(angle = myAngle, length = 5)\n |> close()\n\nbaseExtrusion = extrude(sketch001, length = 5)" ] }, { @@ -80,7 +80,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = toDegrees(acos(0.5)), length = 10)\n |> line(end = [5, 0])\n |> line(endAbsolute = [12, 0])\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = toDegrees(acos(0.5)), length = 10)\n |> line(end = [5, 0])\n |> line(endAbsolute = [12, 0])\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -14676,7 +14676,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> yLine(endAbsolute = 15)\n |> angledLine(angle = 30, length = 15)\n |> line(end = [8, -10])\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> yLine(endAbsolute = 15)\n |> angledLine(angle = 30, length = 15)\n |> line(end = [8, -10])\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -24452,7 +24452,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(endAbsolute = [5, 10])\n |> line(endAbsolute = [-10, 10], tag = $lineToIntersect)\n |> line(endAbsolute = [0, 20])\n |> angledLineThatIntersects(angle = 80, intersectTag = lineToIntersect, offset = 10)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(endAbsolute = [5, 10])\n |> line(endAbsolute = [-10, 10], tag = $lineToIntersect)\n |> line(endAbsolute = [0, 20])\n |> angledLineThatIntersects(angle = 80, intersectTag = lineToIntersect, offset = 10)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -32589,15 +32589,15 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Add color to an extruded solid.\nexampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(endAbsolute = [10, 0])\n |> line(endAbsolute = [0, 10])\n |> line(endAbsolute = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n // There are other options besides 'color', but they're optional.\n |> appearance(color = '#ff0000')", + "// Add color to an extruded solid.\nexampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(endAbsolute = [10, 0])\n |> line(endAbsolute = [0, 10])\n |> line(endAbsolute = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n // There are other options besides 'color', but they're optional.\n |> appearance(color = '#ff0000')", "// Add color to a revolved solid.\nsketch001 = startSketchOn(XY)\n |> circle(center = [15, 0], radius = 5)\n |> revolve(angle = 360, axis = Y)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", - "// Add color to different solids.\nfn cube(center) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - 10, center[1] - 10], %)\n |> line(endAbsolute = [center[0] + 10, center[1] - 10])\n |> line(endAbsolute = [center[0] + 10, center[1] + 10])\n |> line(endAbsolute = [center[0] - 10, center[1] + 10])\n |> close()\n |> extrude(length = 10)\n}\n\nexample0 = cube([0, 0])\nexample1 = cube([20, 0])\nexample2 = cube([40, 0])\n\nappearance(\n [example0, example1],\n color = '#ff0000',\n metalness = 50,\n roughness = 50,\n)\nappearance(\n example2,\n color = '#00ff00',\n metalness = 50,\n roughness = 50,\n)", - "// You can set the appearance before or after you shell it will yield the same result.\n// This example shows setting the appearance _after_ the shell.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\nshell(firstSketch, faces = [END], thickness = 0.25)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", - "// You can set the appearance before or after you shell it will yield the same result.\n// This example shows setting the appearance _before_ the shell.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)\n\nshell(firstSketch, faces = [END], thickness = 0.25)", - "// Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern.\n// This example shows _before_ the pattern.\nexampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)", - "// Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern.\n// This example shows _after_ the pattern.\nexampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", - "// Color the result of a 2D pattern that was extruded.\nexampleSketch = startSketchOn(XZ)\n |> startProfileAt([.5, 25], %)\n |> line(end = [0, 5])\n |> line(end = [-1, 0])\n |> line(end = [0, -5])\n |> close()\n |> patternCircular2d(\n center = [0, 0],\n instances = 13,\n arcDegrees = 360,\n rotateDuplicates = true,\n )\n\nexample = extrude(exampleSketch, length = 1)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", - "// Color the result of a sweep.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -90, radius = 5)\n |> line(end = [0, 7])\n\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 |> appearance(color = \"#ff0000\", metalness = 50, roughness = 50)", + "// Add color to different solids.\nfn cube(center) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - 10, center[1] - 10])\n |> line(endAbsolute = [center[0] + 10, center[1] - 10])\n |> line(endAbsolute = [center[0] + 10, center[1] + 10])\n |> line(endAbsolute = [center[0] - 10, center[1] + 10])\n |> close()\n |> extrude(length = 10)\n}\n\nexample0 = cube([0, 0])\nexample1 = cube([20, 0])\nexample2 = cube([40, 0])\n\nappearance(\n [example0, example1],\n color = '#ff0000',\n metalness = 50,\n roughness = 50,\n)\nappearance(\n example2,\n color = '#00ff00',\n metalness = 50,\n roughness = 50,\n)", + "// You can set the appearance before or after you shell it will yield the same result.\n// This example shows setting the appearance _after_ the shell.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\nshell(firstSketch, faces = [END], thickness = 0.25)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", + "// You can set the appearance before or after you shell it will yield the same result.\n// This example shows setting the appearance _before_ the shell.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)\n\nshell(firstSketch, faces = [END], thickness = 0.25)", + "// Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern.\n// This example shows _before_ the pattern.\nexampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)", + "// Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern.\n// This example shows _after_ the pattern.\nexampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", + "// Color the result of a 2D pattern that was extruded.\nexampleSketch = startSketchOn(XZ)\n |> startProfile(at = [.5, 25])\n |> line(end = [0, 5])\n |> line(end = [-1, 0])\n |> line(end = [0, -5])\n |> close()\n |> patternCircular2d(\n center = [0, 0],\n instances = 13,\n arcDegrees = 360,\n rotateDuplicates = true,\n )\n\nexample = extrude(exampleSketch, length = 1)\n |> appearance(color = '#ff0000', metalness = 90, roughness = 90)", + "// Color the result of a sweep.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -90, radius = 5)\n |> line(end = [0, 7])\n\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 |> appearance(color = \"#ff0000\", metalness = 50, roughness = 50)", "// Change the appearance of an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> appearance(color = \"#ff0000\", metalness = 50, roughness = 50)" ] }, @@ -45594,8 +45594,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> arc(angleStart = 0, angleEnd = 280, radius = 16)\n |> close()\nexample = extrude(exampleSketch, length = 10)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> arc(endAbsolute = [10, 0], interiorAbsolute = [5, 5])\n |> close()\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> arc(angleStart = 0, angleEnd = 280, radius = 16)\n |> close()\nexample = extrude(exampleSketch, length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> arc(endAbsolute = [10, 0], interiorAbsolute = [5, 5])\n |> close()\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -45637,7 +45637,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = toDegrees(asin(0.5)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = toDegrees(asin(0.5)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -45929,7 +45929,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = toDegrees(atan(1.25)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = toDegrees(atan(1.25)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -45986,7 +45986,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = toDegrees(atan2(y = 1.25, x = 2)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = toDegrees(atan2(y = 1.25, x = 2)), length = 20)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -55764,7 +55764,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 10])\n |> bezierCurve(control1 = [5, 0], control2 = [5, 10], end = [10, 10])\n |> line(endAbsolute = [10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 10])\n |> bezierCurve(control1 = [5, 0], control2 = [5, 10], end = [10, 10])\n |> line(endAbsolute = [10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -55806,7 +55806,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(endAbsolute = [12, 10])\n |> line(end = [ceil(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(endAbsolute = [12, 10])\n |> line(end = [ceil(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -64033,8 +64033,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Chamfer a mounting plate.\nwidth = 20\nlength = 10\nthickness = 1\nchamferLength = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfileAt([-width / 2, -length / 2], %)\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> chamfer(\n length = chamferLength,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )", - "// Sketch on the face of a chamfer.\nfn cube(pos, scale) {\n sg = startSketchOn(XY)\n |> startProfileAt(pos, %)\n |> line(end = [0, scale])\n |> line(end = [scale, 0])\n |> line(end = [0, -scale])\n\n return sg\n}\n\npart001 = cube([0, 0], 20)\n |> close(tag = $line1)\n |> extrude(length = 20)\n // We tag the chamfer to reference it later.\n |> chamfer(length = 10, tags = [getOppositeEdge(line1)], tag = $chamfer1)\n\nsketch001 = startSketchOn(part001, face = chamfer1)\n |> startProfileAt([10, 10], %)\n |> line(end = [2, 0])\n |> line(end = [0, 2])\n |> line(end = [-2, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n |> extrude(length = 10)" + "// Chamfer a mounting plate.\nwidth = 20\nlength = 10\nthickness = 1\nchamferLength = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfile(at = [-width / 2, -length / 2])\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> chamfer(\n length = chamferLength,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )", + "// Sketch on the face of a chamfer.\nfn cube(pos, scale) {\n sg = startSketchOn(XY)\n |> startProfile(at = pos)\n |> line(end = [0, scale])\n |> line(end = [scale, 0])\n |> line(end = [0, -scale])\n\n return sg\n}\n\npart001 = cube([0, 0], 20)\n |> close(tag = $line1)\n |> extrude(length = 20)\n // We tag the chamfer to reference it later.\n |> chamfer(length = 10, tags = [getOppositeEdge(line1)], tag = $chamfer1)\n\nsketch001 = startSketchOn(part001, face = chamfer1)\n |> startProfile(at = [10, 10])\n |> line(end = [2, 0])\n |> line(end = [0, 2])\n |> line(end = [-2, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n |> extrude(length = 10)" ] }, { @@ -77354,15 +77354,15 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Clone a basic sketch and move it and extrude it.\nexampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nclonedSketch = clone(exampleSketch)\n |> scale(x = 1.0, y = 1.0, z = 2.5)\n |> translate(x = 15.0, y = 0, z = 0)\n |> extrude(length = 5)", - "// Clone a basic solid and move it.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nmyPart = extrude(exampleSketch, length = 5)\nclonedPart = clone(myPart)\n |> translate(x = 25.0)", - "// Translate and rotate a cloned sketch to create a loft.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfileAt([-10, 10], %)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> close()\n\nsketch002 = clone(sketch001)\n |> translate(x = 0, y = 0, z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([sketch001, sketch002])", - "// Translate a cloned solid. Fillet only the clone.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfileAt([-10, 10], %)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20, tag = $filletTag)\n |> close()\n |> extrude(length = 5)\n\nsketch002 = clone(sketch001)\n |> translate(x = 0, y = 0, z = 20)\n |> fillet(radius = 2, tags = [getNextAdjacentEdge(filletTag)])", - "// You can reuse the tags from the original geometry with the cloned geometry.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10], tag = $sketchingFace)\n |> line(end = [-10, 0])\n |> close()\n\nsketch002 = clone(sketch001)\n |> translate(x = 10, y = 20, z = 0)\n |> extrude(length = 5)\n\nstartSketchOn(sketch002, face = sketchingFace)\n |> startProfileAt([1, 1], %)\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close(tag = $sketchingFace002)\n |> extrude(length = 10)", - "// You can also use the tags from the original geometry to fillet the cloned geometry.\n\n\nwidth = 20\nlength = 10\nthickness = 1\nfilletRadius = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfileAt([-width / 2, -length / 2], %)\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n\nclonedMountingPlate = clone(mountingPlate)\n |> fillet(\n radius = filletRadius,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )\n |> translate(x = 0, y = 50, z = 0)", + "// Clone a basic sketch and move it and extrude it.\nexampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nclonedSketch = clone(exampleSketch)\n |> scale(x = 1.0, y = 1.0, z = 2.5)\n |> translate(x = 15.0, y = 0, z = 0)\n |> extrude(length = 5)", + "// Clone a basic solid and move it.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nmyPart = extrude(exampleSketch, length = 5)\nclonedPart = clone(myPart)\n |> translate(x = 25.0)", + "// Translate and rotate a cloned sketch to create a loft.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfile(at = [-10, 10])\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> close()\n\nsketch002 = clone(sketch001)\n |> translate(x = 0, y = 0, z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([sketch001, sketch002])", + "// Translate a cloned solid. Fillet only the clone.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfile(at = [-10, 10])\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20, tag = $filletTag)\n |> close()\n |> extrude(length = 5)\n\nsketch002 = clone(sketch001)\n |> translate(x = 0, y = 0, z = 20)\n |> fillet(radius = 2, tags = [getNextAdjacentEdge(filletTag)])", + "// You can reuse the tags from the original geometry with the cloned geometry.\n\n\nsketch001 = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10], tag = $sketchingFace)\n |> line(end = [-10, 0])\n |> close()\n\nsketch002 = clone(sketch001)\n |> translate(x = 10, y = 20, z = 0)\n |> extrude(length = 5)\n\nstartSketchOn(sketch002, face = sketchingFace)\n |> startProfile(at = [1, 1])\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close(tag = $sketchingFace002)\n |> extrude(length = 10)", + "// You can also use the tags from the original geometry to fillet the cloned geometry.\n\n\nwidth = 20\nlength = 10\nthickness = 1\nfilletRadius = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfile(at = [-width / 2, -length / 2])\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n\nclonedMountingPlate = clone(mountingPlate)\n |> fillet(\n radius = filletRadius,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )\n |> translate(x = 0, y = 50, z = 0)", "// Create a spring by sweeping around a helix path from a cloned sketch.\n\n// Create a helix around the Z axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 4,\n length = 10,\n radius = 5,\n axis = Z,\n)\n\nspringSketch = startSketchOn(YZ)\n |> circle(center = [0, 0], radius = 1)\n\n// Create a spring by sweeping around the helix path.\nsweepedSpring = clone(springSketch)\n |> translate(x = 100)\n |> sweep(path = helixPath)", "// A donut shape from a cloned sketch.\nsketch001 = startSketchOn(XY)\n |> circle(center = [15, 0], radius = 5)\n\nsketch002 = clone(sketch001)\n |> translate(z = 30)\n |> revolve(angle = 360, axis = Y)", - "// Sketch on the end of a revolved face by tagging the end face.\n// This shows the cloned geometry will have the same tags as the original geometry.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfileAt([4, 12], %)\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample001 = revolve(\n exampleSketch,\n axis = Y,\n angle = 180,\n tagEnd = $end01,\n)\n\n// example002 = clone(example001)\n// |> translate(x = 0, y = 20, z = 0)\n\n\n// Sketch on the cloned face.\n// exampleSketch002 = startSketchOn(example002, face = end01)\n// |> startProfileAt([4.5, -5], %)\n// |> line(end = [0, 5])\n// |> line(end = [5, 0])\n// |> line(end = [0, -5])\n// |> close()\n\n\n// example003 = extrude(exampleSketch002, length = 5)", + "// Sketch on the end of a revolved face by tagging the end face.\n// This shows the cloned geometry will have the same tags as the original geometry.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfile(at = [4, 12])\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample001 = revolve(\n exampleSketch,\n axis = Y,\n angle = 180,\n tagEnd = $end01,\n)\n\n// example002 = clone(example001)\n// |> translate(x = 0, y = 20, z = 0)\n\n\n// Sketch on the cloned face.\n// exampleSketch002 = startSketchOn(example002, face = end01)\n// |> startProfile(at = [4.5, -5])\n// |> line(end = [0, 5])\n// |> line(end = [5, 0])\n// |> line(end = [0, -5])\n// |> close()\n\n\n// example003 = extrude(exampleSketch002, length = 5)", "// Clone an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\nmyCube = cube\n\nclonedCube = clone(myCube)\n |> translate(x = 1020)\n |> appearance(color = \"#ff0000\", metalness = 50, roughness = 50)" ] }, @@ -82314,8 +82314,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 10])\n |> line(end = [10, 0])\n |> close()\n |> extrude(length = 10)", - "exampleSketch = startSketchOn(-XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 10])\n |> line(end = [10, 0])\n |> close()\n |> extrude(length = 10)", + "exampleSketch = startSketchOn(-XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -82343,7 +82343,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 30, length = 2 * e() ^ 2)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 30, length = 2 * e() ^ 2)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -93603,10 +93603,10 @@ "unpublished": false, "deprecated": false, "examples": [ - "example = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> arc(angleStart = 120, angleEnd = 0, radius = 5)\n |> line(end = [5, 0])\n |> line(end = [0, 10])\n |> bezierCurve(control1 = [-10, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-5, -2])\n |> close()\n |> extrude(length = 10)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([-10, 0], %)\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([-10, 0], %)\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 20, symmetric = true)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([-10, 0], %)\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10, bidirectionalLength = 50)" + "example = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> arc(angleStart = 120, angleEnd = 0, radius = 5)\n |> line(end = [5, 0])\n |> line(end = [0, 10])\n |> bezierCurve(control1 = [-10, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-5, -2])\n |> close()\n |> extrude(length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [-10, 0])\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [-10, 0])\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 20, symmetric = true)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [-10, 0])\n |> arc(angleStart = 120, angleEnd = -60, radius = 5)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10])\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10, bidirectionalLength = 50)" ] }, { @@ -103459,8 +103459,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "width = 20\nlength = 10\nthickness = 1\nfilletRadius = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfileAt([-width / 2, -length / 2], %)\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> fillet(\n radius = filletRadius,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )", - "width = 20\nlength = 10\nthickness = 1\nfilletRadius = 1\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfileAt([-width / 2, -length / 2], %)\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> fillet(\n radius = filletRadius,\n tolerance = 0.000001,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )" + "width = 20\nlength = 10\nthickness = 1\nfilletRadius = 2\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfile(at = [-width / 2, -length / 2])\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> fillet(\n radius = filletRadius,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )", + "width = 20\nlength = 10\nthickness = 1\nfilletRadius = 1\n\nmountingPlateSketch = startSketchOn(XY)\n |> startProfile(at = [-width / 2, -length / 2])\n |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1)\n |> line(endAbsolute = [width / 2, length / 2], tag = $edge2)\n |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3)\n |> close(tag = $edge4)\n\nmountingPlate = extrude(mountingPlateSketch, length = thickness)\n |> fillet(\n radius = filletRadius,\n tolerance = 0.000001,\n tags = [\n getNextAdjacentEdge(edge1),\n getNextAdjacentEdge(edge2),\n getNextAdjacentEdge(edge3),\n getNextAdjacentEdge(edge4)\n ],\n )" ] }, { @@ -103502,7 +103502,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(endAbsolute = [12, 10])\n |> line(end = [floor(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(endAbsolute = [12, 10])\n |> line(end = [floor(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -103810,7 +103810,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Get an edge shared between two faces, created after a chamfer.\n\n\nscale = 20\npart001 = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, scale])\n |> line(end = [scale, 0])\n |> line(end = [0, -scale])\n |> close(tag = $line0)\n |> extrude(length = 20, tagEnd = $end0)\n // We tag the chamfer to reference it later.\n |> chamfer(length = 10, tags = [getOppositeEdge(line0)], tag = $chamfer0)\n\n// Get the shared edge between the chamfer and the extrusion.\ncommonEdge = getCommonEdge(faces = [chamfer0, end0])\n\n// Chamfer the shared edge.\n// TODO: uncomment this when ssi for fillets lands\n// chamfer(part001, length = 5, tags = [commonEdge])" + "// Get an edge shared between two faces, created after a chamfer.\n\n\nscale = 20\npart001 = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [0, scale])\n |> line(end = [scale, 0])\n |> line(end = [0, -scale])\n |> close(tag = $line0)\n |> extrude(length = 20, tagEnd = $end0)\n // We tag the chamfer to reference it later.\n |> chamfer(length = 10, tags = [getOppositeEdge(line0)], tag = $chamfer0)\n\n// Get the shared edge between the chamfer and the extrusion.\ncommonEdge = getCommonEdge(faces = [chamfer0, end0])\n\n// Chamfer the shared edge.\n// TODO: uncomment this when ssi for fillets lands\n// chamfer(part001, length = 5, tags = [commonEdge])" ] }, { @@ -103858,7 +103858,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getNextAdjacentEdge(referenceEdge)])" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getNextAdjacentEdge(referenceEdge)])" ] }, { @@ -103906,7 +103906,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getOppositeEdge(referenceEdge)])" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getOppositeEdge(referenceEdge)])" ] }, { @@ -103954,7 +103954,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getPreviousAdjacentEdge(referenceEdge)])" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> angledLine(angle = 60, length = 10)\n |> angledLine(angle = 120, length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = 240, length = 10, tag = $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getPreviousAdjacentEdge(referenceEdge)])" ] }, { @@ -108902,8 +108902,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n |> hole(circle(center = [1, 1], radius = .25), %)\n |> hole(circle(center = [1, 4], radius = .25), %)\n\nexample = extrude(exampleSketch, length = 1)", - "fn squareHoleSketch() {\n squareSketch = startSketchOn(-XZ)\n |> startProfileAt([-1, -1], %)\n |> line(end = [2, 0])\n |> line(end = [0, 2])\n |> line(end = [-2, 0])\n |> close()\n return squareSketch\n}\n\nexampleSketch = startSketchOn(-XZ)\n |> circle(center = [0, 0], radius = 3)\n |> hole(squareHoleSketch(), %)\nexample = extrude(exampleSketch, length = 1)" + "exampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n |> hole(circle(center = [1, 1], radius = .25), %)\n |> hole(circle(center = [1, 4], radius = .25), %)\n\nexample = extrude(exampleSketch, length = 1)", + "fn squareHoleSketch() {\n squareSketch = startSketchOn(-XZ)\n |> startProfile(at = [-1, -1])\n |> line(end = [2, 0])\n |> line(end = [0, 2])\n |> line(end = [-2, 0])\n |> close()\n return squareSketch\n}\n\nexampleSketch = startSketchOn(-XZ)\n |> circle(center = [0, 0], radius = 3)\n |> hole(squareHoleSketch(), %)\nexample = extrude(exampleSketch, length = 1)" ] }, { @@ -113879,9 +113879,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Hollow a basic sketch.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> hollow(thickness = 0.25)", - "// Hollow a basic sketch.\nfirstSketch = startSketchOn(-XZ)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> hollow(thickness = 0.5)", - "// Hollow a sketch on face object.\nsize = 100\ncase = startSketchOn(-XZ)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nhollow(case, thickness = 0.5)" + "// Hollow a basic sketch.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> hollow(thickness = 0.25)", + "// Hollow a basic sketch.\nfirstSketch = startSketchOn(-XZ)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n |> hollow(thickness = 0.5)", + "// Hollow a sketch on face object.\nsize = 100\ncase = startSketchOn(-XZ)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nhollow(case, thickness = 0.5)" ] }, { @@ -118758,8 +118758,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Intersect two cubes using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nintersectedPart = intersect([part001, part002])", - "// Intersect two cubes using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: intersect([part001, part002])\nintersectedPart = part001 & part002" + "// Intersect two cubes using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nintersectedPart = intersect([part001, part002])", + "// Intersect two cubes using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: intersect([part001, part002])\nintersectedPart = part001 & part002" ] }, { @@ -130129,7 +130129,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "a = 10\nb = 14\nstartSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> involuteCircular(startRadius = a, endRadius = b, angle = 60)\n |> involuteCircular(\n startRadius = a,\n endRadius = b,\n angle = 60,\n reverse = true,\n )" + "a = 10\nb = 14\nstartSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> involuteCircular(startRadius = a, endRadius = b, angle = 60)\n |> involuteCircular(\n startRadius = a,\n endRadius = b,\n angle = 60,\n reverse = true,\n )" ] }, { @@ -131821,7 +131821,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [5, 0])\n |> line(end = [20, 5])\n |> line(end = [lastSegX(%), 0])\n |> line(end = [-15, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [5, 0])\n |> line(end = [20, 5])\n |> line(end = [lastSegX(%), 0])\n |> line(end = [-15, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -133513,7 +133513,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [5, 0])\n |> line(end = [20, 5])\n |> line(end = [0, lastSegY(%)])\n |> line(end = [-15, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [5, 0])\n |> line(end = [20, 5])\n |> line(end = [0, lastSegY(%)])\n |> line(end = [-15, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -141854,7 +141854,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "triangle = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n // The END argument means it ends at exactly [10, 0].\n // This is an absolute measurement, it is NOT relative to\n // the start of the sketch.\n |> line(endAbsolute = [10, 0])\n |> line(endAbsolute = [0, 10])\n |> line(endAbsolute = [-10, 0], tag = $thirdLineOfTriangle)\n |> close()\n |> extrude(length = 5)\n\nbox = startSketchOn(XZ)\n |> startProfileAt([10, 10], %)\n // The 'to' argument means move the pen this much.\n // So, [10, 0] is a relative distance away from the current point.\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0], tag = $thirdLineOfBox)\n |> close()\n |> extrude(length = 5)" + "triangle = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n // The END argument means it ends at exactly [10, 0].\n // This is an absolute measurement, it is NOT relative to\n // the start of the sketch.\n |> line(endAbsolute = [10, 0])\n |> line(endAbsolute = [0, 10])\n |> line(endAbsolute = [-10, 0], tag = $thirdLineOfTriangle)\n |> close()\n |> extrude(length = 5)\n\nbox = startSketchOn(XZ)\n |> startProfile(at = [10, 10])\n // The 'to' argument means move the pen this much.\n // So, [10, 0] is a relative distance away from the current point.\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0], tag = $thirdLineOfBox)\n |> close()\n |> extrude(length = 5)" ] }, { @@ -141896,7 +141896,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [ln(100), 15])\n |> line(end = [5, -6])\n |> line(end = [-10, -10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [ln(100), 15])\n |> line(end = [5, -6])\n |> line(end = [-10, -10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -154835,9 +154835,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Loft a square and a triangle.\nsquareSketch = startSketchOn(XY)\n |> startProfileAt([-100, 200], %)\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ntriangleSketch = startSketchOn(offsetPlane(XY, offset = 75))\n |> startProfileAt([0, 125], %)\n |> line(end = [-15, -30])\n |> line(end = [30, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nloft([squareSketch, triangleSketch])", - "// Loft a square, a circle, and another circle.\nsquareSketch = startSketchOn(XY)\n |> startProfileAt([-100, 200], %)\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch0 = startSketchOn(offsetPlane(XY, offset = 75))\n |> circle(center = [0, 100], radius = 50)\n\ncircleSketch1 = startSketchOn(offsetPlane(XY, offset = 150))\n |> circle(center = [0, 100], radius = 20)\n\nloft([\n squareSketch,\n circleSketch0,\n circleSketch1\n])", - "// Loft a square, a circle, and another circle with options.\nsquareSketch = startSketchOn(XY)\n |> startProfileAt([-100, 200], %)\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch0 = startSketchOn(offsetPlane(XY, offset = 75))\n |> circle(center = [0, 100], radius = 50)\n\ncircleSketch1 = startSketchOn(offsetPlane(XY, offset = 150))\n |> circle(center = [0, 100], radius = 20)\n\nloft(\n [\n squareSketch,\n circleSketch0,\n circleSketch1\n ],\n baseCurveIndex = 0,\n bezApproximateRational = false,\n tolerance = 0.000001,\n vDegree = 2,\n)" + "// Loft a square and a triangle.\nsquareSketch = startSketchOn(XY)\n |> startProfile(at = [-100, 200])\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ntriangleSketch = startSketchOn(offsetPlane(XY, offset = 75))\n |> startProfile(at = [0, 125])\n |> line(end = [-15, -30])\n |> line(end = [30, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nloft([squareSketch, triangleSketch])", + "// Loft a square, a circle, and another circle.\nsquareSketch = startSketchOn(XY)\n |> startProfile(at = [-100, 200])\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch0 = startSketchOn(offsetPlane(XY, offset = 75))\n |> circle(center = [0, 100], radius = 50)\n\ncircleSketch1 = startSketchOn(offsetPlane(XY, offset = 150))\n |> circle(center = [0, 100], radius = 20)\n\nloft([\n squareSketch,\n circleSketch0,\n circleSketch1\n])", + "// Loft a square, a circle, and another circle with options.\nsquareSketch = startSketchOn(XY)\n |> startProfile(at = [-100, 200])\n |> line(end = [200, 0])\n |> line(end = [0, -200])\n |> line(end = [-200, 0])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch0 = startSketchOn(offsetPlane(XY, offset = 75))\n |> circle(center = [0, 100], radius = 50)\n\ncircleSketch1 = startSketchOn(offsetPlane(XY, offset = 150))\n |> circle(center = [0, 100], radius = 20)\n\nloft(\n [\n squareSketch,\n circleSketch0,\n circleSketch1\n ],\n baseCurveIndex = 0,\n bezApproximateRational = false,\n tolerance = 0.000001,\n vDegree = 2,\n)" ] }, { @@ -154892,7 +154892,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [log(100, 5), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [log(100, 5), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -154934,7 +154934,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [log10(100), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [log10(100), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -154976,7 +154976,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [log2(100), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [log2(100), 0])\n |> line(end = [5, 8])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -162479,7 +162479,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 70, length = max(15, 31, 4, 13, 22))\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 70, length = max(15, 31, 4, 13, 22))\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -162524,7 +162524,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 70, length = min(15, 31, 4, 13, 22))\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 70, length = min(15, 31, 4, 13, 22))\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -173779,7 +173779,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([.5, 25], %)\n |> line(end = [0, 5])\n |> line(end = [-1, 0])\n |> line(end = [0, -5])\n |> close()\n |> patternCircular2d(\n center = [0, 0],\n instances = 13,\n arcDegrees = 360,\n rotateDuplicates = true,\n )\n\nexample = extrude(exampleSketch, length = 1)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [.5, 25])\n |> line(end = [0, 5])\n |> line(end = [-1, 0])\n |> line(end = [0, -5])\n |> close()\n |> patternCircular2d(\n center = [0, 0],\n instances = 13,\n arcDegrees = 360,\n rotateDuplicates = true,\n )\n\nexample = extrude(exampleSketch, length = 1)" ] }, { @@ -205946,9 +205946,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)", - "// Pattern a whole sketch on face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n // We pass in the \"case\" here since we want to pattern the whole sketch.\n// And the case was the base of the sketch.\npatternLinear3d(\n case,\n axis = [1, 0, 0],\n distance = 250,\n instances = 2,\n)", - "// Pattern an object on a face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We pass in `thing1` here with `useOriginal` since we want to pattern just this object on the face.\npatternLinear3d(\n thing1,\n axis = [1, 0, 0],\n distance = size,\n instances = 2,\n useOriginal = true,\n)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 2])\n |> line(end = [3, 1])\n |> line(end = [0, -4])\n |> close()\n\nexample = extrude(exampleSketch, length = 1)\n |> patternLinear3d(axis = [1, 0, 1], instances = 7, distance = 6)", + "// Pattern a whole sketch on face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n // We pass in the \"case\" here since we want to pattern the whole sketch.\n// And the case was the base of the sketch.\npatternLinear3d(\n case,\n axis = [1, 0, 0],\n distance = 250,\n instances = 2,\n)", + "// Pattern an object on a face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We pass in `thing1` here with `useOriginal` since we want to pattern just this object on the face.\npatternLinear3d(\n thing1,\n axis = [1, 0, 0],\n distance = size,\n instances = 2,\n useOriginal = true,\n)" ] }, { @@ -213991,10 +213991,10 @@ "examples": [ "// Each instance will be shifted along the X axis.\nfn transform(id) {\n return { translate = [4 * id, 0, 0] }\n}\n\n// Sketch 4 cylinders.\nsketch001 = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 5)\n |> patternTransform(instances = 4, transform = transform)", "// Each instance will be shifted along the X axis,\n// with a gap between the original (at x = 0) and the first replica\n// (at x = 8). This is because `id` starts at 1.\nfn transform(id) {\n return { translate = [4 * (1 + id), 0, 0] }\n}\n\nsketch001 = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 5)\n |> patternTransform(instances = 4, transform = transform)", - "fn cube(length, center) {\n l = length / 2\n x = center[0]\n y = center[1]\n p0 = [-l + x, -l + y]\n p1 = [-l + x, l + y]\n p2 = [l + x, l + y]\n p3 = [l + x, -l + y]\n\n return startSketchOn(XY)\n |> startProfileAt(p0, %)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> line(endAbsolute = p0)\n |> close()\n |> extrude(length = length)\n}\n\nwidth = 20\nfn transform(i) {\n return {\n // Move down each time.\n translate = [0, 0, -i * width],\n // Make the cube longer, wider and flatter each time.\n scale = [pow(1.1, i), pow(1.1, i), pow(0.9, i)],\n // Turn by 15 degrees each time.\n rotation = { angle = 15 * i, origin = \"local\" }\n }\n}\n\nmyCubes = cube(width, [100, 0])\n |> patternTransform(instances = 25, transform = transform)", - "fn cube(length, center) {\n l = length / 2\n x = center[0]\n y = center[1]\n p0 = [-l + x, -l + y]\n p1 = [-l + x, l + y]\n p2 = [l + x, l + y]\n p3 = [l + x, -l + y]\n\n return startSketchOn(XY)\n |> startProfileAt(p0, %)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> line(endAbsolute = p0)\n |> close()\n |> extrude(length = length)\n}\n\nwidth = 20\nfn transform(i) {\n return {\n translate = [0, 0, -i * width],\n rotation = {\n angle = 90 * i,\n // Rotate around the overall scene's origin.\n origin = \"global\"\n }\n }\n}\nmyCubes = cube(width, [100, 100])\n |> patternTransform(instances = 4, transform = transform)", + "fn cube(length, center) {\n l = length / 2\n x = center[0]\n y = center[1]\n p0 = [-l + x, -l + y]\n p1 = [-l + x, l + y]\n p2 = [l + x, l + y]\n p3 = [l + x, -l + y]\n\n return startSketchOn(XY)\n |> startProfile(at = p0)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> line(endAbsolute = p0)\n |> close()\n |> extrude(length = length)\n}\n\nwidth = 20\nfn transform(i) {\n return {\n // Move down each time.\n translate = [0, 0, -i * width],\n // Make the cube longer, wider and flatter each time.\n scale = [pow(1.1, i), pow(1.1, i), pow(0.9, i)],\n // Turn by 15 degrees each time.\n rotation = { angle = 15 * i, origin = \"local\" }\n }\n}\n\nmyCubes = cube(width, [100, 0])\n |> patternTransform(instances = 25, transform = transform)", + "fn cube(length, center) {\n l = length / 2\n x = center[0]\n y = center[1]\n p0 = [-l + x, -l + y]\n p1 = [-l + x, l + y]\n p2 = [l + x, l + y]\n p3 = [l + x, -l + y]\n\n return startSketchOn(XY)\n |> startProfile(at = p0)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> line(endAbsolute = p0)\n |> close()\n |> extrude(length = length)\n}\n\nwidth = 20\nfn transform(i) {\n return {\n translate = [0, 0, -i * width],\n rotation = {\n angle = 90 * i,\n // Rotate around the overall scene's origin.\n origin = \"global\"\n }\n }\n}\nmyCubes = cube(width, [100, 100])\n |> patternTransform(instances = 4, transform = transform)", "// Parameters\nr = 50 // base radius\nh = 10 // layer height\nt = 0.005 // taper factor [0-1)\n// Defines how to modify each layer of the vase.\n// Each replica is shifted up the Z axis, and has a smoothly-varying radius\nfn transform(replicaId) {\n scale = r * abs(1 - (t * replicaId)) * (5 + cos(replicaId / 8: number(rad)))\n return {\n translate = [0, 0, replicaId * 10],\n scale = [scale, scale, 0]\n }\n}\n// Each layer is just a pretty thin cylinder.\nfn layer() {\n return startSketchOn(XY)\n // or some other plane idk\n |> circle(center = [0, 0], radius = 1, tag = $tag1)\n |> extrude(length = h)\n}\n// The vase is 100 layers tall.\n// The 100 layers are replica of each other, with a slight transformation applied to each.\nvase = layer()\n |> patternTransform(instances = 100, transform = transform)", - "fn transform(i) {\n // Transform functions can return multiple transforms. They'll be applied in order.\n return [\n { translate = [30 * i, 0, 0] },\n { rotation = { angle = 45 * i } }\n ]\n}\nstartSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> polygon(\n radius = 10,\n numSides = 4,\n center = [0, 0],\n inscribed = false,\n )\n |> extrude(length = 4)\n |> patternTransform(instances = 3, transform = transform)" + "fn transform(i) {\n // Transform functions can return multiple transforms. They'll be applied in order.\n return [\n { translate = [30 * i, 0, 0] },\n { rotation = { angle = 45 * i } }\n ]\n}\nstartSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> polygon(\n radius = 10,\n numSides = 4,\n center = [0, 0],\n inscribed = false,\n )\n |> extrude(length = 4)\n |> patternTransform(instances = 3, transform = transform)" ] }, { @@ -237192,7 +237192,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 50, length = pow(5, 2))\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 50, length = pow(5, 2))\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -238889,7 +238889,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XY)\n |> startProfileAt([5, 2], %)\n |> angledLine(angle = 120, length = 50, tag = $seg01)\n |> angledLine(angle = segAng(seg01) + 120, length = 50)\n |> line(end = profileStart(%))\n |> close()\n |> extrude(length = 20)" + "sketch001 = startSketchOn(XY)\n |> startProfile(at = [5, 2])\n |> angledLine(angle = 120, length = 50, tag = $seg01)\n |> angledLine(angle = segAng(seg01) + 120, length = 50)\n |> line(end = profileStart(%))\n |> close()\n |> extrude(length = 20)" ] }, { @@ -240581,7 +240581,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XY)\n |> startProfileAt([5, 2], %)\n |> angledLine(angle = -26.6, length = 50)\n |> angledLine(angle = 90, length = 50)\n |> angledLine(angle = 30, endAbsoluteX = profileStartX(%))" + "sketch001 = startSketchOn(XY)\n |> startProfile(at = [5, 2])\n |> angledLine(angle = -26.6, length = 50)\n |> angledLine(angle = 90, length = 50)\n |> angledLine(angle = 30, endAbsoluteX = profileStartX(%))" ] }, { @@ -242273,7 +242273,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XY)\n |> startProfileAt([5, 2], %)\n |> angledLine(angle = -60, length = 14)\n |> angledLine(angle = 30, endAbsoluteY = profileStartY(%))" + "sketch001 = startSketchOn(XY)\n |> startProfile(at = [5, 2])\n |> angledLine(angle = -60, length = 14)\n |> angledLine(angle = 30, endAbsoluteY = profileStartY(%))" ] }, { @@ -261194,7 +261194,7 @@ "examples": [ "// This function adds two numbers.\nfn add(a, b) {\n return a + b\n}\n\n// This function adds an array of numbers.\n// It uses the `reduce` function, to call the `add` function on every\n// element of the `arr` parameter. The starting value is 0.\nfn sum(arr) {\n return reduce(arr, 0, add)\n}\n\n/* The above is basically like this pseudo-code:\nfn sum(arr):\n sumSoFar = 0\n for i in arr:\n sumSoFar = add(sumSoFar, i)\n return sumSoFar */\n\n// We use `assert` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassert(\n sum([1, 2, 3]),\n isEqualTo = 6,\n tolerance = 0.1,\n error = \"1 + 2 + 3 summed is 6\",\n)", "// This example works just like the previous example above, but it uses\n// an anonymous `add` function as its parameter, instead of declaring a\n// named function outside.\narr = [1, 2, 3]\nsum = reduce(arr, 0, fn(i, result_so_far) {\n return i + result_so_far\n})\n\n// We use `assert` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassert(\n sum,\n isEqualTo = 6,\n tolerance = 0.1,\n error = \"1 + 2 + 3 summed is 6\",\n)", - "// Declare a function that sketches a decagon.\nfn decagon(radius) {\n // Each side of the decagon is turned this many radians from the previous angle.\n stepAngle = 1 / 10 * TAU\n\n // Start the decagon sketch at this point.\n startOfDecagonSketch = startSketchOn(XY)\n |> startProfileAt([cos(0) * radius, sin(0) * radius], %)\n\n // Use a `reduce` to draw the remaining decagon sides.\n // For each number in the array 1..10, run the given function,\n // which takes a partially-sketched decagon and adds one more edge to it.\n fullDecagon = reduce([1..10], startOfDecagonSketch, fn(i, partialDecagon) {\n // Draw one edge of the decagon.\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n return line(partialDecagon, end = [x, y])\n })\n\n return fullDecagon\n}\n\n/* The `decagon` above is basically like this pseudo-code:\nfn decagon(radius):\n stepAngle = (1/10) * TAU\n plane = startSketchOn('XY')\n startOfDecagonSketch = startProfileAt([(cos(0)*radius), (sin(0) * radius)], plane)\n\n // Here's the reduce part.\n partialDecagon = startOfDecagonSketch\n for i in [1..10]:\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n partialDecagon = line(partialDecagon, end = [x, y])\n fullDecagon = partialDecagon // it's now full\n return fullDecagon */\n\n// Use the `decagon` function declared above, to sketch a decagon with radius 5.\ndecagon(5.0)\n |> close()" + "// Declare a function that sketches a decagon.\nfn decagon(radius) {\n // Each side of the decagon is turned this many radians from the previous angle.\n stepAngle = 1 / 10 * TAU\n\n // Start the decagon sketch at this point.\n startOfDecagonSketch = startSketchOn(XY)\n |> startProfile(at = [cos(0) * radius, sin(0) * radius])\n\n // Use a `reduce` to draw the remaining decagon sides.\n // For each number in the array 1..10, run the given function,\n // which takes a partially-sketched decagon and adds one more edge to it.\n fullDecagon = reduce([1..10], startOfDecagonSketch, fn(i, partialDecagon) {\n // Draw one edge of the decagon.\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n return line(partialDecagon, end = [x, y])\n })\n\n return fullDecagon\n}\n\n/* The `decagon` above is basically like this pseudo-code:\nfn decagon(radius):\n stepAngle = (1/10) * TAU\n plane = startSketchOn('XY')\n startOfDecagonSketch = startProfile(plane, at = [(cos(0)*radius), (sin(0) * radius)])\n\n // Here's the reduce part.\n partialDecagon = startOfDecagonSketch\n for i in [1..10]:\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n partialDecagon = line(partialDecagon, end = [x, y])\n fullDecagon = partialDecagon // it's now full\n return fullDecagon */\n\n// Use the `decagon` function declared above, to sketch a decagon with radius 5.\ndecagon(5.0)\n |> close()" ] }, { @@ -274251,12 +274251,12 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Rotate a pipe with roll, pitch, and yaw.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(roll = 10, pitch = 10, yaw = 90)", - "// Rotate a pipe with just roll.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(roll = 10)", - "// 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(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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 a pipe with roll, pitch, and yaw.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(roll = 10, pitch = 10, yaw = 90)", + "// Rotate a pipe with just roll.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(roll = 10)", + "// Rotate a pipe about an axis with an angle.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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 = 9)", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\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, angle = -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(x = 0, y = 0, z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfile(sketch001, at = [-200, 23.86])\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfile(sketch002, at = [0, 0])\n |> yLine(length = 231.81)\n |> tangentialArc(radius = 80, angle = -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 startProfile(sketch001, at = [-10, 10])\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])" ] }, { @@ -274298,7 +274298,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(endAbsolute = [12, 10])\n |> line(end = [round(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(endAbsolute = [12, 10])\n |> line(end = [round(7.02986), 0])\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -284083,9 +284083,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(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(z = 2.5)", + "// Scale a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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(z = 2.5)", "// Scale an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> scale(y = 2.5)", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\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, angle = -90)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(parts, z = 0.5)" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfile(sketch001, at = [-200, 23.86])\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfile(sketch002, at = [0, 0])\n |> yLine(length = 231.81)\n |> tangentialArc(radius = 80, angle = -90)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(parts, z = 0.5)" ] }, { @@ -284133,7 +284133,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [5, 10], tag = $seg01)\n |> line(end = [-10, 0])\n |> angledLine(angle = segAng(seg01), length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = segAng(seg01), length = -15)\n |> close()\n\nexample = extrude(exampleSketch, length = 4)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [5, 10], tag = $seg01)\n |> line(end = [-10, 0])\n |> angledLine(angle = segAng(seg01), length = 10)\n |> line(end = [-10, 0])\n |> angledLine(angle = segAng(seg01), length = -15)\n |> close()\n\nexample = extrude(exampleSketch, length = 4)" ] }, { @@ -284191,7 +284191,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "w = 15\ncube = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [w, 0], tag = $line1)\n |> line(end = [0, w], tag = $line2)\n |> line(end = [-w, 0], tag = $line3)\n |> line(end = [0, -w], tag = $line4)\n |> close()\n |> extrude(length = 5)\n\nfn cylinder(radius, tag) {\n return startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> circle(radius = radius, center = segEnd(tag))\n |> extrude(length = radius)\n}\n\ncylinder(1, line1)\ncylinder(2, line2)\ncylinder(3, line3)\ncylinder(4, line4)" + "w = 15\ncube = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [w, 0], tag = $line1)\n |> line(end = [0, w], tag = $line2)\n |> line(end = [-w, 0], tag = $line3)\n |> line(end = [0, -w], tag = $line4)\n |> close()\n |> extrude(length = 5)\n\nfn cylinder(radius, tag) {\n return startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> circle(radius = radius, center = segEnd(tag))\n |> extrude(length = radius)\n}\n\ncylinder(1, line1)\ncylinder(2, line2)\ncylinder(3, line3)\ncylinder(4, line4)" ] }, { @@ -284239,7 +284239,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0], tag = $thing)\n |> line(end = [0, 5])\n |> line(end = [segEndX(thing), 0])\n |> line(end = [-20, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [20, 0], tag = $thing)\n |> line(end = [0, 5])\n |> line(end = [segEndX(thing), 0])\n |> line(end = [-20, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -284287,7 +284287,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0])\n |> line(end = [0, 3], tag = $thing)\n |> line(end = [-10, 0])\n |> line(end = [0, segEndY(thing)])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [20, 0])\n |> line(end = [0, 3], tag = $thing)\n |> line(end = [-10, 0])\n |> line(end = [0, segEndY(thing)])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -284335,7 +284335,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 60, length = 10, tag = $thing)\n |> tangentialArc(angle = -120, radius = 5)\n |> angledLine(angle = -60, length = segLen(thing))\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 60, length = 10, tag = $thing)\n |> tangentialArc(angle = -120, radius = 5)\n |> angledLine(angle = -60, length = segLen(thing))\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -284393,7 +284393,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "w = 15\ncube = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [w, 0], tag = $line1)\n |> line(end = [0, w], tag = $line2)\n |> line(end = [-w, 0], tag = $line3)\n |> line(end = [0, -w], tag = $line4)\n |> close()\n |> extrude(length = 5)\n\nfn cylinder(radius, tag) {\n return startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> circle(radius = radius, center = segStart(tag))\n |> extrude(length = radius)\n}\n\ncylinder(1, line1)\ncylinder(2, line2)\ncylinder(3, line3)\ncylinder(4, line4)" + "w = 15\ncube = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [w, 0], tag = $line1)\n |> line(end = [0, w], tag = $line2)\n |> line(end = [-w, 0], tag = $line3)\n |> line(end = [0, -w], tag = $line4)\n |> close()\n |> extrude(length = 5)\n\nfn cylinder(radius, tag) {\n return startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> circle(radius = radius, center = segStart(tag))\n |> extrude(length = radius)\n}\n\ncylinder(1, line1)\ncylinder(2, line2)\ncylinder(3, line3)\ncylinder(4, line4)" ] }, { @@ -284441,7 +284441,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0], tag = $thing)\n |> line(end = [0, 5])\n |> line(end = [20 - segStartX(thing), 0])\n |> line(end = [-20, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [20, 0], tag = $thing)\n |> line(end = [0, 5])\n |> line(end = [20 - segStartX(thing), 0])\n |> line(end = [-20, 10])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -284489,7 +284489,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0])\n |> line(end = [0, 3], tag = $thing)\n |> line(end = [-10, 0])\n |> line(end = [0, 20 - segStartY(thing)])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [20, 0])\n |> line(end = [0, 3], tag = $thing)\n |> line(end = [-10, 0])\n |> line(end = [0, 20 - segStartY(thing)])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -290962,13 +290962,13 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Remove the end face for the extrusion.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\n// Remove the end face for the extrusion.\nshell(firstSketch, faces = [END], thickness = 0.25)", - "// Remove the start face for the extrusion.\nfirstSketch = startSketchOn(-XZ)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\n// Remove the start face for the extrusion.\nshell(firstSketch, faces = [START], thickness = 0.25)", - "// Remove a tagged face and the end face for the extrusion.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0], tag = $myTag)\n |> close()\n |> extrude(length = 6)\n\n// Remove a tagged face for the extrusion.\nshell(firstSketch, faces = [myTag], thickness = 0.25)", - "// Remove multiple faces at once.\nfirstSketch = startSketchOn(XY)\n |> startProfileAt([-12, 12], %)\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0], tag = $myTag)\n |> close()\n |> extrude(length = 6)\n\n// Remove a tagged face and the end face for the extrusion.\nshell(firstSketch, faces = [myTag, END], thickness = 0.25)", - "// Shell a sketch on face.\nsize = 100\ncase = startSketchOn(-XZ)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"case\" in the shell function to shell the entire object.\nshell(case, faces = [START], thickness = 5)", - "// Shell a sketch on face object on the end face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"thing1\" in the shell function to shell the end face of the object.\nshell(thing1, faces = [END], thickness = 5)", - "// Shell sketched on face objects on the end face, include all sketches to shell\n// the entire object.\n\n\nsize = 100\ncase = startSketchOn(XY)\n |> startProfileAt([-size, -size], %)\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"thing1\" and \"thing2\" in the shell function to shell the end face of the object.\nshell([thing1, thing2], faces = [END], thickness = 5)" + "// Remove the end face for the extrusion.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\n// Remove the end face for the extrusion.\nshell(firstSketch, faces = [END], thickness = 0.25)", + "// Remove the start face for the extrusion.\nfirstSketch = startSketchOn(-XZ)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0])\n |> close()\n |> extrude(length = 6)\n\n// Remove the start face for the extrusion.\nshell(firstSketch, faces = [START], thickness = 0.25)", + "// Remove a tagged face and the end face for the extrusion.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0], tag = $myTag)\n |> close()\n |> extrude(length = 6)\n\n// Remove a tagged face for the extrusion.\nshell(firstSketch, faces = [myTag], thickness = 0.25)", + "// Remove multiple faces at once.\nfirstSketch = startSketchOn(XY)\n |> startProfile(at = [-12, 12])\n |> line(end = [24, 0])\n |> line(end = [0, -24])\n |> line(end = [-24, 0], tag = $myTag)\n |> close()\n |> extrude(length = 6)\n\n// Remove a tagged face and the end face for the extrusion.\nshell(firstSketch, faces = [myTag, END], thickness = 0.25)", + "// Shell a sketch on face.\nsize = 100\ncase = startSketchOn(-XZ)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"case\" in the shell function to shell the entire object.\nshell(case, faces = [START], thickness = 5)", + "// Shell a sketch on face object on the end face.\nsize = 100\ncase = startSketchOn(XY)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"thing1\" in the shell function to shell the end face of the object.\nshell(thing1, faces = [END], thickness = 5)", + "// Shell sketched on face objects on the end face, include all sketches to shell\n// the entire object.\n\n\nsize = 100\ncase = startSketchOn(XY)\n |> startProfile(at = [-size, -size])\n |> line(end = [2 * size, 0])\n |> line(end = [0, 2 * size])\n |> tangentialArc(endAbsolute = [-size, size])\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, face = END)\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, face = END)\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\n// We put \"thing1\" and \"thing2\" in the shell function to shell the end face of the object.\nshell([thing1, thing2], faces = [END], thickness = 5)" ] }, { @@ -291010,39 +291010,16 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 50, length = sqrt(2500))\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 50, length = sqrt(2500))\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { - "name": "startProfileAt", + "name": "startProfile", "summary": "Start a new profile at a given point.", "description": "", "tags": [], - "keywordArguments": false, + "keywordArguments": true, "args": [ - { - "name": "to", - "type": "[number]", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Array_size_2_of_TyF64", - "type": "array", - "items": { - "$ref": "#/components/schemas/TyF64" - }, - "maxItems": 2, - "minItems": 2, - "definitions": { - "TyF64": { - "type": "number", - "format": "double" - } - } - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, { "name": "sketchSurface", "type": "SketchSurface", @@ -291179,10 +291156,6 @@ } ], "definitions": { - "TyF64": { - "type": "number", - "format": "double" - }, "ArtifactId": { "type": "string", "format": "uuid" @@ -292767,11 +292740,1625 @@ } } ] + }, + "TyF64": { + "type": "number", + "format": "double" } } }, "required": true, "includeInSnippet": true, + "description": "What to start the profile on", + "labelRequired": false + }, + { + "name": "at", + "type": "[number]", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Array_size_2_of_TyF64", + "type": "array", + "items": { + "$ref": "#/components/schemas/TyF64" + }, + "maxItems": 2, + "minItems": 2, + "definitions": { + "ArtifactId": { + "type": "string", + "format": "uuid" + }, + "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": [ + "units", + "x", + "y", + "z" + ], + "properties": { + "x": { + "type": "number", + "format": "double" + }, + "y": { + "type": "number", + "format": "double" + }, + "z": { + "type": "number", + "format": "double" + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + }, + "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" + ] + } + } + }, + { + "type": "object", + "required": [ + "type" + ], + "properties": { + "type": { + "type": "string", + "enum": [ + "Unknown" + ] + } + } + } + ] + }, + "Solid": { + "type": "object", + "required": [ + "artifactId", + "height", + "id", + "sectional", + "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": { + "description": "The units of the solid.", + "allOf": [ + { + "$ref": "#/components/schemas/UnitLen" + } + ] + }, + "sectional": { + "description": "Is this a sectional solid?", + "type": "boolean" + } + } + }, + "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 (interiorAbsolute kwarg)", + "type": "array", + "items": { + "type": "number", + "format": "double" + }, + "maxItems": 2, + "minItems": 2 + }, + "p3": { + "description": "Point 3 of the arc (endAbsolute 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" + } + ] + } + } + } + ] + }, + "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", + "value", + "xAxis", + "yAxis" + ], + "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" + } + ] + } + } + }, + { + "description": "A face.", + "type": "object", + "required": [ + "artifactId", + "id", + "solid", + "type", + "units", + "value", + "xAxis", + "yAxis" + ], + "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" + } + ] + }, + "solid": { + "description": "The solid the face is on.", + "allOf": [ + { + "$ref": "#/components/schemas/Solid" + } + ] + }, + "units": { + "$ref": "#/components/schemas/UnitLen" + } + } + } + ] + }, + "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": { + "$ref": "#/components/schemas/TyF64" + }, + "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": { + "$ref": "#/components/schemas/TyF64" + }, + "edgeId": { + "description": "The engine id of the edge to chamfer.", + "type": "string", + "format": "uuid" + }, + "tag": { + "allOf": [ + { + "$ref": "#/components/schemas/TagDeclarator" + } + ], + "nullable": true + } + } + } + ] + }, + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": true, + "includeInSnippet": true, + "description": "Where to start the profile. An absolute point.", "labelRequired": true }, { @@ -292787,10 +294374,6 @@ ], "nullable": true, "definitions": { - "TyF64": { - "type": "number", - "format": "double" - }, "ArtifactId": { "type": "string", "format": "uuid" @@ -294375,10 +295958,15 @@ } } ] + }, + "TyF64": { + "type": "number", + "format": "double" } } }, "required": false, + "description": "Tag this first starting point", "labelRequired": true } ], @@ -296049,9 +297637,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)", - "exampleSketch = startSketchOn(-XZ)\n |> startProfileAt([10, 10], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)", - "exampleSketch = startSketchOn(-XZ)\n |> startProfileAt([-10, 23], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)", + "exampleSketch = startSketchOn(-XZ)\n |> startProfile(at = [10, 10])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)", + "exampleSketch = startSketchOn(-XZ)\n |> startProfile(at = [-10, 23])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -301341,12 +302929,12 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n\nexampleSketch002 = startSketchOn(example, face = END)\n |> startProfileAt([1, 1], %)\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)\n\nexampleSketch003 = startSketchOn(example002, face = END)\n |> startProfileAt([2, 2], %)\n |> line(end = [6, 0])\n |> line(end = [0, 6])\n |> line(end = [-6, 0])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", - "// Sketch on the end of an extruded face by tagging the end face.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5, tagEnd = $end01)\n\nexampleSketch002 = startSketchOn(example, face = end01)\n |> startProfileAt([1, 1], %)\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5, tagEnd = $end02)\n\nexampleSketch003 = startSketchOn(example002, face = end02)\n |> startProfileAt([2, 2], %)\n |> line(end = [6, 0])\n |> line(end = [0, 6])\n |> line(end = [-6, 0])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", - "exampleSketch = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10], tag = $sketchingFace)\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)\n\nexampleSketch002 = startSketchOn(example, face = sketchingFace)\n |> startProfileAt([1, 1], %)\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close(tag = $sketchingFace002)\n\nexample002 = extrude(exampleSketch002, length = 10)\n\nexampleSketch003 = startSketchOn(example002, face = sketchingFace002)\n |> startProfileAt([-8, 12], %)\n |> line(end = [0, 6])\n |> line(end = [6, 0])\n |> line(end = [0, -6])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", - "exampleSketch = startSketchOn(XY)\n |> startProfileAt([4, 12], %)\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample = revolve(exampleSketch, axis = Y, angle = 180)\n\nexampleSketch002 = startSketchOn(example, face = END)\n |> startProfileAt([4.5, -5], %)\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)", - "// Sketch on the end of a revolved face by tagging the end face.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfileAt([4, 12], %)\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample = revolve(\n exampleSketch,\n axis = Y,\n angle = 180,\n tagEnd = $end01,\n)\n\nexampleSketch002 = startSketchOn(example, face = end01)\n |> startProfileAt([4.5, -5], %)\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)", - "a1 = startSketchOn({\n origin = { x = 0, y = 0, z = 0 },\n xAxis = { x = 1, y = 0, z = 0 },\n yAxis = { x = 0, y = 1, z = 0 },\n zAxis = { x = 0, y = 0, z = 1 }\n })\n |> startProfileAt([0, 0], %)\n |> line(end = [100.0, 0])\n |> yLine(length = -100.0)\n |> xLine(length = -100.0)\n |> yLine(length = 100.0)\n |> close()\n |> extrude(length = 3.14)" + "exampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n\nexampleSketch002 = startSketchOn(example, face = END)\n |> startProfile(at = [1, 1])\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)\n\nexampleSketch003 = startSketchOn(example002, face = END)\n |> startProfile(at = [2, 2])\n |> line(end = [6, 0])\n |> line(end = [0, 6])\n |> line(end = [-6, 0])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", + "// Sketch on the end of an extruded face by tagging the end face.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5, tagEnd = $end01)\n\nexampleSketch002 = startSketchOn(example, face = end01)\n |> startProfile(at = [1, 1])\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5, tagEnd = $end02)\n\nexampleSketch003 = startSketchOn(example002, face = end02)\n |> startProfile(at = [2, 2])\n |> line(end = [6, 0])\n |> line(end = [0, 6])\n |> line(end = [-6, 0])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", + "exampleSketch = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0])\n |> line(end = [0, 10], tag = $sketchingFace)\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)\n\nexampleSketch002 = startSketchOn(example, face = sketchingFace)\n |> startProfile(at = [1, 1])\n |> line(end = [8, 0])\n |> line(end = [0, 8])\n |> line(end = [-8, 0])\n |> close(tag = $sketchingFace002)\n\nexample002 = extrude(exampleSketch002, length = 10)\n\nexampleSketch003 = startSketchOn(example002, face = sketchingFace002)\n |> startProfile(at = [-8, 12])\n |> line(end = [0, 6])\n |> line(end = [6, 0])\n |> line(end = [0, -6])\n |> close()\n\nexample003 = extrude(exampleSketch003, length = 5)", + "exampleSketch = startSketchOn(XY)\n |> startProfile(at = [4, 12])\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample = revolve(exampleSketch, axis = Y, angle = 180)\n\nexampleSketch002 = startSketchOn(example, face = END)\n |> startProfile(at = [4.5, -5])\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)", + "// Sketch on the end of a revolved face by tagging the end face.\n\n\nexampleSketch = startSketchOn(XY)\n |> startProfile(at = [4, 12])\n |> line(end = [2, 0])\n |> line(end = [0, -6])\n |> line(end = [4, -6])\n |> line(end = [0, -6])\n |> line(end = [-3.75, -4.5])\n |> line(end = [0, -5.5])\n |> line(end = [-2, 0])\n |> close()\n\nexample = revolve(\n exampleSketch,\n axis = Y,\n angle = 180,\n tagEnd = $end01,\n)\n\nexampleSketch002 = startSketchOn(example, face = end01)\n |> startProfile(at = [4.5, -5])\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n\nexample002 = extrude(exampleSketch002, length = 5)", + "a1 = startSketchOn({\n origin = { x = 0, y = 0, z = 0 },\n xAxis = { x = 1, y = 0, z = 0 },\n yAxis = { x = 0, y = 1, z = 0 },\n zAxis = { x = 0, y = 0, z = 1 }\n })\n |> startProfile(at = [0, 0])\n |> line(end = [100.0, 0])\n |> yLine(length = -100.0)\n |> xLine(length = -100.0)\n |> yLine(length = 100.0)\n |> close()\n |> extrude(length = 3.14)" ] }, { @@ -307788,8 +309376,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Subtract a cylinder from a cube using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nsubtractedPart = subtract([part001], tools = [part002])", - "// Subtract a cylinder from a cube using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: subtract([part001], tools=[part002])\nsubtractedPart = part001 - part002" + "// Subtract a cylinder from a cube using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nsubtractedPart = subtract([part001], tools = [part002])", + "// Subtract a cylinder from a cube using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: subtract([part001], tools=[part002])\nsubtractedPart = part001 - part002" ] }, { @@ -319306,10 +320894,10 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Create a pipe using a sweep.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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)", + "// Create a pipe using a sweep.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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)", "// Create a spring by sweeping around a helix path.\n\n// Create a helix around the Z axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 4,\n length = 10,\n radius = 5,\n axis = Z,\n)\n\n// Create a spring by sweeping around the helix path.\nspringSketch = startSketchOn(YZ)\n |> circle(center = [0, 0], radius = 1)\n |> sweep(path = helixPath)", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\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, angle = -90)\n |> xLine(length = 384.93)\n\nsweep([rectangleSketch, circleSketch], path = sweepPath)", - "// Sectionally sweep one sketch along the path\n\n\nsketch001 = startSketchOn(XY)\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, angle = -90)\n |> xLine(length = 384.93)\n\nsweep(circleSketch, path = sweepPath, sectional = true)" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfile(sketch001, at = [-200, 23.86])\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfile(sketch002, at = [0, 0])\n |> yLine(length = 231.81)\n |> tangentialArc(radius = 80, angle = -90)\n |> xLine(length = 384.93)\n\nsweep([rectangleSketch, circleSketch], path = sweepPath)", + "// Sectionally sweep one sketch along the path\n\n\nsketch001 = startSketchOn(XY)\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfile(sketch002, at = [0, 0])\n |> yLine(length = 231.81)\n |> tangentialArc(radius = 80, angle = -90)\n |> xLine(length = 384.93)\n\nsweep(circleSketch, path = sweepPath, sectional = true)" ] }, { @@ -319357,11 +320945,11 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Horizontal pill.\npillSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0])\n |> tangentialArc(end = [0, 10], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> tangentialArc(end = [0, -10])\n |> close()\n\npillExtrude = extrude(pillSketch, length = 10)", - "// Vertical pill. Use absolute coordinate for arc.\npillSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> tangentialArc(endAbsolute = [10, 20], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> tangentialArc(end = [-10, 0])\n |> close()\n\npillExtrude = extrude(pillSketch, length = 10)", - "rectangleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0], tag = $seg1)\n |> angledLine(angle = tangentToEnd(seg1), length = 10)\n |> line(end = [0, 10])\n |> line(end = [-20, 0])\n |> close()\n\nrectangleExtrude = extrude(rectangleSketch, length = 10)", - "bottom = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> arc(endAbsolute = [10, 10], interiorAbsolute = [5, 1], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> close()", - "circSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 3, tag = $circ)\n\ntriangleSketch = startSketchOn(XY)\n |> startProfileAt([-5, 0], %)\n |> angledLine(angle = tangentToEnd(circ), length = 10)\n |> line(end = [-15, 0])\n |> close()" + "// Horizontal pill.\npillSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [20, 0])\n |> tangentialArc(end = [0, 10], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> tangentialArc(end = [0, -10])\n |> close()\n\npillExtrude = extrude(pillSketch, length = 10)", + "// Vertical pill. Use absolute coordinate for arc.\npillSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [0, 20])\n |> tangentialArc(endAbsolute = [10, 20], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> tangentialArc(end = [-10, 0])\n |> close()\n\npillExtrude = extrude(pillSketch, length = 10)", + "rectangleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> line(end = [10, 0], tag = $seg1)\n |> angledLine(angle = tangentToEnd(seg1), length = 10)\n |> line(end = [0, 10])\n |> line(end = [-20, 0])\n |> close()\n\nrectangleExtrude = extrude(rectangleSketch, length = 10)", + "bottom = startSketchOn(XY)\n |> startProfile(at = [0, 0])\n |> arc(endAbsolute = [10, 10], interiorAbsolute = [5, 1], tag = $arc1)\n |> angledLine(angle = tangentToEnd(arc1), length = 20)\n |> close()", + "circSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 3, tag = $circ)\n\ntriangleSketch = startSketchOn(XY)\n |> startProfile(at = [-5, 0])\n |> angledLine(angle = tangentToEnd(circ), length = 10)\n |> line(end = [-15, 0])\n |> close()" ] }, { @@ -330747,9 +332335,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 45, length = 10)\n |> tangentialArc(end = [0, -10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 60, length = 10)\n |> tangentialArc(endAbsolute = [15, 15])\n |> line(end = [10, -15])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 60, length = 10)\n |> tangentialArc(radius = 10, angle = -120)\n |> angledLine(angle = -60, length = 10)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 45, length = 10)\n |> tangentialArc(end = [0, -10])\n |> line(end = [-10, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 60, length = 10)\n |> tangentialArc(endAbsolute = [15, 15])\n |> line(end = [10, -15])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 60, length = 10)\n |> tangentialArc(radius = 10, angle = -120)\n |> angledLine(angle = -60, length = 10)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -330777,7 +332365,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine(angle = 50, length = 10 * tau())\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> angledLine(angle = 50, length = 10 * tau())\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -340571,11 +342159,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(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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 a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfile(at = [0.05, 0.05])\n |> line(end = [0, 7])\n |> tangentialArc(angle = 90, radius = 5)\n |> line(end = [-3, 0])\n |> tangentialArc(angle = -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\n// Circle so you actually see the move.\nstartSketchOn(XY)\n |> circle(center = [-10, -10], radius = 10)\n |> extrude(length = 10)\n\ncube\n |> translate(x = 10.0, y = 10.0, z = 2.5)", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\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, angle = -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)\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(z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfile(sketch001, at = [-200, 23.86])\n |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001)\n |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61)\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001))\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfile(sketch002, at = [0, 0])\n |> yLine(length = 231.81)\n |> tangentialArc(radius = 80, angle = -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 |> startProfile(at = 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)\n |> extrude(length = 10)", + "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfile(sketch001, at = [-10, 10])\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(z = 20)\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" ] }, { @@ -345410,9 +346998,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Union two cubes using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nunionedPart = union([part001, part002])", - "// Union two cubes using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: union([part001, part002])\nunionedPart = part001 + part002", - "// Union two cubes using the more programmer-friendly operator.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfileAt([center[0] - size, center[1] - size], %)\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n // This is the equivalent of: union([part001, part002])\n // Programmers will understand `|` as a union operation, but mechanical engineers\n// will understand `+`, we made both work.\nunionedPart = part001 | part002" + "// Union two cubes using the stdlib functions.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\nunionedPart = union([part001, part002])", + "// Union two cubes using operators.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n// This is the equivalent of: union([part001, part002])\nunionedPart = part001 + part002", + "// Union two cubes using the more programmer-friendly operator.\n// NOTE: This will not work when using codemods through the UI.\n// Codemods will generate the stdlib function call instead.\n\n\nfn cube(center, size) {\n return startSketchOn(XY)\n |> startProfile(at = [center[0] - size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] - size])\n |> line(endAbsolute = [center[0] + size, center[1] + size])\n |> line(endAbsolute = [center[0] - size, center[1] + size])\n |> close()\n |> extrude(length = 10)\n}\n\npart001 = cube([0, 0], 10)\npart002 = cube([7, 3], 5)\n |> translate(z = 1)\n\n // This is the equivalent of: union([part001, part002])\n // Programmers will understand `|` as a union operation, but mechanical engineers\n// will understand `+`, we made both work.\nunionedPart = part001 | part002" ] }, { @@ -353580,7 +355168,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> xLine(length = 15)\n |> angledLine(angle = 80, length = 15)\n |> line(end = [8, -10])\n |> xLine(length = 10)\n |> angledLine(angle = 120, length = 30)\n |> xLine(length = -15)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> xLine(length = 15)\n |> angledLine(angle = 80, length = 15)\n |> line(end = [8, -10])\n |> xLine(length = 10)\n |> angledLine(angle = 120, length = 30)\n |> xLine(length = -15)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -361748,7 +363336,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> yLine(length = 15)\n |> angledLine(angle = 30, length = 15)\n |> line(end = [8, -10])\n |> yLine(length = -5)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "exampleSketch = startSketchOn(XZ)\n |> startProfile(at = [0, 0])\n |> yLine(length = 15)\n |> angledLine(angle = 30, length = 15)\n |> line(end = [8, -10])\n |> yLine(length = -5)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] } ] \ No newline at end of file diff --git a/docs/kcl/subtract.md b/docs/kcl/subtract.md index e3f704956..ff85cf048 100644 --- a/docs/kcl/subtract.md +++ b/docs/kcl/subtract.md @@ -38,7 +38,7 @@ subtract( fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -63,7 +63,7 @@ subtractedPart = subtract([part001], tools = [part002]) fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/docs/kcl/sweep.md b/docs/kcl/sweep.md index c0207f747..a0f3746f6 100644 --- a/docs/kcl/sweep.md +++ b/docs/kcl/sweep.md @@ -45,7 +45,7 @@ sweep( // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -90,7 +90,7 @@ springSketch = startSketchOn(YZ) sketch001 = startSketchOn(XY) -rectangleSketch = startProfileAt([-200, 23.86], sketch001) +rectangleSketch = startProfile(sketch001, at = [-200, 23.86]) |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -100,7 +100,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) sketch002 = startSketchOn(YZ) -sweepPath = startProfileAt([0, 0], sketch002) +sweepPath = startProfile(sketch002, at = [0, 0]) |> yLine(length = 231.81) |> tangentialArc(radius = 80, angle = -90) |> xLine(length = 384.93) @@ -118,7 +118,7 @@ sketch001 = startSketchOn(XY) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) sketch002 = startSketchOn(YZ) -sweepPath = startProfileAt([0, 0], sketch002) +sweepPath = startProfile(sketch002, at = [0, 0]) |> yLine(length = 231.81) |> tangentialArc(radius = 80, angle = -90) |> xLine(length = 384.93) diff --git a/docs/kcl/tangentToEnd.md b/docs/kcl/tangentToEnd.md index 5c6a893b3..a0637823c 100644 --- a/docs/kcl/tangentToEnd.md +++ b/docs/kcl/tangentToEnd.md @@ -29,7 +29,7 @@ tangentToEnd(tag: TagIdentifier): number ```js // Horizontal pill. pillSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [20, 0]) |> tangentialArc(end = [0, 10], tag = $arc1) |> angledLine(angle = tangentToEnd(arc1), length = 20) @@ -44,7 +44,7 @@ pillExtrude = extrude(pillSketch, length = 10) ```js // Vertical pill. Use absolute coordinate for arc. pillSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> tangentialArc(endAbsolute = [10, 20], tag = $arc1) |> angledLine(angle = tangentToEnd(arc1), length = 20) @@ -58,7 +58,7 @@ pillExtrude = extrude(pillSketch, length = 10) ```js rectangleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0], tag = $seg1) |> angledLine(angle = tangentToEnd(seg1), length = 10) |> line(end = [0, 10]) @@ -72,7 +72,7 @@ rectangleExtrude = extrude(rectangleSketch, length = 10) ```js bottom = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> arc(endAbsolute = [10, 10], interiorAbsolute = [5, 1], tag = $arc1) |> angledLine(angle = tangentToEnd(arc1), length = 20) |> close() @@ -85,7 +85,7 @@ circSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 3, tag = $circ) triangleSketch = startSketchOn(XY) - |> startProfileAt([-5, 0], %) + |> startProfile(at = [-5, 0]) |> angledLine(angle = tangentToEnd(circ), length = 10) |> line(end = [-15, 0]) |> close() diff --git a/docs/kcl/tangentialArc.md b/docs/kcl/tangentialArc.md index 148187c13..a37579a84 100644 --- a/docs/kcl/tangentialArc.md +++ b/docs/kcl/tangentialArc.md @@ -40,7 +40,7 @@ tangentialArc( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 45, length = 10) |> tangentialArc(end = [0, -10]) |> line(end = [-10, 0]) @@ -53,7 +53,7 @@ example = extrude(exampleSketch, length = 10) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = 10) |> tangentialArc(endAbsolute = [15, 15]) |> line(end = [10, -15]) @@ -66,7 +66,7 @@ example = extrude(exampleSketch, length = 10) ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = 10) |> tangentialArc(radius = 10, angle = -120) |> angledLine(angle = -60, length = 10) diff --git a/docs/kcl/tangentialArcTo.md b/docs/kcl/tangentialArcTo.md deleted file mode 100644 index 4c517946d..000000000 --- a/docs/kcl/tangentialArcTo.md +++ /dev/null @@ -1,48 +0,0 @@ ---- -title: "tangentialArcTo" -excerpt: "Starting at the current sketch's origin, draw a curved line segment along some part of an imaginary circle until it reaches the desired (x, y) coordinates." -layout: manual ---- - -Starting at the current sketch's origin, draw a curved line segment along some part of an imaginary circle until it reaches the desired (x, y) coordinates. - - - -```js -tangentialArcTo( - to: [number], - sketch: Sketch, - tag?: TagDeclarator, -): Sketch -``` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `to` | [`[number]`](/docs/kcl/types/number) | | Yes | -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | | Yes | -| [`tag`](/docs/kcl/types/tag) | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | | No | - -### Returns - -[`Sketch`](/docs/kcl/types/Sketch) - - -### Examples - -```js -exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) - |> angledLine(angle = 60, length = 10) - |> tangentialArcTo([15, 15], %) - |> line(end = [10, -15]) - |> close() - -example = extrude(exampleSketch, length = 10) -``` - -![Rendered example of tangentialArcTo 0]() - - diff --git a/docs/kcl/tangentialArcToRelative.md b/docs/kcl/tangentialArcToRelative.md deleted file mode 100644 index f277bfbb1..000000000 --- a/docs/kcl/tangentialArcToRelative.md +++ /dev/null @@ -1,48 +0,0 @@ ---- -title: "tangentialArcToRelative" -excerpt: "Starting at the current sketch's origin, draw a curved line segment along some part of an imaginary circle until it reaches a point the given (x, y) distance away." -layout: manual ---- - -Starting at the current sketch's origin, draw a curved line segment along some part of an imaginary circle until it reaches a point the given (x, y) distance away. - - - -```js -tangentialArcToRelative( - delta: [number], - sketch: Sketch, - tag?: TagDeclarator, -): Sketch -``` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `delta` | [`[number]`](/docs/kcl/types/number) | | Yes | -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | | Yes | -| [`tag`](/docs/kcl/types/tag) | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | | No | - -### Returns - -[`Sketch`](/docs/kcl/types/Sketch) - - -### Examples - -```js -exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) - |> angledLine(angle = 45, length = 10) - |> tangentialArcToRelative([0, -10], %) - |> line(end = [-10, 0]) - |> close() - -example = extrude(exampleSketch, length = 10) -``` - -![Rendered example of tangentialArcToRelative 0]() - - diff --git a/docs/kcl/tau.md b/docs/kcl/tau.md index 48f51783a..60a25f16d 100644 --- a/docs/kcl/tau.md +++ b/docs/kcl/tau.md @@ -29,7 +29,7 @@ tau(): number ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 50, length = 10 * tau()) |> yLine(endAbsolute = 0) |> close() diff --git a/docs/kcl/translate.md b/docs/kcl/translate.md index e3330886b..14419ae2e 100644 --- a/docs/kcl/translate.md +++ b/docs/kcl/translate.md @@ -43,7 +43,7 @@ translate( // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -85,7 +85,7 @@ cube sketch001 = startSketchOn(XY) -rectangleSketch = startProfileAt([-200, 23.86], sketch001) +rectangleSketch = startProfile(sketch001, at = [-200, 23.86]) |> angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 50.61) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -95,7 +95,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) sketch002 = startSketchOn(YZ) -sweepPath = startProfileAt([0, 0], sketch002) +sweepPath = startProfile(sketch002, at = [0, 0]) |> yLine(length = 231.81) |> tangentialArc(radius = 80, angle = -90) |> xLine(length = 384.93) @@ -125,7 +125,7 @@ fn square(length) { p3 = [l, -l] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) @@ -144,7 +144,7 @@ square(10) sketch001 = startSketchOn(XY) fn square() { - return startProfileAt([-10, 10], sketch001) + return startProfile(sketch001, at = [-10, 10]) |> xLine(length = 20) |> yLine(length = -20) |> xLine(length = -20) diff --git a/docs/kcl/types.md b/docs/kcl/types.md index 7e993aaa2..cf454d512 100644 --- a/docs/kcl/types.md +++ b/docs/kcl/types.md @@ -169,7 +169,7 @@ startSketchOn(XZ) Note that we are still in the process of migrating KCL's standard library to use keyword arguments. So some functions are still unfortunately using positional arguments. We're moving them over, so keep checking back. -Some functions like `angledLine`, `startProfileAt` etc are still using the old positional argument syntax. +Some functions are still using the old positional argument syntax. Check the docs page for each function and look at its examples to see. ## Tags @@ -183,7 +183,7 @@ way: ```norun startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, @@ -218,7 +218,7 @@ However if the code was written like this: ```norun fn rect(origin) { return startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, @@ -248,7 +248,7 @@ For example the following code works. ```norun fn rect(origin) { return startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, diff --git a/docs/kcl/types/Sketch.md b/docs/kcl/types/Sketch.md index 22753afa1..c0cd6408d 100644 --- a/docs/kcl/types/Sketch.md +++ b/docs/kcl/types/Sketch.md @@ -10,7 +10,7 @@ When you define a sketch to a variable like: ```js mySketch = startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -28,7 +28,7 @@ you can use a function. ```js fn createSketch() { return startSketchOn(XY) - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) diff --git a/docs/kcl/types/Solid.md b/docs/kcl/types/Solid.md index 99122fc63..9bda8bd12 100644 --- a/docs/kcl/types/Solid.md +++ b/docs/kcl/types/Solid.md @@ -10,7 +10,7 @@ When you define a solid to a variable like: ```js myPart = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -29,7 +29,7 @@ you can use a function. ```js fn createPart() { return startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) diff --git a/docs/kcl/types/tag.md b/docs/kcl/types/tag.md index f224f200d..747bf2f5b 100644 --- a/docs/kcl/types/tag.md +++ b/docs/kcl/types/tag.md @@ -13,7 +13,7 @@ way: ```js startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, @@ -47,7 +47,7 @@ However if the code was written like this: ```js fn rect(origin) { return startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, @@ -76,7 +76,7 @@ For example the following code works. ```js fn rect(origin) { return startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, diff --git a/docs/kcl/union.md b/docs/kcl/union.md index b192d282f..68252b23b 100644 --- a/docs/kcl/union.md +++ b/docs/kcl/union.md @@ -36,7 +36,7 @@ union( fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -61,7 +61,7 @@ unionedPart = union([part001, part002]) fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -87,7 +87,7 @@ unionedPart = part001 + part002 fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/docs/kcl/xLine.md b/docs/kcl/xLine.md index 1614e2dc5..f5aceb9fb 100644 --- a/docs/kcl/xLine.md +++ b/docs/kcl/xLine.md @@ -36,7 +36,7 @@ xLine( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 15) |> angledLine(angle = 80, length = 15) |> line(end = [8, -10]) diff --git a/docs/kcl/yLine.md b/docs/kcl/yLine.md index 6f7d38e20..7485c571f 100644 --- a/docs/kcl/yLine.md +++ b/docs/kcl/yLine.md @@ -36,7 +36,7 @@ yLine( ```js exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = 15) |> angledLine(angle = 30, length = 15) |> line(end = [8, -10]) diff --git a/e2e/playwright/basic-sketch.spec.ts b/e2e/playwright/basic-sketch.spec.ts index 5abf1722a..788cef611 100644 --- a/e2e/playwright/basic-sketch.spec.ts +++ b/e2e/playwright/basic-sketch.spec.ts @@ -57,7 +57,7 @@ async function doBasicSketch( await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) if (openPanes.includes('code')) { await expect(u.codeLocator).toContainText( - `sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` + `sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt})` ) } await page.waitForTimeout(500) @@ -67,7 +67,7 @@ async function doBasicSketch( if (openPanes.includes('code')) { await expect( u.codeLocator - ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt}) |> xLine(length = ${commonPoints.num1})`) } await page.waitForTimeout(500) @@ -75,9 +75,9 @@ async function doBasicSketch( if (openPanes.includes('code')) { await expect( u.codeLocator - ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${ commonPoints.startAt - }, sketch001) + }) |> xLine(length = ${commonPoints.num1}) |> yLine(length = ${commonPoints.num1 + 0.01})`) } else { @@ -88,9 +88,9 @@ async function doBasicSketch( if (openPanes.includes('code')) { await expect( u.codeLocator - ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, ${ commonPoints.startAt - }, sketch001) + }) |> xLine(length = ${commonPoints.num1}) |> yLine(length = ${commonPoints.num1 + 0.01}) |> xLine(length = ${commonPoints.num2 * -1})`) @@ -146,9 +146,9 @@ async function doBasicSketch( await u.openKclCodePanel() await expect( u.codeLocator - ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${ commonPoints.startAt - }, sketch001) + }) |> xLine(length = ${commonPoints.num1}, tag = $seg01) |> yLine(length = ${commonPoints.num1 + 0.01}) |> xLine(length = -segLen(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 bda3c3b71..3ec4f1332 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('Can create sketches on all planes and their back sides', () => { }, } - const code = `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(${plane})profile001 = startProfileAt([0.91, -1.22], sketch001)` + const code = `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(${plane})profile001 = startProfile(sketch001, at = [0.91, -1.22])` await u.openDebugPanel() diff --git a/e2e/playwright/code-pane-and-errors.spec.ts b/e2e/playwright/code-pane-and-errors.spec.ts index 52989c8e8..30554acfe 100644 --- a/e2e/playwright/code-pane-and-errors.spec.ts +++ b/e2e/playwright/code-pane-and-errors.spec.ts @@ -22,7 +22,7 @@ test.describe('Code pane and errors', () => { `@settings(defaultLengthUnit = in) // Extruded Triangle sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [-5, 10]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/e2e/playwright/command-bar-tests.spec.ts b/e2e/playwright/command-bar-tests.spec.ts index 0b67e7556..bbf57af76 100644 --- a/e2e/playwright/command-bar-tests.spec.ts +++ b/e2e/playwright/command-bar-tests.spec.ts @@ -14,7 +14,7 @@ test.describe('Command bar tests', () => { localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> xLine(length = -20) @@ -53,7 +53,7 @@ test.describe('Command bar tests', () => { localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-5, -5], %) + |> startProfile(at = [-5, -5]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -236,7 +236,7 @@ test.describe('Command bar tests', () => { 'persistCode', `distance = sqrt(20) sketch001 = startSketchOn(XZ) - |> startProfileAt([-6.95, 10.98], %) + |> startProfile(at = [-6.95, 10.98]) |> line(end = [25.1, 0.41]) |> line(end = [0.73, -20.93]) |> line(end = [-23.44, 0.52]) diff --git a/e2e/playwright/copilot-ghost-test.spec.ts b/e2e/playwright/copilot-ghost-test.spec.ts index c507176d4..a178da769 100644 --- a/e2e/playwright/copilot-ghost-test.spec.ts +++ b/e2e/playwright/copilot-ghost-test.spec.ts @@ -20,7 +20,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -29,7 +29,7 @@ test.describe('Copilot ghost text', () => { // We should be able to hit Tab to accept the completion. await page.keyboard.press('Tab') await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) // Hit enter a few times. @@ -37,7 +37,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-content')).toHaveText( - `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) ` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20) ` ) await expect(page.locator('.cm-ghostText')).not.toBeVisible() @@ -80,7 +80,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -89,7 +89,7 @@ test.describe('Copilot ghost text', () => { // We should be able to hit Tab to accept the completion. await page.keyboard.press('Tab') await expect(page.locator('.cm-content')).toContainText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) }) @@ -156,7 +156,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ)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)` + `sketch001 = startSketchOn(XZ)fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -165,7 +165,7 @@ test.describe('Copilot ghost text', () => { // We should be able to hit Tab to accept the completion. await page.keyboard.press('Tab') await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ)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)` + `sketch001 = startSketchOn(XZ)fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) // Hit enter a few times. @@ -173,7 +173,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ)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) ` + `sketch001 = startSketchOn(XZ)fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20) ` ) await expect(page.locator('.cm-ghostText')).not.toBeVisible() @@ -194,7 +194,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -225,7 +225,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -256,7 +256,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -287,7 +287,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -315,7 +315,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -326,7 +326,7 @@ test.describe('Copilot ghost text', () => { await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) }) @@ -348,7 +348,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -409,7 +409,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `{thing: "blah"}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)` + `{thing: "blah"}fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -450,7 +450,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -483,7 +483,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` @@ -514,7 +514,7 @@ test.describe('Copilot ghost text', () => { await page.keyboard.press('Enter') await expect(page.locator('.cm-ghostText').first()).toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `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)` + `fn cube = (pos, scale) => { sg = startSketchOn(XY) |> startProfile(at = pos) |> line(end = [0, scale], %) |> line(end = [scale, 0]) |> line(end = [0, -scale]) return sg}part001 = cube([0,0], 20) |> close() |> extrude(length = 20)` ) await expect(page.locator('.cm-ghostText').first()).toHaveText( `fn cube = (pos, scale) => {` diff --git a/e2e/playwright/debug-pane.spec.ts b/e2e/playwright/debug-pane.spec.ts index 81514761f..5fa807a59 100644 --- a/e2e/playwright/debug-pane.spec.ts +++ b/e2e/playwright/debug-pane.spec.ts @@ -18,7 +18,7 @@ test.describe('Debug pane', () => { homePage, }) => { const code = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [1, 1]) ` const u = await getUtils(page) diff --git a/e2e/playwright/editor-tests.spec.ts b/e2e/playwright/editor-tests.spec.ts index 64f3e281f..ba7dc4ab1 100644 --- a/e2e/playwright/editor-tests.spec.ts +++ b/e2e/playwright/editor-tests.spec.ts @@ -21,7 +21,7 @@ test.describe('Editor tests', () => { await u.codeLocator.click() await page.keyboard.type(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -34,7 +34,7 @@ test.describe('Editor tests', () => { await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -49,7 +49,7 @@ sketch001 = startSketchOn(XY) await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -69,7 +69,7 @@ sketch001 = startSketchOn(XY) await u.codeLocator.click() await page.keyboard.type(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -122,7 +122,7 @@ sketch001 = startSketchOn(XY) await u.codeLocator.click() await page.keyboard.type(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -177,7 +177,7 @@ sketch001 = startSketchOn(XY) await u.codeLocator.click() await page.keyboard.type(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -188,7 +188,7 @@ sketch001 = startSketchOn(XY) await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -210,7 +210,7 @@ sketch001 = startSketchOn(XY) await u.codeLocator.click() await page.keyboard.type(`sketch_001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -239,7 +239,7 @@ sketch001 = startSketchOn(XY) await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch_001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -258,7 +258,7 @@ sketch_001 = startSketchOn(XY) test('fold gutters work', async ({ page, homePage }) => { const fullCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -267,7 +267,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -336,7 +336,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -383,7 +383,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -411,7 +411,7 @@ sketch_001 = startSketchOn(XY) await expect( page.locator('.cm-content') ).toHaveText(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -427,7 +427,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `sketch_001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -465,7 +465,7 @@ sketch_001 = startSketchOn(XY) await expect( page.locator('.cm-content') ).toHaveText(`sketch_001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -536,7 +536,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) |> close() @@ -661,7 +661,7 @@ sketch_001 = startSketchOn(XY) fn squareHole = (l, w) => { squareHoleSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2]) |> line(endAbsolute = [width / 2, length / 2]) |> line(endAbsolute = [-width / 2, length / 2]) @@ -724,7 +724,7 @@ sketch_001 = startSketchOn(XY) localStorage.setItem( 'persistCode', `box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $revolveAxis) @@ -732,7 +732,7 @@ sketch_001 = startSketchOn(XY) |> extrude(length = 10) sketch001 = startSketchOn(box, face = revolveAxis) - |> startProfileAt([5, 10], %) + |> startProfile(at = [5, 10]) |> line(end = [0, -10]) |> line(end = [2, 0]) |> line(end = [0, -10]) @@ -793,10 +793,10 @@ sketch_001 = startSketchOn(XY) await page.keyboard.press('Tab') await page.waitForTimeout(100) - await page.keyboard.type('12') - await page.waitForTimeout(100) await page.keyboard.press('Tab') await page.waitForTimeout(100) + await page.keyboard.type('12') + await page.waitForTimeout(100) await page.keyboard.press('Tab') await page.waitForTimeout(100) await page.keyboard.press('Tab') @@ -828,7 +828,7 @@ sketch_001 = startSketchOn(XY) await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([3.14, 12], %) + |> startProfile(%, at = [3.14, 12]) |> xLine(%, length = 5) // lin`.replaceAll('\n', '') ) @@ -868,9 +868,9 @@ sketch001 = startSketchOn(XZ) await page.keyboard.press('Tab') // accepting the auto complete, not a new line await page.keyboard.press('Tab') - await page.keyboard.type('12') await page.waitForTimeout(100) await page.keyboard.press('Tab') + await page.keyboard.type('12') await page.waitForTimeout(100) await page.keyboard.press('Tab') await page.waitForTimeout(100) @@ -903,7 +903,7 @@ sketch001 = startSketchOn(XZ) await expect(page.locator('.cm-content')).toHaveText( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([3.14, 12], %) + |> startProfile(%, at = [3.14, 12]) |> xLine(%, length = 5) // lin`.replaceAll('\n', '') ) }) @@ -918,7 +918,7 @@ sketch001 = startSketchOn(XZ) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -14.01], %) + |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> close()` @@ -954,7 +954,7 @@ sketch001 = startSketchOn(XZ) }) await page.waitForTimeout(100) - await page.getByText('startProfileAt([4.61, -14.01], %)').click() + await page.getByText('startProfile(at = [4.61, -14.01])').click() await expect(page.getByRole('button', { name: 'Extrude' })).toBeVisible() await page.getByRole('button', { name: 'Extrude' }).click() @@ -969,7 +969,7 @@ sketch001 = startSketchOn(XZ) // expect the code to have changed await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> close()extrude001 = extrude(sketch001, length = 5)` + `sketch001 = startSketchOn(XZ) |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> close()extrude001 = extrude(sketch001, length = 5)` ) // Now hit undo @@ -981,7 +981,7 @@ sketch001 = startSketchOn(XZ) await expect( page.locator('.cm-content') ).toHaveText(`sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -14.01], %) + |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> close()`) @@ -998,7 +998,7 @@ sketch001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit=in) sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -10.01], %) + |> startProfile(at = [4.61, -10.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -0.38]) |> close() @@ -1039,7 +1039,7 @@ sketch001 = startSketchOn(XZ) const dragPX = 40 - await page.getByText('startProfileAt([4.61, -10.01], %)').click() + await page.getByText('startProfile(at = [4.61, -10.01])').click() await expect( page.getByRole('button', { name: 'Edit Sketch' }) ).toBeVisible() @@ -1089,7 +1089,7 @@ sketch001 = startSketchOn(XZ) // expect the code to have changed await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([2.71, -2.71], %) + |> startProfile(at = [2.71, -2.71]) |> line(end = [15.4, -2.78]) |> tangentialArc(endAbsolute = [27.6, -3.05]) |> close() @@ -1104,7 +1104,7 @@ sketch001 = startSketchOn(XZ) await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([2.71, -2.71], %) + |> startProfile(at = [2.71, -2.71]) |> line(end = [15.4, -2.78]) |> tangentialArc(endAbsolute = [24.95, -0.38]) |> close() @@ -1119,7 +1119,7 @@ sketch001 = startSketchOn(XZ) await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([2.71, -2.71], %) + |> startProfile(at = [2.71, -2.71]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -0.38]) |> close() @@ -1135,7 +1135,7 @@ sketch001 = startSketchOn(XZ) await page.waitForTimeout(100) await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -10.01], %) + |> startProfile(at = [4.61, -10.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -0.38]) |> close() @@ -1288,7 +1288,7 @@ sketch001 = startSketchOn(XZ) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - profile001 = startProfileAt([100.00, 100.0], sketch001) + profile001 = startProfile(sketch001, at = [100.00, 100.0]) |> yLine(length = -100.0) |> xLine(length = 200.0) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/e2e/playwright/feature-tree-pane.spec.ts b/e2e/playwright/feature-tree-pane.spec.ts index fb1ee6f41..2bc34ff3e 100644 --- a/e2e/playwright/feature-tree-pane.spec.ts +++ b/e2e/playwright/feature-tree-pane.spec.ts @@ -8,7 +8,7 @@ const FEATURE_TREE_EXAMPLE_CODE = `export fn timesFive(x) { } export fn triangle() { return startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 10) |> line(end = [-10, -5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -17,7 +17,7 @@ export fn triangle() { length001 = timesFive(1) * 5 sketch001 = startSketchOn(XZ) - |> startProfileAt([20, 10], %) + |> startProfile(at = [20, 10]) |> line(end = [10, 10]) |> angledLine(angle = -45, length = length001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -27,7 +27,7 @@ triangle() |> extrude(length = 30) plane001 = offsetPlane(XY, offset = 10) sketch002 = startSketchOn(plane001) - |> startProfileAt([-20, 0], %) + |> startProfile(at = [-20, 0]) |> line(end = [5, -15]) |> xLine(length = -10) |> line(endAbsolute = [-40, 0]) @@ -37,7 +37,7 @@ extrude001 = extrude(sketch002, length = 10) ` const FEATURE_TREE_SKETCH_CODE = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 0, length = 4, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 2, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -397,9 +397,9 @@ test.describe('Feature Tree pane', () => { const beforeKclCode = `plane001 = offsetPlane(XY, offset = 5) sketch001 = startSketchOn(plane001) profile001 = circle(sketch001, center = [0, 20], radius = 12) -profile002 = startProfileAt([0, 7.25], sketch001) +profile002 = startProfile(sketch001, at = [0, 7.25]) |> xLine(length = 13.3) -profile003 = startProfileAt([0, -4.93], sketch001) +profile003 = startProfile(sketch001, at = [0, -4.93]) |> line(endAbsolute = [-5.56, 0])` await context.folderSetupFn(async (dir) => { const testProject = join(dir, 'test-sample') diff --git a/e2e/playwright/file-tree.spec.ts b/e2e/playwright/file-tree.spec.ts index dcfe922d1..abc0b1f8c 100644 --- a/e2e/playwright/file-tree.spec.ts +++ b/e2e/playwright/file-tree.spec.ts @@ -46,7 +46,7 @@ test.describe('integrations tests', () => { await scene.moveNoWhere() await editor.expectState({ activeLines: [ - '|>startProfileAt([75.8,317.2],%)//[$startCapTag,$EndCapTag]', + '|>startProfile(at=[75.8,317.2])//[$startCapTag,$EndCapTag]', ], highlightedCode: '', diagnostics: [], @@ -75,7 +75,7 @@ test.describe('integrations tests', () => { await page.waitForTimeout(1000) await editor.expectState({ activeLines: [ - '|>startProfileAt([75.8,317.2],%)//[$startCapTag,$EndCapTag]', + '|>startProfile(at=[75.8,317.2])//[$startCapTag,$EndCapTag]', ], highlightedCode: '', diagnostics: [], diff --git a/e2e/playwright/import-ui.spec.ts b/e2e/playwright/import-ui.spec.ts index a02e11a8e..8d87b0b59 100644 --- a/e2e/playwright/import-ui.spec.ts +++ b/e2e/playwright/import-ui.spec.ts @@ -20,7 +20,7 @@ test.describe('Import UI tests', () => { await fsp.writeFile( path.join(projectDir, 'toBeImported.kcl'), `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([281.54, 305.81], sketch001) +profile001 = startProfile(sketch001, at = [281.54, 305.81]) |> angledLine(angle = 0, length = 123.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 85.99) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -37,7 +37,7 @@ extrude(profile001, length = 100)` importedCube sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-134.53, -56.17], sketch001) +profile001 = startProfile(sketch001, at = [-134.53, -56.17]) |> angledLine(angle = 0, length = 79.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 76.28) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $seg01) @@ -73,7 +73,7 @@ sketch002 = startSketchOn(extrude001, face = seg01)` await test.step('check code highlight works for code define in the file being edited', async () => { await hoverOverNonImport() await editor.expectState({ - highlightedCode: 'startProfileAt([-134.53,-56.17],sketch001)', + highlightedCode: 'startProfile(sketch001,at = [-134.53,-56.17])', diagnostics: [], activeLines: ['import"toBeImported.kcl"asimportedCube'], }) diff --git a/e2e/playwright/point-click.spec.ts b/e2e/playwright/point-click.spec.ts index 68075fc7b..74876fd85 100644 --- a/e2e/playwright/point-click.spec.ts +++ b/e2e/playwright/point-click.spec.ts @@ -221,7 +221,7 @@ test.describe('Point-and-click tests', () => { afterChamferSelectSnippet: 'sketch002 = startSketchOn(extrude001, face = seg03)', afterRectangle1stClickSnippet: - 'startProfileAt([205.96, 254.59], sketch002)', + 'startProfile(sketch002, at = [205.96, 254.59])', afterRectangle2ndClickSnippet: `angledLine(angle=0,length=11.39,tag=$rectangleSegmentA002) |>angledLine(angle=segAng(rectangleSegmentA002)-90,length=105.26) |>angledLine(angle=segAng(rectangleSegmentA002),length=-segLen(rectangleSegmentA002)) @@ -245,7 +245,7 @@ test.describe('Point-and-click tests', () => { afterChamferSelectSnippet: 'sketch003 = startSketchOn(extrude001, face = seg04)', afterRectangle1stClickSnippet: - 'startProfileAt([-209.64, 255.28], sketch003)', + 'startProfile(sketch003, at = [-209.64, 255.28])', afterRectangle2ndClickSnippet: `angledLine(angle=0,length=11.56,tag=$rectangleSegmentA003) |>angledLine(angle=segAng(rectangleSegmentA003)-90,length=106.84) |>angledLine(angle=segAng(rectangleSegmentA003),length=-segLen(rectangleSegmentA003)) @@ -267,7 +267,7 @@ test.describe('Point-and-click tests', () => { afterChamferSelectSnippet: 'sketch004 = startSketchOn(extrude001, face = seg05)', afterRectangle1stClickSnippet: - 'startProfileAt([82.57, 322.96], sketch004)', + 'startProfile(sketch004, at = [82.57, 322.96])', afterRectangle2ndClickSnippet: `angledLine(angle=0,length=11.16,tag=$rectangleSegmentA004) |>angledLine(angle=segAng(rectangleSegmentA004)-90,length=103.07) |>angledLine(angle=segAng(rectangleSegmentA004),length=-segLen(rectangleSegmentA004)) @@ -285,7 +285,7 @@ test.describe('Point-and-click tests', () => { afterChamferSelectSnippet: 'sketch005 = startSketchOn(extrude001, face = seg06)', afterRectangle1stClickSnippet: - 'startProfileAt([-23.43, 19.69], sketch005)', + 'startProfile(sketch005, at = [-23.43, 19.69])', afterRectangle2ndClickSnippet: `angledLine(angle=0,length=9.1,tag=$rectangleSegmentA005) |>angledLine(angle=segAng(rectangleSegmentA005)-90,length=84.07) |>angledLine(angle=segAng(rectangleSegmentA005),length=-segLen(rectangleSegmentA005)) @@ -297,7 +297,7 @@ test.describe('Point-and-click tests', () => { await editor.expectEditor.toContain( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $yo) @@ -309,28 +309,28 @@ extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 30, tags = [getNextAdjacentEdge(seg02)], tag = $seg05) |> chamfer(length = 30, tags = [getNextAdjacentEdge(yo)], tag = $seg06) sketch005 = startSketchOn(extrude001, face = seg06) -profile004=startProfileAt([-23.43,19.69], sketch005) +profile004=startProfile(sketch005, at = [-23.43,19.69]) |> angledLine(angle = 0, length = 9.1, tag = $rectangleSegmentA005) |> angledLine(angle = segAng(rectangleSegmentA005) - 90, length = 84.07) |> angledLine(angle = segAng(rectangleSegmentA005), length = -segLen(rectangleSegmentA005)) |> line(endAbsolute=[profileStartX(%), profileStartY(%)]) |> close() sketch004 = startSketchOn(extrude001, face = seg05) -profile003 = startProfileAt([82.57, 322.96], sketch004) +profile003 = startProfile(sketch004, at = [82.57, 322.96]) |> angledLine(angle = 0, length = 11.16, tag = $rectangleSegmentA004) |> angledLine(angle = segAng(rectangleSegmentA004) - 90, length = 103.07) |> angledLine(angle = segAng(rectangleSegmentA004), length = -segLen(rectangleSegmentA004)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(extrude001, face = seg04) -profile002 = startProfileAt([-209.64, 255.28], sketch003) +profile002 = startProfile(sketch003, at = [-209.64, 255.28]) |> angledLine(angle = 0, length = 11.56, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 106.84) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(extrude001, face = seg03) -profile001 = startProfileAt([205.96, 254.59], sketch002) +profile001 = startProfile(sketch002, at = [205.96, 254.59]) |> angledLine(angle = 0, length = 11.39, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 105.26) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) @@ -384,7 +384,7 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) afterChamferSelectSnippet: 'sketch002 = startSketchOn(extrude001, face = seg03)', afterRectangle1stClickSnippet: - 'startProfileAt([205.96, 254.59], sketch002)', + 'startProfile(sketch002, at = [205.96, 254.59])', afterRectangle2ndClickSnippet: `angledLine(angle=0,length=11.39,tag=$rectangleSegmentA002) |>angledLine(angle=segAng(rectangleSegmentA002)-90,length=105.26) |>angledLine(angle=segAng(rectangleSegmentA002),length=-segLen(rectangleSegmentA002)) @@ -394,7 +394,7 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) await editor.expectEditor.toContain( `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) + |> startProfile(at = [75.8, 317.2]) |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $yo) @@ -416,7 +416,7 @@ chamf = chamfer( ], ) sketch002 = startSketchOn(extrude001, face = seg03) -profile001 = startProfileAt([205.96, 254.59], sketch002) +profile001 = startProfile(sketch002, at = [205.96, 254.59]) |> angledLine(angle = 0, length = 11.39, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 105.26) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) @@ -488,10 +488,10 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) const expectedCodeSnippets = { sketchOnXzPlane: `sketch001 = startSketchOn(XZ)`, - pointAtOrigin: `startProfileAt([${originSloppy.kcl[0]}, ${originSloppy.kcl[1]}], sketch001)`, + pointAtOrigin: `startProfile(sketch001, at = [${originSloppy.kcl[0]}, ${originSloppy.kcl[1]}])`, segmentOnXAxis: `xLine(length = ${xAxisSloppy.kcl[0]})`, - afterSegmentDraggedOffYAxis: `startProfileAt([${offYAxis.kcl[0]}, ${offYAxis.kcl[1]}], sketch001)`, - afterSegmentDraggedOnYAxis: `startProfileAt([${yAxisSloppy.kcl[0]}, ${yAxisSloppy.kcl[1]}], sketch001)`, + afterSegmentDraggedOffYAxis: `startProfile(sketch001, at = [${offYAxis.kcl[0]}, ${offYAxis.kcl[1]}])`, + afterSegmentDraggedOnYAxis: `startProfile(sketch001, at = [${yAxisSloppy.kcl[0]}, ${yAxisSloppy.kcl[1]}])`, } await test.step(`Start a sketch on the XZ plane`, async () => { @@ -546,7 +546,7 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) const initialCode = `closedSketch = startSketchOn(XZ) |> circle(center = [8, 5], radius = 2) openSketch = startSketchOn(XY) - |> startProfileAt([-5, 0], %) + |> startProfile(at = [-5, 0]) |> line(endAbsolute = [0, 5]) |> xLine(length = 5) |> tangentialArc(endAbsolute = [10, 0]) @@ -648,7 +648,7 @@ openSketch = startSketchOn(XY) }) => { // Code samples const initialCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-12, -6], %) + |> startProfile(at = [-12, -6]) |> line(end = [0, 12]) |> line(end = [24, 0]) |> line(end = [0, -12]) @@ -1197,7 +1197,7 @@ openSketch = startSketchOn(XY) }) => { page.on('console', console.log) const initialCode = `sketch001 = startSketchOn(XZ) - profile001 = startProfileAt([0, 0], sketch001) + profile001 = startProfile(sketch001, at = [0, 0]) |> yLine(length = 100) |> line(endAbsolute = [100, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -1637,7 +1637,7 @@ loft001 = loft([sketch001, sketch002]) sketch001 = startSketchOn(YZ) profile001 = circle(sketch001, center = [0, 0], radius = 500) sketch002 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = -500) |> tangentialArc(endAbsolute = [-2000, 500])`, }, @@ -1646,14 +1646,14 @@ sketch002 = startSketchOn(XZ) testPoint: { x: 710, y: 255 }, initialCode: `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(YZ) -profile001 = startProfileAt([-400, -400], sketch001) +profile001 = startProfile(sketch001, at = [-400, -400]) |> angledLine(angle = 0, length = 800, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 800) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = -500) |> tangentialArc(endAbsolute = [-2000, 500])`, }, @@ -1806,7 +1806,7 @@ sketch001 = startSketchOn(YZ) radius = 500 ) sketch002 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = -500) |> line(endAbsolute = [-2000, 500]) ` @@ -1880,7 +1880,7 @@ sketch002 = startSketchOn(XZ) }) => { // Code samples const initialCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-12, -6], %) + |> startProfile(at = [-12, -6]) |> line(end = [0, 12]) |> line(end = [24, 0]) |> line(end = [0, -12]) @@ -2221,7 +2221,7 @@ fillet001 = fillet(extrude001, radius = 5, tags = [getOppositeEdge(seg01)]) }) => { // Code samples const initialCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-12, -6], %) + |> startProfile(at = [-12, -6]) |> line(end = [0, 12]) |> line(end = [24, 0], tag = $seg02) |> line(end = [0, -12]) @@ -2364,7 +2364,7 @@ fillet04 = fillet(extrude001, radius = 5, tags = [getOppositeEdge(seg02)]) }) => { // Create a cube with small edges that will cause some fillets to fail const initialCode = `sketch001 = startSketchOn(XY) -profile001 = startProfileAt([0, 0], sketch001) +profile001 = startProfile(sketch001, at = [0, 0]) |> yLine(length = -1) |> xLine(length = -10) |> yLine(length = 10) @@ -2478,7 +2478,7 @@ extrude001 = extrude(profile001, length = 5) // Code samples const initialCode = `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-12, -6], %) + |> startProfile(at = [-12, -6]) |> line(end = [0, 12]) |> line(end = [24, 0]) |> line(end = [0, -12]) @@ -2779,7 +2779,7 @@ extrude001 = extrude(sketch001, length = -12) // Code samples const initialCode = `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-12, -6], %) + |> startProfile(at = [-12, -6]) |> line(end = [0, 12]) |> line(end = [24, 0], tag = $seg02) |> line(end = [0, -12]) @@ -3073,7 +3073,7 @@ extrude001 = extrude(sketch001, length = 30) }) => { const initialCode = `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) - |> startProfileAt([-20, 20], %) + |> startProfile(at = [-20, 20]) |> xLine(length = 40) |> yLine(length = -60) |> xLine(length = -40) @@ -3305,7 +3305,7 @@ extrude002 = extrude(sketch002, length = 50) cmdBar, }) => { const sketchCode = `sketch001 = startSketchOn(XY) -profile001 = startProfileAt([-20, 20], sketch001) +profile001 = startProfile(sketch001, at = [-20, 20]) |> xLine(length = 40) |> yLine(length = -60) |> xLine(length = -40) @@ -3393,7 +3393,7 @@ profile001 = startProfileAt([-20, 20], sketch001) radius = 500 ) sketch002 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = -2000) sweep001 = sweep(sketch001, path = sketch002) ` @@ -3451,7 +3451,7 @@ sweep001 = sweep(sketch001, path = sketch002) }) => { const initialCode = ` sketch001 = startSketchOn(XZ) -|> startProfileAt([-100.0, 100.0], %) +|> startProfile(at = [-100.0, 100.0]) |> angledLine(angle = 0, length = 200.0, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 200, tag = $rectangleSegmentB001) |> angledLine( @@ -3463,7 +3463,7 @@ tag=$rectangleSegmentC001, |> close() extrude001 = extrude(sketch001, length = 200) sketch002 = startSketchOn(extrude001, face = rectangleSegmentA001) -|> startProfileAt([-66.77, 84.81], %) +|> startProfile(at = [-66.77, 84.81]) |> angledLine(angle = 180, length = 27.08, tag = $rectangleSegmentA002) |> angledLine( angle=segAng(rectangleSegmentA002) - 90, @@ -3543,7 +3543,7 @@ tag=$rectangleSegmentC002, cmdBar, }) => { const initialCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([-102.57, 101.72], %) + |> startProfile(at = [-102.57, 101.72]) |> angledLine(angle = 0, length = 202.6, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 202.6, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -3628,10 +3628,10 @@ sketch002 = startSketchOn(extrude001, face = rectangleSegmentA001) }) => { const initialCode = ` sketch002 = startSketchOn(XY) - |> startProfileAt([-2.02, 1.79], %) + |> startProfile(at = [-2.02, 1.79]) |> xLine(length = 2.6) sketch001 = startSketchOn('-XY') - |> startProfileAt([-0.48, 1.25], %) + |> startProfile(at = [-0.48, 1.25]) |> angledLine(angle = 0, length = 2.38, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 2.4, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) diff --git a/e2e/playwright/projects.spec.ts b/e2e/playwright/projects.spec.ts index f6f5addf7..d8b45a6e5 100644 --- a/e2e/playwright/projects.spec.ts +++ b/e2e/playwright/projects.spec.ts @@ -1450,7 +1450,7 @@ test( ) await page.locator('.cm-content').fill(`sketch001 = startSketchOn('XZ') - |> startProfileAt([-87.4, 282.92], %) + |> startProfile(at = [-87.4, 282.92]) |> line(end = [324.07, 27.199], tag = $seg01) |> line(end = [118.328, -291.754]) |> line(end = [-180.04, -202.08]) diff --git a/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts b/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts index 14b102ebc..0a1250703 100644 --- a/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts +++ b/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts @@ -23,7 +23,7 @@ import { expect, test } from '@e2e/playwright/zoo-test' */ const file = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([57.81, 250.51], sketch001) +profile001 = startProfile(sketch001, at = [57.81, 250.51]) |> line(end = [121.13, 56.63], tag = $seg02) |> line(end = [83.37, -34.61], tag = $seg01) |> line(end = [19.66, -116.4]) @@ -32,7 +32,7 @@ profile001 = startProfileAt([57.81, 250.51], sketch001) |> close() extrude001 = extrude(profile001, length = 200) sketch002 = startSketchOn(XZ) - |> startProfileAt([-73.64, -42.89], %) + |> startProfile(at = [-73.64, -42.89]) |> xLine(length = 173.71) |> line(end = [-22.12, -94.4]) |> xLine(length = -156.98) @@ -40,7 +40,7 @@ sketch002 = startSketchOn(XZ) |> close() extrude002 = extrude(sketch002, length = 50) sketch003 = startSketchOn(XY) - |> startProfileAt([52.92, 157.81], %) + |> startProfile(at = [52.92, 157.81]) |> angledLine(angle = 0, length = 176.4, tag = $rectangleSegmentA001) |> angledLine( angle = segAng(rectangleSegmentA001) - 90, @@ -74,7 +74,7 @@ test.describe('edit with AI example snapshots', () => { await clickBody1Cap() await editor.expectState({ highlightedCode: '', - activeLines: ['|>startProfileAt([-73.64,-42.89],%)'], + activeLines: ['|>startProfile(at=[-73.64,-42.89])'], diagnostics: [], }) }) diff --git a/e2e/playwright/prompt-to-edit.spec.ts b/e2e/playwright/prompt-to-edit.spec.ts index b42a021d1..4f38c5652 100644 --- a/e2e/playwright/prompt-to-edit.spec.ts +++ b/e2e/playwright/prompt-to-edit.spec.ts @@ -3,7 +3,7 @@ import { expect, test } from '@e2e/playwright/zoo-test' /* eslint-disable jest/no-conditional-expect */ const file = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([57.81, 250.51], sketch001) +profile001 = startProfile(sketch001, at = [57.81, 250.51]) |> line(end = [121.13, 56.63], tag = $seg02) |> line(end = [83.37, -34.61], tag = $seg01) |> line(end = [19.66, -116.4]) @@ -12,7 +12,7 @@ profile001 = startProfileAt([57.81, 250.51], sketch001) |> close() extrude001 = extrude(profile001, length = 200) sketch002 = startSketchOn(XZ) - |> startProfileAt([-114, 85.52], %) + |> startProfile(at = [-114, 85.52]) |> xLine(length = 265.36) |> line(end = [33.17, -261.22]) |> xLine(length = -297.25) @@ -20,7 +20,7 @@ sketch002 = startSketchOn(XZ) |> close() extrude002 = extrude(sketch002, length = 50) sketch003 = startSketchOn(XY) - |> startProfileAt([52.92, 157.81], %) + |> startProfile(at = [52.92, 157.81]) |> angledLine(angle = 0, length = 176.4, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 53.4, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -82,7 +82,7 @@ test.describe('Prompt-to-edit tests', () => { await scene.expectPixelColor(yellow, body1CapCoords, 20) await editor.expectState({ highlightedCode: '', - activeLines: ['|>startProfileAt([-114,85.52],%)'], + activeLines: ['|>startProfile(at=[-114,85.52])'], diagnostics: [], }) }) @@ -170,7 +170,7 @@ test.describe('Prompt-to-edit tests', () => { await editor.expectState({ highlightedCode: '', - activeLines: ['|>startProfileAt([-114,85.52],%)'], + activeLines: ['|>startProfile(at=[-114,85.52])'], diagnostics: [], }) }) @@ -293,7 +293,7 @@ test.describe('Prompt-to-edit tests', () => { // Hold shift and select second body await editor.expectState({ highlightedCode: '', - activeLines: ['|>startProfileAt([-114,85.52],%)'], + activeLines: ['|>startProfile(at=[-114,85.52])'], diagnostics: [], }) await page.keyboard.down('Shift') @@ -304,7 +304,7 @@ test.describe('Prompt-to-edit tests', () => { 'line(end=[121.13,56.63],tag=$seg02)extrude(profile001,length=200)', activeLines: [ '|>line(end=[121.13,56.63],tag=$seg02)', - '|>startProfileAt([-114,85.52],%)', + '|>startProfile(at=[-114,85.52])', ], diagnostics: [], }) diff --git a/e2e/playwright/regression-tests.spec.ts b/e2e/playwright/regression-tests.spec.ts index ad6d8f9df..e96da04fc 100644 --- a/e2e/playwright/regression-tests.spec.ts +++ b/e2e/playwright/regression-tests.spec.ts @@ -29,7 +29,7 @@ test.describe('Regression tests', () => { 'persistCode', `sketch2 = startSketchOn("XY") sketch001 = startSketchOn("XY") - |> startProfileAt([-0, -0], %) + |> startProfile(at = [-0, -0]) |> line(end = [0, 0]) |> line(end = [-4.84, -5.29]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -66,7 +66,7 @@ test.describe('Regression tests', () => { localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([82.33, 238.21], %) + |> startProfile(at = [82.33, 238.21]) |> angledLine(angle = 0, length = 288.63, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 197.97, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -128,7 +128,7 @@ extrude001 = extrude(sketch001, length = 50) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(-XZ) - |> startProfileAt([-6.95, 4.98], %) + |> startProfile(at = [-6.95, 4.98]) |> line(end = [25.1, 0.41]) |> line(end = [0.73, -14.93]) |> line(end = [-23.44, 0.52])` @@ -189,7 +189,7 @@ extrude001 = extrude(sketch001, length = 50) localStorage.setItem( 'persistCode', `part = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -250,7 +250,7 @@ extrude001 = extrude(sketch001, length = 50) localStorage.setItem( 'persistCode', `exampleSketch = startSketchOn("XZ") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 50, length = 45 ) |> yLine(endAbsolute = 0) |> close() @@ -307,7 +307,7 @@ extrude001 = extrude(sketch001, length = 50) await expect( page.locator('.cm-content') ).toContainText(`exampleSketch = startSketchOn("XZ") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 50, length = 45 ) |> yLine(endAbsolute = 0) |> close() @@ -327,7 +327,7 @@ extrude001 = extrude(sketch001, length = 50) 'persistCode', `@settings(defaultLengthUnit = mm) sketch002 = startSketchOn(XY) -profile002 = startProfileAt([72.24, -52.05], sketch002) +profile002 = startProfile(sketch002, at = [72.24, -52.05]) |> angledLine(angle = 0, length = 181.26, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 21.54) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) diff --git a/e2e/playwright/sketch-tests.spec.ts b/e2e/playwright/sketch-tests.spec.ts index 85f9c7857..c62e3feab 100644 --- a/e2e/playwright/sketch-tests.spec.ts +++ b/e2e/playwright/sketch-tests.spec.ts @@ -26,9 +26,9 @@ test.describe('Sketch tests', () => { const u = await getUtils(page) const selectionsSnippets = { startProfileAt1: - '|> startProfileAt([-width / 4 + screwRadius, height / 2], %)', - startProfileAt2: '|> startProfileAt([-width / 2, 0], %)', - startProfileAt3: '|> startProfileAt([0, thickness], %)', + '|> startProfile(at = [-width / 4 + screwRadius, height / 2])', + startProfileAt2: '|> startProfile(at = [-width / 2, 0])', + startProfileAt3: '|> startProfile(at = [0, thickness])', } await context.addInitScript( async ({ startProfileAt1, startProfileAt2, startProfileAt3 }: any) => { @@ -108,7 +108,7 @@ test.describe('Sketch tests', () => { 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([2.61, -4.01], %) + |> startProfile(at = [2.61, -4.01]) |> xLine(length = 8.73) |> tangentialArc(endAbsolute = [8.33, -1.31])` ) @@ -158,7 +158,7 @@ sketch001 = startSketchOn(XZ) sketch002 = startSketchOn(XZ) -sketch001 = startProfileAt([12.34, -12.34], sketch002) +sketch001 = startProfile(sketch002, at = [12.34, -12.34]) |> yLine(length = 12.34) `) @@ -201,7 +201,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -14.01], %) + |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> arc(interiorAbsolute = [20.18, -1.7], endAbsolute = [11.82, -1.16]) @@ -244,7 +244,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // If we have the code pane open, we should see the code. if (openPanes.includes('code')) { await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -14.01], %) + |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> arc(interiorAbsolute = [20.18, -1.7], endAbsolute = [11.82, -1.16]) @@ -262,7 +262,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) let prevContent = '' if (openPanes.includes('code')) { - await page.getByText('startProfileAt([4.61, -14.01], %)').click() + await page.getByText('startProfile(at = [4.61, -14.01])').click() } else { // Wait for the render. await page.waitForTimeout(1000) @@ -383,7 +383,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await expect( page.locator('.cm-content') ).toHaveText(`sketch001 = startSketchOn(XZ) - |> startProfileAt([6.44, -12.07], %) + |> startProfile(at = [6.44, -12.07]) |> line(end = [14.72, 1.97]) |> tangentialArc(endAbsolute = [26.92, -3.32]) |> arc(interiorAbsolute = [18.11, -3.73], endAbsolute = [9.77, -3.19]) @@ -550,7 +550,7 @@ sketch001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit=in) sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -10.01], %) + |> startProfile(at = [4.61, -10.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -0.38]) |> close() @@ -590,7 +590,7 @@ sketch001 = startSketchOn(XZ) const dragPX = 40 - await page.getByText('startProfileAt([4.61, -10.01], %)').click() + await page.getByText('startProfile(at = [4.61, -10.01])').click() await expect( page.getByRole('button', { name: 'Edit Sketch' }) ).toBeVisible() @@ -636,7 +636,7 @@ sketch001 = startSketchOn(XZ) // expect the code to have changed await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([7.12, -12.68], %) + |> startProfile(at = [7.12, -12.68]) |> line(end = [12.68, -1.09]) |> tangentialArc(endAbsolute = [24.89, 0.68]) |> close() @@ -658,7 +658,7 @@ sketch001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit=in) sketch001 = startSketchOn(XZ) - |> startProfileAt([4.61, -14.01], %) + |> startProfile(at = [4.61, -14.01]) |> line(end = [12.73, -0.09]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> close() @@ -699,7 +699,7 @@ sketch001 = startSketchOn(XZ) const dragPX = 30 - await page.getByText('startProfileAt([4.61, -14.01], %)').click() + await page.getByText('startProfile(at = [4.61, -14.01])').click() await expect( page.getByRole('button', { name: 'Edit Sketch' }) ).toBeVisible() @@ -744,7 +744,7 @@ sketch001 = startSketchOn(XZ) // expect the code to have changed await editor.expectEditor.toContain( `sketch001 = startSketchOn(XZ) - |> startProfileAt([6.44, -12.07], %) + |> startProfile(at = [6.44, -12.07]) |> line(end = [14.72, 1.97]) |> tangentialArc(endAbsolute = [24.95, -5.38]) |> line(end = [1.97, 2.06]) @@ -788,7 +788,7 @@ sketch001 = startSketchOn(XZ) await page.waitForTimeout(500) // TODO detect animation ending, or disable animation await click00r(0, 0) - codeStr += `profile001 = startProfileAt(${toSU([0, 0])}, sketch001)` + codeStr += `profile001 = startProfile(sketch001, at = ${toSU([0, 0])})` await expect(u.codeLocator).toHaveText(codeStr) await click00r(50, 0) @@ -824,7 +824,7 @@ sketch001 = startSketchOn(XZ) await u.closeDebugPanel() await click00r(30, 0) - codeStr += `profile002 = startProfileAt([2.03, 0], sketch002)` + codeStr += `profile002 = startProfile(sketch002, at = [2.03, 0])` await expect(u.codeLocator).toHaveText(codeStr) // TODO: I couldn't use `toSU` here because of some rounding error causing @@ -861,9 +861,9 @@ sketch001 = startSketchOn(XZ) const code = `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(-XZ) -profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( +profile001 = startProfile(sketch001, at = [${roundOff(scale * 69.6)}, ${roundOff( scale * 34.8 - )}], sketch001) + )}]) |> xLine(length = ${roundOff(scale * 139.19)}) |> yLine(length = -${roundOff(scale * 139.2)}) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -968,7 +968,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([-0.45, 0.87], %) + |> startProfile(at = [-0.45, 0.87]) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) |> line(end = [-1.01, -0.77]) @@ -1026,7 +1026,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([-0.45, 0.87], %) + |> startProfile(at = [-0.45, 0.87]) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) |> line(end = [-1.01, -0.77]) @@ -1069,7 +1069,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await expect((await u.codeLocator.innerText()).replace(/\s/g, '')).toBe( `sketch001 = startSketchOn(XZ) - |> startProfileAt([-0.45, 0.87], %) + |> startProfile(at = [-0.45, 0.87]) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) |> line(end = [-1.01, -0.77]) @@ -1121,7 +1121,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await u.openAndClearDebugPanel() await u.codeLocator.fill(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> xLine(length = -20) @@ -1160,7 +1160,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.waitForTimeout(200) await page.mouse.click(XYPlanePoint.x + 50, XYPlanePoint.y + 50) await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ) - |> startProfileAt([11.8, 9.09], %) + |> startProfile(at = [11.8, 9.09]) |> line(end = [3.39, -3.39]) `) @@ -1168,7 +1168,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([11.8, 9.09], %) + |> startProfile(at = [11.8, 9.09]) |> line(end = [3.39, -3.39]) ` ) @@ -1197,7 +1197,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( fn lug = (origin, length, diameter, plane) => { lugSketch = startSketchOn(plane) - |> startProfileAt([origin[0] + lugDiameter / 2, origin[1]], %) + |> startProfile(at = [origin[0] + lugDiameter / 2, origin[1]]) |> angledLine(angle = 60, lengthY = lugHeadLength) |> xLine(endAbsolute = 0 + .001) |> yLine(endAbsolute = 0) @@ -1267,10 +1267,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( const railClampable = in2mm(.200) const rail = startSketchOn(XZ) - |> startProfileAt([ - -railTop / 2, - railClampable + railBaseLength - ], %) + |> startProfile(at = [-railTop / 2, railClampable + railBaseLength]) |> line(endAbsolute = [ railTop / 2, railClampable + railBaseLength @@ -1405,12 +1402,12 @@ test.describe('multi-profile sketching', () => { 'persistCode', `yo = 5 sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([121.52, 168.25], sketch001) +profile001 = startProfile(sketch001, at = [121.52, 168.25]) |> line(end = [115.04, 113.61]) |> line(end = [130.87, -97.79]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile002 = startProfileAt([117.2, 56.08], sketch001) +profile002 = startProfile(sketch001, at = [117.2, 56.08]) |> line(end = [166.82, 25.89]) |> yLine(length = -107.86) @@ -1490,12 +1487,12 @@ profile002 = startProfileAt([117.2, 56.08], sketch001) await toolbar.rectangleBtn.click() await page.waitForTimeout(100) await cornerRectPoint1() - await editor.expectEditor.toContain('profile004 = startProfileAt(') + await editor.expectEditor.toContain('profile004 = startProfile(') }) await test.step('equip line tool and verify corner rectangle code is removed', async () => { await toolbar.lineBtn.click() - await editor.expectEditor.not.toContain('profile004 = startProfileAt(') + await editor.expectEditor.not.toContain('profile004 = startProfile(') }) const [centerRectPoint1] = scene.makeMouseHelpers(700, 300) @@ -1504,12 +1501,12 @@ profile002 = startProfileAt([117.2, 56.08], sketch001) await toolbar.selectCenterRectangle() await page.waitForTimeout(100) await centerRectPoint1() - await editor.expectEditor.toContain('profile004 = startProfileAt(') + await editor.expectEditor.toContain('profile004 = startProfile(') }) await test.step('equip line tool and verify center rectangle code is removed', async () => { await toolbar.lineBtn.click() - await editor.expectEditor.not.toContain('profile004 = startProfileAt(') + await editor.expectEditor.not.toContain('profile004 = startProfile(') }) await test.step('continue profile002 with the three point arc tool, and then switch back to the line tool to verify it only removes the last expression in the pipe', async () => { @@ -1540,9 +1537,9 @@ profile002 = startProfileAt([117.2, 56.08], sketch001) `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile002 = startProfileAt([40.68, 87.67], sketch001) +profile002 = startProfile(sketch001, at = [40.68, 87.67]) |> xLine(length = 239.17) -profile003 = startProfileAt([206.63, -56.73], sketch001) +profile003 = startProfile(sketch001, at = [206.63, -56.73]) |> xLine(length = -156.32) ` ) @@ -1649,7 +1646,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) .toBe('true') await startProfile1() - await editor.expectEditor.toContain(`profile001 = startProfileAt`) + await editor.expectEditor.toContain(`profile001 = startProfile`) await segment1Clk() await editor.expectEditor.toContain(`|> line(end`) }) @@ -1682,7 +1679,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await test.step('add two segments', async () => { await startProfile1() await editor.expectEditor.toContain( - `profile001 = startProfileAt([4.61, 12.21], sketch001)` + `profile001 = startProfile(sketch001, at = [4.61, 12.21])` ) await segment1Clk() await editor.expectEditor.toContain(`|> line(end`) @@ -1778,7 +1775,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await test.step('Create a close profile stopping mid profile to equip the tangential arc, then three-point arc, and then back to the line tool', async () => { await startProfile1() await editor.expectEditor.toContain( - `profile001 = startProfileAt([4.61, 12.21], sketch001)` + `profile001 = startProfile(sketch001, at = [4.61, 12.21])` ) await endLineStartTanArc() @@ -1847,7 +1844,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await startProfile2() await page.waitForTimeout(300) await editor.expectEditor.toContain( - `profile002 = startProfileAt([19.12, 11.53], sketch001)` + `profile002 = startProfile(sketch001, at = [19.12, 11.53])` ) await profile2Point2() await page.waitForTimeout(300) @@ -1890,7 +1887,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await crnRect1point1() await editor.expectEditor.toContain( - `profile005 = startProfileAt([5.63, 3.05], sketch001)` + `profile005 = startProfile(sketch001, at = [5.63, 3.05])` ) await crnRect1point2() await editor.expectEditor.toContain( @@ -1904,7 +1901,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await crnRect2point1() await page.waitForTimeout(300) await editor.expectEditor.toContain( - `profile006 = startProfileAt([11.05, 2.37], sketch001)` + `profile006 = startProfile(sketch001, at = [11.05, 2.37])` ) await crnRect2point2() await page.waitForTimeout(300) @@ -1923,7 +1920,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await cntrRect1point1() await page.waitForTimeout(300) await editor.expectEditor.toContain( - `profile007 = startProfileAt([8.41, -9.29], sketch001)` + `profile007 = startProfile(sketch001, at = [8.41, -9.29])` ) await cntrRect1point2() await page.waitForTimeout(300) @@ -1939,7 +1936,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await cntrRect2point1() await page.waitForTimeout(300) await editor.expectEditor.toContain( - `profile008 = startProfileAt([19.33, -5.56], sketch001)` + `profile008 = startProfile(sketch001, at = [19.33, -5.56])` ) await cntrRect2point2() await page.waitForTimeout(300) @@ -2041,7 +2038,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) // Verify the first three-point arc was created correctly await editor.expectEditor.toContain( - `profile011 = startProfileAt([13.56, -9.97], sketch001) + `profile011 = startProfile(sketch001, at = [13.56, -9.97]) |> arc(interiorAbsolute = [15.19, -6.51], endAbsolute = [19.33, -11.19])`, { shouldNormalise: true } ) @@ -2089,11 +2086,11 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([6.24, 4.54], sketch001) +profile001 = startProfile(sketch001, at = [6.24, 4.54]) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) |> line(end = [10.99, -5.22]) -profile002 = startProfileAt([11.19, 5.02], sketch001) +profile002 = startProfile(sketch001, at = [11.19, 5.02]) |> angledLine(angle = 0, length = 10.78, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 4.14) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -2201,7 +2198,7 @@ profile004 = circleThreePoint(sketch001, p1 = [13.44, -6.8], p2 = [13.39, -2.07] await page.waitForTimeout(100) await rectStart() await editor.expectEditor.toContain( - `profile005 = startProfileAt([15.68, -3.84], sketch001)` + `profile005 = startProfile(sketch001, at = [15.68, -3.84])` ) await page.waitForTimeout(100) await rectEnd() @@ -2227,11 +2224,11 @@ profile004 = circleThreePoint(sketch001, p1 = [13.44, -6.8], p2 = [13.39, -2.07] 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([6.24, 4.54], sketch001) +profile001 = startProfile(sketch001, at = [6.24, 4.54]) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) |> line(end = [10.99, -5.22]) -profile002 = startProfileAt([11.19, 5.02], sketch001) +profile002 = startProfile(sketch001, at = [11.19, 5.02]) |> angledLine(angle = 0, length = 10.78, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 4.14) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -2329,14 +2326,14 @@ profile003 = circle(sketch001, center = [6.92, -4.2], radius = 3.16) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-63.43, 193.08], sketch001) +profile001 = startProfile(sketch001, at = [-63.43, 193.08]) |> line(end = [168.52, 149.87]) |> line(end = [190.29, -39.18]) |> tangentialArc(endAbsolute = [319.63, 129.65]) |> line(end = [-217.65, -21.76]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile003 = startProfileAt([16.79, 38.24], sketch001) +profile003 = startProfile(sketch001, at = [16.79, 38.24]) |> angledLine(angle = 0, length = 182.82, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 105.71) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -2441,13 +2438,13 @@ extrude001 = extrude(profile003, length = 5) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([85.19, 338.59], sketch001) +profile001 = startProfile(sketch001, at = [85.19, 338.59]) |> line(end = [213.3, -94.52]) |> line(end = [-230.09, -55.34]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(XY) -profile002 = startProfileAt([85.81, 52.55], sketch002) +profile002 = startProfile(sketch002, at = [85.81, 52.55]) ` ) @@ -2461,7 +2458,7 @@ profile002 = startProfileAt([85.81, 52.55], sketch002) const [startProfileAt] = scene.makeMouseHelpers(606, 184) const [nextPoint] = scene.makeMouseHelpers(763, 130) - await page.getByText('startProfileAt([85.81, 52.55], sketch002)').click() + await page.getByText('startProfile(sketch002, at = [85.81, 52.55])').click() await toolbar.editSketch(1) // timeout wait for engine animation is unavoidable await page.waitForTimeout(600) @@ -2486,7 +2483,7 @@ profile002 = startProfileAt([85.81, 52.55], sketch002) 'persistCode', `@settings(defaultLengthUnit = in) thePart = startSketchOn(XZ) - |> startProfileAt([7.53, 10.51], %) + |> startProfile(at = [7.53, 10.51]) |> line(end = [12.54, 1.83]) |> line(end = [6.65, -6.91]) |> line(end = [-6.31, -8.69]) @@ -2516,21 +2513,21 @@ extrude001 = extrude(thePart, length = 75) await test.step('expect code to match initial conditions still', async () => { await editor.expectEditor.toContain( - `thePart = startSketchOn(XZ) |> startProfileAt([7.53, 10.51], %)` + `thePart = startSketchOn(XZ) |> startProfile(at = [7.53, 10.51])` ) }) await test.step('equiping the line tool should break up the pipe expression', async () => { await toolbar.lineBtn.click() await editor.expectEditor.toContain( - `sketch001 = startSketchOn(XZ)thePart = startProfileAt([7.53, 10.51], sketch001)` + `sketch001 = startSketchOn(XZ)thePart = startProfile(sketch001, at = [7.53, 10.51])` ) }) await test.step('can continue on to add a new profile to this sketch', async () => { await profilePoint1() await editor.expectEditor.toContain( - `profile001 = startProfileAt([19.69, -7.05], sketch001)` + `profile001 = startProfile(sketch001, at = [19.69, -7.05])` ) await profilePoint2() await editor.expectEditor.toContain(`|> line(end = [18.97, -18.06])`) @@ -2551,29 +2548,29 @@ extrude001 = extrude(thePart, length = 75) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([6.71, -3.66], sketch001) +profile001 = startProfile(sketch001, at = [6.71, -3.66]) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 20) sketch002 = startSketchOn(extrude001, face = seg01) -profile002 = startProfileAt([0.75, 13.46], sketch002) +profile002 = startProfile(sketch002, at = [0.75, 13.46]) |> line(end = [4.52, 3.79]) |> line(end = [5.98, -2.81]) -profile003 = startProfileAt([3.19, 13.3], sketch002) +profile003 = startProfile(sketch002, at = [3.19, 13.3]) |> angledLine(angle = 0, length = 6.64, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 2.81) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile004 = startProfileAt([3.15, 9.39], sketch002) +profile004 = startProfile(sketch002, at = [3.15, 9.39]) |> xLine(length = 6.92) |> line(end = [-7.41, -2.85]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() profile005 = circle(sketch002, center = [5.15, 4.34], radius = 1.66) -profile006 = startProfileAt([9.65, 3.82], sketch002) +profile006 = startProfile(sketch002, at = [9.65, 3.82]) |> line(end = [2.38, 5.62]) |> line(end = [2.13, -5.57]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -2585,15 +2582,15 @@ revolve001 = revolve( ) extrude002 = extrude(profile006, length = 4) sketch003 = startSketchOn(-XZ) -profile007 = startProfileAt([4.8, 7.55], sketch003) +profile007 = startProfile(sketch003, at = [4.8, 7.55]) |> line(end = [7.39, 2.58]) |> line(end = [7.02, -2.85]) -profile008 = startProfileAt([5.54, 5.49], sketch003) +profile008 = startProfile(sketch003, at = [5.54, 5.49]) |> line(end = [6.34, 2.64]) |> line(end = [6.33, -2.96]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile009 = startProfileAt([5.23, 1.95], sketch003) +profile009 = startProfile(sketch003, at = [5.23, 1.95]) |> line(end = [6.8, 2.17]) |> line(end = [7.34, -2.75]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -2603,7 +2600,7 @@ profile010 = circle( center = [7.18, -2.11], radius = 2.67 ) -profile011 = startProfileAt([5.07, -6.39], sketch003) +profile011 = startProfile(sketch003, at = [5.07, -6.39]) |> angledLine(angle = 0, length = 4.54, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 4.17) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) @@ -2715,14 +2712,14 @@ extrude003 = extrude(profile011, length = 2.5) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([34, 42.66], sketch001) +profile001 = startProfile(sketch001, at = [34, 42.66]) |> line(end = [102.65, 151.99]) |> line(end = [76, -138.66]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) -profile002 = startProfileAt([39.43, 172.21], sketch002) +profile002 = startProfile(sketch002, at = [39.43, 172.21]) |> xLine(length = 183.99) |> line(end = [-77.95, -145.93]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -2753,7 +2750,7 @@ loft([profile001, profile002]) await page.waitForTimeout(100) await rect1Crn1() await editor.expectEditor.toContain( - `profile003 = startProfileAt([50.72, -18.19], sketch001)` + `profile003 = startProfile(sketch001, at = [50.72, -18.19])` ) await rect1Crn2() await editor.expectEditor.toContain( @@ -2771,14 +2768,14 @@ loft([profile001, profile002]) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([34, 42.66], sketch001) +profile001 = startProfile(sketch001, at = [34, 42.66]) |> line(end = [102.65, 151.99]) |> line(end = [76, -138.66]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) -profile002 = startProfileAt([39.43, 172.21], sketch002) +profile002 = startProfile(sketch002, at = [39.43, 172.21]) |> xLine(length = 183.99) |> line(end = [-77.95, -145.93]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -2822,7 +2819,7 @@ loft([profile001, profile002]) await page.waitForTimeout(100) await rect1Crn1() await editor.expectEditor.toContain( - `profile003 = startProfileAt([47.76, -17.13], plane001)` + `profile003 = startProfile(plane001, at = [47.76, -17.13])` ) await rect1Crn2() await editor.expectEditor.toContain( @@ -2848,7 +2845,7 @@ test.describe(`Click based selection don't brick the app when clicked out of ran localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3.14, 3.14]) |> arc( interiorAbsolute = [1, 2], @@ -2927,7 +2924,7 @@ test.describe('Redirecting to home page and back to the original file should cle localStorage.setItem( 'persistCode', ` sketch001 = startSketchOn(XZ) -|> startProfileAt([256.85, 14.41], %) +|> startProfile(at = [256.85, 14.41]) |> line(endAbsolute = [0, 211.07]) ` ) @@ -3015,7 +3012,7 @@ test.describe('Redirecting to home page and back to the original file should cle `@settings(defaultLengthUnit = mm) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([0, 0], sketch001) +profile001 = startProfile(sketch001, at = [0, 0]) |> line(end = [191.39, 191.39]) |> tangentialArc(endAbsolute = [287.08, 95.69], tag = $seg01) |> angledLine(angle = tangentToEnd(seg01), length = 135.34) @@ -3040,14 +3037,14 @@ test.describe('manual edits during sketch mode', () => { myVar2 = 6 sketch001 = startSketchOn(XZ) - profile001 = startProfileAt([106.68, 89.77], sketch001) + profile001 = startProfile(sketch001, at = [106.68, 89.77]) |> line(end = [132.34, 157.8]) |> line(end = [67.65, -460.55], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 500) sketch002 = startSketchOn(extrude001, face = seg01) - profile002 = startProfileAt([83.39, 329.15], sketch002) + profile002 = startProfile(sketch002, at = [83.39, 329.15]) |> angledLine(angle = 0, length = 119.61, tag = $rectangleSegmentA001) |> angledLine(length = 156.54, angle = -28) |> angledLine( @@ -3056,7 +3053,7 @@ test.describe('manual edits during sketch mode', () => { ) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() - profile003 = startProfileAt([-201.08, 254.17], sketch002) + profile003 = startProfile(sketch002, at = [-201.08, 254.17]) |> line(end = [103.55, 33.32]) |> line(end = [48.8, -153.54])` @@ -3176,20 +3173,20 @@ sketch003 = startSketchOn(XY) profile004 = circle(sketch003, center = [143.91, 136.89], radius = 71.63) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([106.68, 89.77], sketch001) +profile001 = startProfile(sketch001, at = [106.68, 89.77]) |> line(end = [132.34, 157.8]) |> line(end = [67.65, -460.55], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 500) sketch002 = startSketchOn(extrude001, face = seg01) -profile002 = startProfileAt([83.39, 329.15], sketch002) +profile002 = startProfile(sketch002, at = [83.39, 329.15]) |> angledLine(angle = 0, length = 119.61, tag = $rectangleSegmentA001) |> angledLine(length = 219.2, angle = -56) |> angledLine(angle = -151, length = 116.27) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile003 = startProfileAt([-201.08, 254.17], sketch002) +profile003 = startProfile(sketch002, at = [-201.08, 254.17]) |> line(end = [103.55, 33.32]) |> line(end = [48.8, -153.54]) `, @@ -3215,14 +3212,14 @@ profile003 = startProfileAt([-201.08, 254.17], sketch002) myVar2 = 6 sketch001 = startSketchOn(XZ) - profile001 = startProfileAt([106.68, 89.77], sketch001) + profile001 = startProfile(sketch001, at = [106.68, 89.77]) |> line(end = [132.34, 157.8]) |> line(end = [67.65, -460.55], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 500) sketch002 = startSketchOn(extrude001, face = seg01) - profile002 = startProfileAt([83.39, 329.15], sketch002) + profile002 = startProfile(sketch002, at = [83.39, 329.15]) |> angledLine(angle = 0, length = 119.61, tag = $rectangleSegmentA001) |> angledLine(length = 156.54, angle = -28) |> angledLine( @@ -3231,7 +3228,7 @@ profile003 = startProfileAt([-201.08, 254.17], sketch002) ) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() - profile003 = startProfileAt([-201.08, 254.17], sketch002) + profile003 = startProfile(sketch002, at = [-201.08, 254.17]) |> line(end = [103.55, 33.32]) |> line(end = [48.8, -153.54])` @@ -3303,7 +3300,7 @@ profile003 = startProfileAt([-201.08, 254.17], sketch002) // sometimes initial click doesn't register await objClick() await editor.expectActiveLinesToBe([ - '|> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag]', + '|> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag]', ]) }).toPass({ timeout: 15_000, intervals: [500] }) }) @@ -3351,8 +3348,8 @@ profile003 = startProfileAt([-201.08, 254.17], sketch002) // defends against a regression where sketch would duplicate in the scene // https://github.com/KittyCAD/modeling-app/issues/6345 await editor.replaceCode( - 'startProfileAt([75.8, 317.2', - 'startProfileAt([75.8, 217.2' + 'startProfile(at = [75.8, 317.2', + 'startProfile(at = [75.8, 217.2' ) // expect not white anymore await scene.expectPixelColorNotToBe( diff --git a/e2e/playwright/snapshot-tests.spec.ts b/e2e/playwright/snapshot-tests.spec.ts index 05c5d23b5..38e3bf536 100644 --- a/e2e/playwright/snapshot-tests.spec.ts +++ b/e2e/playwright/snapshot-tests.spec.ts @@ -67,7 +67,7 @@ totalHeightHalf = 2 armThick = 0.5 totalLen = 9.5 part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = baseHeight) |> xLine(length = baseLen) |> angledLine( @@ -317,7 +317,7 @@ const extrudeDefaultPlane = async ( plane: string ) => { const code = `part001 = startSketchOn(${plane}) - |> startProfileAt([7.00, 4.40], %) + |> startProfile(at = [7.00, 4.40]) |> line(end = [6.60, -0.20]) |> line(end = [2.80, 5.00]) |> line(end = [-5.60, 4.40]) @@ -442,7 +442,7 @@ test( await page.waitForTimeout(700) // TODO detect animation ending, or disable animation await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) - code += `profile001 = startProfileAt([182.59, -246.32], sketch001)` + code += `profile001 = startProfile(sketch001, at = [182.59, -246.32])` await expect(page.locator('.cm-content')).toHaveText(code) await page.waitForTimeout(100) @@ -641,7 +641,7 @@ test.describe( const startXPx = 600 await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) - code += `profile001 = startProfileAt([182.59, -246.32], sketch001)` + code += `profile001 = startProfile(sketch001, at = [182.59, -246.32])` await expect(u.codeLocator).toHaveText(code) await page.waitForTimeout(100) @@ -738,7 +738,7 @@ test.describe( const startXPx = 600 await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) - code += `profile001 = startProfileAt([182.59, -246.32], sketch001)` + code += `profile001 = startProfile(sketch001, at = [182.59, -246.32])` await expect(u.codeLocator).toHaveText(code) await page.waitForTimeout(100) @@ -797,13 +797,13 @@ test( localStorage.setItem( 'persistCode', `part001 = startSketchOn(-XZ) - |> startProfileAt([1.4, 2.47], %) + |> startProfile(at = [1.4, 2.47]) |> line(end = [9.31, 10.55], tag = $seg01) |> line(end = [11.91, -10.42]) |> close() |> extrude(length = ${KCL_DEFAULT_LENGTH}) part002 = startSketchOn(part001, face = seg01) - |> startProfileAt([8, 8], %) + |> startProfile(at = [8, 8]) |> line(end = [4.68, 3.05]) |> line(end = [0, -7.79]) |> close() @@ -855,7 +855,7 @@ test( localStorage.setItem( 'persistCode', `part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -891,7 +891,7 @@ test( localStorage.setItem( 'persistCode', `part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -1050,7 +1050,7 @@ test('theme persists', async ({ page, context }) => { localStorage.setItem( 'persistCode', `part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -1121,7 +1121,7 @@ test.describe('code color goober', { tag: '@snapshot' }, () => { // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -1129,7 +1129,7 @@ sweepPath = startSketchOn(XZ) |> line(end = [0, 7]) sweepSketch = startSketchOn(XY) - |> startProfileAt([2, 0], %) + |> startProfile(at = [2, 0]) |> arc(angleStart = 0, angleEnd = 360, radius = 2) |> sweep(path = sweepPath) |> appearance( @@ -1166,7 +1166,7 @@ sweepSketch = startSketchOn(XY) // Create a path for the sweep. sweepPath = startSketchOn(XZ) - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) @@ -1174,7 +1174,7 @@ sweepPath = startSketchOn(XZ) |> line(end = [0, 7]) sweepSketch = startSketchOn(XY) - |> startProfileAt([2, 0], %) + |> startProfile(at = [2, 0]) |> arc(angleStart = 0, angleEnd = 360, radius = 2) |> sweep(path = sweepPath) |> appearance( 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 fb74b2933..d700bc8e4 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 dc1ec10f1..6210f4102 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/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-1-Google-Chrome-linux.png index 503436315..0930d6f1c 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-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-Millimeter-scale-2-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-2-Google-Chrome-linux.png index dfc191b84..6210f4102 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-2-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Client-side-scene-scale-should-match-engine-scale-Millimeter-scale-2-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 a0d03e676..3ffcf6bb5 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 707c41cb7..07e46d441 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 59d87f5c9..44941d7d0 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 887859f3d..7f11ac4b2 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 6f48eeb66..212b208e4 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/Draft-segments-should-look-right-5-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-5-Google-Chrome-linux.png index 01518ab5c..d047115e9 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-5-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-segments-should-look-right-5-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 8ad07fc80..c5711f32d 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-2d-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-2d-1-Google-Chrome-linux.png index 04832de74..a5d9fe750 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-2d-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Zoom-to-fit-on-load---solid-2d-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 6215a6dd8..902df7091 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 0eb5e7bd7..9f5375cdb 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 bc507763c..5d213836b 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 01030ec67..067fb599b 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 6f44ca37f..b2f396f3b 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 f763ad7ac..2a3ba9bb3 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 1a4531969..3ad306366 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 c096bb0cc..fa22d0b7c 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 f81f5f26e..25a345083 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--edit-with-ai-example-snapshots--change-colour.snap.json b/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--edit-with-ai-example-snapshots--change-colour.snap.json index 1ac46ddf4..caf73eebb 100644 --- a/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--edit-with-ai-example-snapshots--change-colour.snap.json +++ b/e2e/playwright/snapshots/prompt-to-edit/prompt-to-edit-snapshot-tests-spec-ts--edit-with-ai-example-snapshots--change-colour.snap.json @@ -1,9 +1,9 @@ { - "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(angle = 0, length = 176.4, tag = $rectangleSegmentA001)\n |> angledLine(\n angle = segAng(rectangleSegmentA001) - 90,\n length = 53.4,\n tag = $rectangleSegmentB001,\n )\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", + "original_source_code": "sketch001 = startSketchOn(XZ)\nprofile001 = startProfile(sketch001, at = [57.81, 250.51])\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 |> startProfile(at = [-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 |> startProfile(at = [52.92, 157.81])\n |> angledLine(angle = 0, length = 176.4, tag = $rectangleSegmentA001)\n |> angledLine(\n angle = segAng(rectangleSegmentA001) - 90,\n length = 53.4,\n tag = $rectangleSegmentB001,\n )\n |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", "prompt": "make this neon green please, use #39FF14", "source_ranges": [ { - "prompt": "The users main selection is the end cap of a general-sweep (that is an extrusion, revolve, sweep or loft).\nThe source range most likely refers to \"startProfileAt\" simply because this is the start of the profile that was swept.\nIf you need to operate on this cap, for example for sketching on the face, you can use the special string END i.e. `startSketchOn(someSweepVariable, face = END)`\nWhen they made this selection they main have intended this surface directly or meant something more general like the sweep body.\nSee later source ranges for more context.", + "prompt": "The users main selection is the end cap of a general-sweep (that is an extrusion, revolve, sweep or loft).\nThe source range most likely refers to \"startProfile\" simply because this is the start of the profile that was swept.\nIf you need to operate on this cap, for example for sketching on the face, you can use the special string END i.e. `startSketchOn(someSweepVariable, face = END)`\nWhen they made this selection they main have intended this surface directly or meant something more general like the sweep body.\nSee later source ranges for more context.", "range": { "start": { "line": 11, diff --git a/e2e/playwright/storageStates.ts b/e2e/playwright/storageStates.ts index cc6273946..27f363ea8 100644 --- a/e2e/playwright/storageStates.ts +++ b/e2e/playwright/storageStates.ts @@ -82,7 +82,7 @@ export const TEST_SETTINGS_CORRUPTED = { export const TEST_CODE_GIZMO = `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) -|> startProfileAt([20, 0], %) +|> startProfile(at = [20, 0]) |> line(end = [7.13, 4 + 0]) |> angledLine(angle = 3 + 0, length = 3.14 + 0 ) |> line(endAbsolute = [20.14 + 0, -0.14 + 0]) @@ -105,7 +105,7 @@ thickness = 2 keychainHoleSize = 3 keychain = startSketchOn("XY") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [width, 0]) |> line(endAbsolute = [width, height]) |> line(endAbsolute = [0, height]) @@ -113,7 +113,7 @@ keychain = startSketchOn("XY") |> extrude(length = thickness) keychain1 = startSketchOn("XY") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [width, 0]) |> line(endAbsolute = [width, height]) |> line(endAbsolute = [0, height]) @@ -121,7 +121,7 @@ keychain1 = startSketchOn("XY") |> extrude(length = thickness) keychain2 = startSketchOn("XY") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [width, 0]) |> line(endAbsolute = [width, height]) |> line(endAbsolute = [0, height]) @@ -129,7 +129,7 @@ keychain2 = startSketchOn("XY") |> extrude(length = thickness) box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $revolveAxis) @@ -137,7 +137,7 @@ box = startSketchOn(XY) |> extrude(length = 10) sketch001 = startSketchOn(box, face = revolveAxis) - |> startProfileAt([5, 10], %) + |> startProfile(at = [5, 10]) |> line(end = [0, -10]) |> line(end = [2, 0]) |> line(end = [0, -10]) @@ -148,7 +148,7 @@ sketch001 = startSketchOn(box, face = revolveAxis) ) sketch001 = startSketchOn(XZ) - |> startProfileAt([0.0, 0.0], %) + |> startProfile(at = [0.0, 0.0]) |> xLine(length = 0.0) |> close() diff --git a/e2e/playwright/test-network-and-connection-issues.spec.ts b/e2e/playwright/test-network-and-connection-issues.spec.ts index aa1c5bcce..fab50e8d0 100644 --- a/e2e/playwright/test-network-and-connection-issues.spec.ts +++ b/e2e/playwright/test-network-and-connection-issues.spec.ts @@ -118,7 +118,7 @@ test.describe( const startXPx = 600 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)` + `sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt})` ) await page.waitForTimeout(100) @@ -127,7 +127,7 @@ test.describe( await expect( page.locator('.cm-content') - ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + ).toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt}) |> xLine(length = ${commonPoints.num1})`) // Expect the network to be up @@ -176,7 +176,7 @@ test.describe( // select a line await page - .getByText(`startProfileAt(${commonPoints.startAt}, sketch001)`) + .getByText(`startProfile(sketch001, at = ${commonPoints.startAt})`) .click() // enter sketch again @@ -220,7 +220,7 @@ test.describe( await expect .poll(u.normalisedEditorCode) .toBe(`sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([12.34, -12.34], sketch001) +profile001 = startProfile(sketch001, at = [12.34, -12.34]) |> xLine(length = 12.34) |> line(end = [-12.34, 12.34]) @@ -231,7 +231,7 @@ profile001 = startProfileAt([12.34, -12.34], sketch001) await expect .poll(u.normalisedEditorCode) .toBe(`sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([12.34, -12.34], sketch001) +profile001 = startProfile(sketch001, at = [12.34, -12.34]) |> xLine(length = 12.34) |> line(end = [-12.34, 12.34]) |> xLine(length = -12.34) diff --git a/e2e/playwright/testing-camera-movement.spec.ts b/e2e/playwright/testing-camera-movement.spec.ts index 7f662063b..7c94c3e39 100644 --- a/e2e/playwright/testing-camera-movement.spec.ts +++ b/e2e/playwright/testing-camera-movement.spec.ts @@ -234,7 +234,7 @@ test.describe('Testing Camera Movement', () => { x = 948 await u.canvasLocator.click({ position: { x: 783, y } }) - code += `\n |> startProfileAt([8.12, -12.98], %)` + code += `\n |> startProfile(at = [8.12, -12.98])` // await expect(u.codeLocator).toHaveText(code) await u.canvasLocator.click({ position: { x, y } }) code += `\n |> line(end = [11.18, 0])` diff --git a/e2e/playwright/testing-constraints.spec.ts b/e2e/playwright/testing-constraints.spec.ts index c4c39e8e2..55398c3d1 100644 --- a/e2e/playwright/testing-constraints.spec.ts +++ b/e2e/playwright/testing-constraints.spec.ts @@ -15,7 +15,7 @@ test.describe('Testing constraints', () => { localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> xLine(length = -20) @@ -57,7 +57,7 @@ test.describe('Testing constraints', () => { .click() await expect(page.locator('.cm-content')).toHaveText( - `length001 = 20sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> angledLine(angle = 90, length = length001) |> xLine(length = -20)` + `length001 = 20sketch001 = startSketchOn(XY) |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> angledLine(angle = 90, length = length001) |> xLine(length = -20)` ) // Make sure we didn't pop out of sketch mode. @@ -83,13 +83,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 79 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4], tag = $seg01) |> line(end = [78.92, -120.11]) |> angledLine(angle = segAng(seg01), length = yo) |> line(end = [41.19, 58.97 + 5]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 120], %) + |> startProfile(at = [299.05, 120]) |> xLine(length = -385.34, tag = $seg_what) |> yLine(length = -170.06) |> xLine(length = segLen(seg_what)) @@ -148,13 +148,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4], tag = $seg01) |> line(end = [78.92, -120.11]) |> angledLine(angle = segAng(seg01), length = 78.33) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -263,13 +263,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -379,13 +379,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -493,13 +493,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -596,13 +596,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -691,13 +691,13 @@ test.describe('Testing constraints', () => { `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -773,13 +773,13 @@ part002 = startSketchOn(XZ) `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) |> line(end = [51.19, 48.97]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -875,12 +875,12 @@ part002 = startSketchOn(XZ) `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -957,12 +957,12 @@ part002 = startSketchOn(XZ) `@settings(defaultLengthUnit = in) yo = 5 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> line(end = [74.36, 130.4]) |> line(end = [78.92, -120.11]) |> line(end = [9.16, 77.79]) part002 = startSketchOn(XZ) - |> startProfileAt([299.05, 231.45], %) + |> startProfile(at = [299.05, 231.45]) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) |> xLine(length = segLen(seg_what)) @@ -1022,7 +1022,7 @@ part002 = startSketchOn(XZ) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XY) - |> startProfileAt([-1.05, -1.07], %) + |> startProfile(at = [-1.05, -1.07]) |> line(end = [3.79, 2.68], tag = $seg01) |> line(end = [3.13, -2.4])` ) @@ -1127,7 +1127,7 @@ test.describe('Electron constraint tests', () => { path.join(bracketDir, 'main.kcl'), `@settings(defaultLengthUnit = in) const part001 = startSketchOn(XY) - |> startProfileAt([4.83, 12.56], %) + |> startProfile(at = [4.83, 12.56]) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) diff --git a/e2e/playwright/testing-gizmo.spec.ts b/e2e/playwright/testing-gizmo.spec.ts index 5f220cd56..da0c4f945 100644 --- a/e2e/playwright/testing-gizmo.spec.ts +++ b/e2e/playwright/testing-gizmo.spec.ts @@ -258,7 +258,7 @@ test.describe(`Testing gizmo, fixture-based`, () => { 'persistCode', `@settings(defaultLengthUnit = in) const sketch002 = startSketchOn(XZ) - |> startProfileAt([-108.83, -57.48], %) + |> startProfile(at = [-108.83, -57.48]) |> angledLine(angle = 0, length = 105.13, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 77.9) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) diff --git a/e2e/playwright/testing-segment-overlays.spec.ts b/e2e/playwright/testing-segment-overlays.spec.ts index e485d0245..124ec5b16 100644 --- a/e2e/playwright/testing-segment-overlays.spec.ts +++ b/e2e/playwright/testing-segment-overlays.spec.ts @@ -205,7 +205,7 @@ test.describe('Testing segment overlays', () => { 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([5 + 0, 20 + 0], %) + |> startProfile(at = [5 + 0, 20 + 0]) |> line(end = [0.5, -14 + 0]) |> angledLine(angle = 3 + 0, length = 32 + 0) |> line(endAbsolute = [5 + 33, 20 + 11.5 + 0]) @@ -375,7 +375,7 @@ test.describe('Testing segment overlays', () => { xAbs001 = 33 xAbs002 = 4 part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0.5, yRel001]) |> angledLine(angle = angle001, length = len001) |> line(endAbsolute = [33, yAbs001]) @@ -448,7 +448,7 @@ test.describe('Testing segment overlays', () => { 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0.5, -14 + 0]) |> angledLine(angle = 3 + 0, length = 32 + 0) |> line(endAbsolute = [33, 11.5 + 0]) @@ -569,7 +569,7 @@ test.describe('Testing segment overlays', () => { 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0.5, -14 + 0]) |> angledLine(angle = 3 + 0, length = 32 + 0) |> line(endAbsolute = [33, 11.5 + 0]) @@ -697,7 +697,7 @@ test.describe('Testing segment overlays', () => { 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0.5, -14 + 0]) |> angledLine(angle = 3 + 0, length = 32 + 0) |> line(endAbsolute = [33, 11.5 + 0]) @@ -775,7 +775,7 @@ test.describe('Testing segment overlays', () => { 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([56.37, 120.33], sketch001) +profile001 = startProfile(sketch001, at = [56.37, 120.33]) |> line(end = [162.86, 106.48]) |> arc( interiorAbsolute = [360.16, 231.76], @@ -983,7 +983,7 @@ part001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |>startProfileAt([0, 0], %) + |>startProfile(at = [0, 0]) |> line(end = [0.5, -14 + 0]) |> angledLine(angle = 3 + 0, length = 32 + 0) |> line(endAbsolute = [33, 11.5 + 0]) @@ -1230,7 +1230,7 @@ part001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([5, 6], %) + |> startProfile(at = [5, 6]) |> ${lineToBeDeleted} |> line(end = [-10, -15]) |> angledLine(angle = -176, length = segLen(seg01)) @@ -1391,7 +1391,7 @@ part001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([5, 6], %) + |> startProfile(at = [5, 6]) |> ${lineToBeDeleted} |> line(end = [-10, -15]) |> angledLine(angle = -176, length = segLen(seg01))` diff --git a/e2e/playwright/testing-selections.spec.ts b/e2e/playwright/testing-selections.spec.ts index 4df161131..f3d89ea61 100644 --- a/e2e/playwright/testing-selections.spec.ts +++ b/e2e/playwright/testing-selections.spec.ts @@ -68,7 +68,7 @@ test.describe('Testing selections', () => { await u.closeDebugPanel() await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) await expect(page.locator('.cm-content')).toHaveText( - `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` + `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt})` ) await page.waitForTimeout(100) @@ -76,25 +76,25 @@ test.describe('Testing selections', () => { await expect( page.locator('.cm-content') - ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${commonPoints.startAt}) |> 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(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${ commonPoints.startAt - }, sketch001) + }) |> xLine(length = ${commonPoints.num1}) |> yLine(length = ${commonPoints.num1 + 0.01})`) await page.waitForTimeout(100) await page.mouse.click(startXPx, 500 - PUR * 20) await expect( page.locator('.cm-content') - ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ + ).toHaveText(`@settings(defaultLengthUnit = in)sketch001 = startSketchOn(XZ)profile001 = startProfile(sketch001, at = ${ commonPoints.startAt - }, sketch001) + }) |> xLine(length = ${commonPoints.num1}) |> yLine(length = ${commonPoints.num1 + 0.01}) |> xLine(length = ${commonPoints.num2 * -1})`) @@ -265,34 +265,34 @@ test.describe('Testing selections', () => { 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([-79.26, 95.04], %) + |> startProfile(at = [-79.26, 95.04]) |> line(end = [112.54, 127.64], tag = $seg02) |> line(end = [170.36, -121.61], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(sketch001, length = 50) sketch005 = startSketchOn(extrude001, face = 'END') - |> startProfileAt([23.24, 136.52], %) + |> startProfile(at = [23.24, 136.52]) |> line(end = [-8.44, 36.61]) |> line(end = [49.4, 2.05]) |> line(end = [29.69, -46.95]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(extrude001, face = seg01) - |> startProfileAt([21.23, 17.81], %) + |> startProfile(at = [21.23, 17.81]) |> line(end = [51.97, 21.32]) |> line(end = [4.07, -22.75]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(extrude001, face = seg02) - |> startProfileAt([-100.54, 16.99], %) + |> startProfile(at = [-100.54, 16.99]) |> line(end = [0, 20.03]) |> line(end = [62.61, 0], tag = $seg03) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude002 = extrude(sketch002, length = 50) sketch004 = startSketchOn(extrude002, face = seg03) - |> startProfileAt([57.07, 134.77], %) + |> startProfile(at = [57.07, 134.77]) |> line(end = [-4.72, 22.84]) |> line(end = [28.8, 6.71]) |> line(end = [9.19, -25.33]) @@ -304,7 +304,7 @@ pipeSmallDia = 10 pipeLargeDia = 20 thickness = 0.5 part009 = startSketchOn(XY) - |> startProfileAt([pipeLargeDia - (thickness / 2), 38], %) + |> startProfile(at = [pipeLargeDia - (thickness / 2), 38]) |> line(end = [thickness, 0]) |> line(end = [0, -1]) |> angledLine(angle = 60, endAbsoluteX = pipeSmallDia + thickness) @@ -324,13 +324,13 @@ profile001 = circle( center = [42.91, -70.42], radius = 17.96 ) -profile002 = startProfileAt([86.92, -63.81], sketch006) +profile002 = startProfile(sketch006, at = [86.92, -63.81]) |> angledLine(angle = 0, length = 63.81, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 17.05) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile003 = startProfileAt([40.16, -120.48], sketch006) +profile003 = startProfile(sketch006, at = [40.16, -120.48]) |> line(end = [26.95, 24.21]) |> line(end = [20.91, -28.61]) |> line(end = [32.46, 18.71]) @@ -412,7 +412,7 @@ profile003 = startProfileAt([40.16, -120.48], sketch006) await page.mouse.click(solid2d.x, solid2d.y) await page.waitForTimeout(100) await expect(page.locator('.cm-activeLine')).toHaveText( - '|> startProfileAt([23.24, 136.52], %)' + '|> startProfile(at = [23.24, 136.52])' ) await u.clearCommandLogs() await page.keyboard.press('Delete') @@ -424,7 +424,7 @@ profile003 = startProfileAt([40.16, -120.48], sketch006) await page.mouse.click(individualProfile.x, individualProfile.y) await page.waitForTimeout(100) const codeToBeDeletedSnippet = - 'profile003 = startProfileAt([40.16, -120.48], sketch006)' + 'profile003 = startProfile(sketch006, at = [40.16, -120.48])' await expect(page.locator('.cm-activeLine')).toHaveText( ' |> line(end = [20.91, -28.61])' ) @@ -447,7 +447,7 @@ profile003 = startProfileAt([40.16, -120.48], sketch006) localStorage.setItem( 'persistCode', `part001 = startSketchOn(XY) -yo = startProfileAt([4.83, 12.56], part001) +yo = startProfile(part001, at = [4.83, 12.56]) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) @@ -457,13 +457,13 @@ yo = startProfileAt([4.83, 12.56], part001) yoo = extrude(yo, length = 4) sketch002 = startSketchOn(yoo, face = seg02) sketch001 = startSketchOn(yoo, face = 'END') -profile002 = startProfileAt([-11.08, 2.39], sketch002) +profile002 = startProfile(sketch002, at = [-11.08, 2.39]) |> line(end = [4.89, 0.9]) |> line(end = [-0.61, -2.41]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile002, length = 15) -profile001 = startProfileAt([7.49, 9.96], sketch001) +profile001 = startProfile(sketch001, at = [7.49, 9.96]) |> angledLine(angle = 0, length = 5.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 4.81) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -511,7 +511,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) 'persistCode', `@settings(defaultLengthUnit = in) part001 = startSketchOn(XZ) - |> startProfileAt([20, 0], %) + |> startProfile(at = [20, 0]) |> line(end = [7.13, 4 + 0]) |> angledLine(angle = 3 + 0, length = 3.14 + 0 ) |> line(endAbsolute = [20.14 + 0, -0.14 + 0]) @@ -648,8 +648,8 @@ part001 = startSketchOn(XZ) await checkCodeAtHoverPosition( 'extrusionTopCap', extrusionTopCap, - 'startProfileAt([20,0],%)', - 'startProfileAt([20, 0], %)' + 'startProfile(at=[20,0])', + 'startProfile(at = [20, 0])' ) await checkCodeAtHoverPosition( 'flatExtrusionFace', @@ -727,7 +727,7 @@ part001 = startSketchOn(XZ) await u.removeCurrentCode() await u.codeLocator.fill(`@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $yo) @@ -839,7 +839,7 @@ part001 = startSketchOn(XZ) localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) |> line(end = [3.75, 0.46]) @@ -882,7 +882,7 @@ part001 = startSketchOn(XZ) const codeToAdd = `${await u.codeLocator.allInnerTexts()} sketch002 = startSketchOn(extrude001, face = $seg01) - |> startProfileAt([-12.94, 6.6], %) + |> startProfile(at = [-12.94, 6.6]) |> line(end = [2.45, -0.2]) |> line(end = [-2, -1.25]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -938,7 +938,7 @@ part001 = startSketchOn(XZ) `@settings(defaultLengthUnit = in) yo = 79 part001 = startSketchOn(XZ) - |> startProfileAt([-7.54, -26.74], %) + |> startProfile(at = [-7.54, -26.74]) |> ${cases[0].expectedCode} |> line(end = [-3.19, -138.43]) |> ${cases[1].expectedCode} @@ -994,7 +994,7 @@ part001 = startSketchOn(XZ) 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([-79.26, 95.04], %) + |> startProfile(at = [-79.26, 95.04]) |> line(end = [112.54, 127.64]) |> line(end = [170.36, -121.61], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -1033,7 +1033,7 @@ part001 = startSketchOn(XZ) const extrudeText = `line(end = [170.36, -121.61], tag = $seg01)` const cap = { x: 594, y: 283 } - const capText = `startProfileAt([-79.26, 95.04], %)` + const capText = `startProfile(at = [-79.26, 95.04])` const nothing = { x: 946, y: 229 } @@ -1094,10 +1094,10 @@ part001 = startSketchOn(XZ) }) => { const u = await getUtils(page) const selectionsSnippets = { - extrudeAndEditBlocked: '|> startProfileAt([10.81, 32.99], %)', - extrudeAndEditBlockedInFunction: '|> startProfileAt(pos, %)', - extrudeAndEditAllowed: '|> startProfileAt([15.72, 4.7], %)', - editOnly: '|> startProfileAt([15.79, -14.6], %)', + extrudeAndEditBlocked: '|> startProfile(at = [10.81, 32.99])', + extrudeAndEditBlockedInFunction: '|> startProfile(at = pos)', + extrudeAndEditAllowed: '|> startProfile(at = [15.72, 4.7])', + editOnly: '|> startProfile(at = [15.79, -14.6])', } await page.addInitScript( async ({ diff --git a/e2e/playwright/testing-selections.spec.ts-snapshots/editor-content-Google-Chrome-darwin b/e2e/playwright/testing-selections.spec.ts-snapshots/editor-content-Google-Chrome-darwin index efc539430..de7c97041 100644 --- a/e2e/playwright/testing-selections.spec.ts-snapshots/editor-content-Google-Chrome-darwin +++ b/e2e/playwright/testing-selections.spec.ts-snapshots/editor-content-Google-Chrome-darwin @@ -1 +1 @@ -part001 = startSketchOn('XY')yo = startProfileAt([4.83, 12.56], part001) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) |> angledLine(angle = segAng(seg01), 12.35], %, $seg02) |> line(end = [-13.02, 10.03]) |> close()sketch002 = startSketchOn({ plane = { origin = { x = 7.49, y = 2.4, z = 0 }, xAxis = { x = -0.3, y = 0.95, z = 0 }, yAxis = { x = 0, y = 0, z = 1 }, zAxis = { x = 0.95, y = 0.3, z = 0 } }})sketch001 = startSketchOn({ plane = { origin = { x = 0, y = 0, z = 4 }, xAxis = { x = 1, y = 0, z = 0 }, yAxis = { x = 0, y = 1, z = 0 }, zAxis = { x = 0, y = 0, z = 1 } }})profile002 = startProfileAt([-11.08, 2.39], sketch002) |> line(end = [4.89, 0.9]) |> line(end = [-0.61, -2.41]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close()extrude001 = extrude(profile002, length = 15)profile001 = startProfileAt([7.49, 9.96], sketch001) |> angledLine(angle = 0, length = 5.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 4.81 ) |> angledLine( angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001) ) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() +part001 = startSketchOn('XY')yo = startProfile(-4.1]) |> angledLine(angle = segAng(seg01, at = [4.83, 12.56], part001) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17), 12.35], %, $seg02) |> line(end = [-13.02, 10.03]) |> close()sketch002 = startSketchOn({ plane = { origin = { x = 7.49, y = 2.4, z = 0 }, xAxis = { x = -0.3, y = 0.95, z = 0 }, yAxis = { x = 0, y = 0, z = 1 }, zAxis = { x = 0.95, y = 0.3, z = 0 } }})sketch001 = startSketchOn({ plane = { origin = { x = 0, y = 0, z = 4 }, xAxis = { x = 1, y = 0, z = 0 }, yAxis = { x = 0, y = 1, z = 0 }, zAxis = { x = 0, y = 0, z = 1 } }})profile002 = startProfile(-2.41], at = [-11.08, 2.39], sketch002) |> line(end = [4.89, 0.9]) |> line(end = [-0.61) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close()extrude001 = extrude(profile002, length = 15)profile001 = startProfile(length = -segLen(rectangleSegmentA001) , at = [7.49, 9.96], sketch001) |> angledLine(angle = 0, length = 5.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 4.81 ) |> angledLine( angle = segAng(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() diff --git a/e2e/playwright/testing-settings.spec.ts b/e2e/playwright/testing-settings.spec.ts index b1146ce96..6e20698ef 100644 --- a/e2e/playwright/testing-settings.spec.ts +++ b/e2e/playwright/testing-settings.spec.ts @@ -767,7 +767,7 @@ test.describe( localStorage.setItem( 'persistCode', `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 0]) |> line(end = [0, 5]) |> line(end = [-5, 0]) diff --git a/e2e/playwright/various.spec.ts b/e2e/playwright/various.spec.ts index a4992906e..bcc8d6b55 100644 --- a/e2e/playwright/various.spec.ts +++ b/e2e/playwright/various.spec.ts @@ -48,7 +48,7 @@ totalHeightHalf = 2 armThick = 0.5 totalLen = 9.5 part001 = startSketchOn(-XZ) -|> startProfileAt([0, 0], %) +|> startProfile(at = [0, 0]) |> yLine(length = baseHeight) |> xLine(length = baseLen) |> angledLine( @@ -466,7 +466,7 @@ test('Sketch on face', async ({ page, homePage, scene, cmdBar, toolbar }) => { 'persistCode', `@settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) -|> startProfileAt([3.29, 7.86], %) +|> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) |> line(end = [3.75, 0.46]) @@ -527,7 +527,7 @@ extrude001 = extrude(sketch001, length = 5 + 7)` await expect.poll(u.normalisedEditorCode).toContain( u.normalisedCode(`sketch002 = startSketchOn(extrude001, face = seg01) -profile001 = startProfileAt([-12.34, 12.34], sketch002) +profile001 = startProfile(sketch002, at = [-12.34, 12.34]) |> line(end = [12.34, -12.34]) |> line(end = [-12.34, -12.34]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -542,7 +542,7 @@ profile001 = startProfileAt([-12.34, 12.34], sketch002) await u.updateCamPosition([1049, 239, 686]) await u.closeDebugPanel() - await page.getByText('startProfileAt([-12').click() + await page.getByText('startProfile(sketch002, at = [-12').click() await expect(page.getByRole('button', { name: 'Edit Sketch' })).toBeVisible() await page.getByRole('button', { name: 'Edit Sketch' }).click() await page.waitForTimeout(500) @@ -564,7 +564,7 @@ profile001 = startProfileAt([-12.34, 12.34], sketch002) previousCodeContent = await page.locator('.cm-content').innerText() const result = makeTemplate`sketch002 = startSketchOn(extrude001, face = seg01) -|> startProfileAt([-12.83, 6.7], %) +|> startProfile(at = [-12.83, 6.7]) |> line(end = [${[2.28, 2.35]}, -${0.07}]) |> line(end = [-3.05, -1.47]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -577,7 +577,7 @@ profile001 = startProfileAt([-12.34, 12.34], sketch002) await page.getByRole('button', { name: 'Exit Sketch' }).click() await u.expectCmdLog('[data-message-type="execution-done"]') - await page.getByText('startProfileAt([-12').click() + await page.getByText('startProfile(sketch002, at = [-12').click() await expect(page.getByRole('button', { name: 'Extrude' })).not.toBeDisabled() await page.waitForTimeout(100) diff --git a/public/kcl-samples/80-20-rail/main.kcl b/public/kcl-samples/80-20-rail/main.kcl index 8babb783d..4ee58a6d1 100644 --- a/public/kcl-samples/80-20-rail/main.kcl +++ b/public/kcl-samples/80-20-rail/main.kcl @@ -8,10 +8,10 @@ fn rail8020(originStart, railHeight, railLength) { // Sketch side 1 of profile sketch001 = startSketchOn(-XZ) - |> startProfileAt([ + |> startProfile(at = [ originStart[0], 0.1 * railHeight + originStart[1] - ], %) + ]) |> arc(angleStart = 180, angleEnd = 270, radius = 0.1 * railHeight) |> arc(angleStart = 180, angleEnd = 0, radius = 0.072 / 4 * railHeight) |> xLine(length = 0.1 * railHeight) diff --git a/public/kcl-samples/axial-fan/fan-housing.kcl b/public/kcl-samples/axial-fan/fan-housing.kcl index 0d9f9448b..bd7e02bc6 100644 --- a/public/kcl-samples/axial-fan/fan-housing.kcl +++ b/public/kcl-samples/axial-fan/fan-housing.kcl @@ -10,7 +10,7 @@ import * from "parameters.kcl" // Model the housing which holds the motor, the fan, and the mounting provisions // Bottom mounting face bottomFaceSketch = startSketchOn(XY) - |> startProfileAt([-fanSize / 2, -fanSize / 2], %) + |> startProfile(at = [-fanSize / 2, -fanSize / 2]) |> angledLine(angle = 0, length = fanSize, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = fanSize, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -49,7 +49,7 @@ bottomFaceSketch = startSketchOn(XY) // Add large openings to the bottom face to allow airflow through the fan airflowPattern = startSketchOn(bottomFaceSketch, face = END) - |> startProfileAt([fanSize * 7 / 25, -fanSize * 9 / 25], %) + |> startProfile(at = [fanSize * 7 / 25, -fanSize * 9 / 25]) |> angledLine(angle = 140, length = fanSize * 12 / 25, tag = $seg01) |> tangentialArc(radius = fanSize * 1 / 50, angle = 90) |> angledLine(angle = -130, length = fanSize * 8 / 25) @@ -71,10 +71,10 @@ airflowPattern = startSketchOn(bottomFaceSketch, face = END) housingMiddleLength = fanSize / 3 housingMiddleRadius = fanSize / 3 - 1 bodyMiddle = startSketchOn(bottomFaceSketch, face = END) - |> startProfileAt([ + |> startProfile(at = [ housingMiddleLength / 2, -housingMiddleLength / 2 - housingMiddleRadius - ], %) + ]) |> tangentialArc(radius = housingMiddleRadius, angle = 90) |> yLine(length = housingMiddleLength) |> tangentialArc(radius = housingMiddleRadius, angle = 90) @@ -92,7 +92,7 @@ bodyFanHole = startSketchOn(bodyMiddle, face = END) // Top mounting face. Cut a hole in the face to accommodate the fan topFaceSketch = startSketchOn(bodyMiddle, face = END) -topHoles = startProfileAt([-fanSize / 2, -fanSize / 2], topFaceSketch) +topHoles = startProfile(topFaceSketch, at = [-fanSize / 2, -fanSize / 2]) |> angledLine(angle = 0, length = fanSize, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) + 90, length = fanSize, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC002) diff --git a/public/kcl-samples/axial-fan/fan.kcl b/public/kcl-samples/axial-fan/fan.kcl index 0cc3192e7..a590d2d23 100644 --- a/public/kcl-samples/axial-fan/fan.kcl +++ b/public/kcl-samples/axial-fan/fan.kcl @@ -9,7 +9,7 @@ import * from "parameters.kcl" // Model the center of the fan fanCenter = startSketchOn(XZ) - |> startProfileAt([-0.0001, fanHeight], %) + |> startProfile(at = [-0.0001, fanHeight]) |> xLine(endAbsolute = -15 + 1.5) |> tangentialArc(radius = 1.5, angle = 90) |> yLine(endAbsolute = 4.5) @@ -35,10 +35,10 @@ fanCenter = startSketchOn(XZ) // Create a function for a lofted fan blade cross section that rotates about the center hub of the fan fn fanBlade(offsetHeight, startAngle) { fanBlade = startSketchOn(offsetPlane(XY, offset = offsetHeight)) - |> startProfileAt([ + |> startProfile(at = [ 15 * cos(toRadians(startAngle)), 15 * sin(toRadians(startAngle)) - ], %) + ]) |> arc(angleStart = startAngle, angleEnd = startAngle + 14, radius = 15) |> arc( endAbsolute = [ diff --git a/public/kcl-samples/ball-bearing/main.kcl b/public/kcl-samples/ball-bearing/main.kcl index ac82062bb..3019f3e5c 100644 --- a/public/kcl-samples/ball-bearing/main.kcl +++ b/public/kcl-samples/ball-bearing/main.kcl @@ -26,7 +26,7 @@ insideWall = extrude(insideWallSketch, length = overallThickness) // Create the sketch of one of the balls ballsSketch = startSketchOn(XY) - |> startProfileAt([shaftDia / 2 + wallThickness, 0.001], %) + |> startProfile(at = [shaftDia / 2 + wallThickness, 0.001]) |> arc(angleStart = 180, angleEnd = 0, radius = sphereDia / 2) |> close() @@ -42,10 +42,10 @@ balls = revolve(ballsSketch, axis = X) // Create the sketch for the chain around the balls chainSketch = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ shaftDia / 2 + wallThickness + sphereDia / 2 - (chainWidth / 2), 0.125 * sin(toRadians(60)) - ], %) + ]) |> arc(angleStart = 120, angleEnd = 60, radius = sphereDia / 2) |> line(end = [0, chainThickness]) |> line(end = [-chainWidth, 0]) diff --git a/public/kcl-samples/bench/bench-parts.kcl b/public/kcl-samples/bench/bench-parts.kcl index 112fcdd8d..129fb1954 100644 --- a/public/kcl-samples/bench/bench-parts.kcl +++ b/public/kcl-samples/bench/bench-parts.kcl @@ -8,7 +8,7 @@ export dividerThickness = 4 fn dividerSketch(plane) { sketch000 = startSketchOn(plane) - |> startProfileAt([-16.82, 21.2], %) + |> startProfile(at = [-16.82, 21.2]) |> line(end = [-0.13, -1.27]) |> tangentialArc(endAbsolute = [-15.94, profileStartY(%) - 7.73]) |> tangentialArc(endAbsolute = [-16.6, profileStartY(%) - 15.52]) @@ -45,7 +45,7 @@ export fn divider(plane) { fn connectorSketch(plane, start) { sketch001 = startSketchOn(plane) - |> startProfileAt(start, %) + |> startProfile(at = start) |> polygon( radius = 1.2, numSides = 6, @@ -65,7 +65,7 @@ export fn connector(plane, length) { fn seatSlatSketch(plane) { sketch003 = startSketchOn(plane) - |> startProfileAt([-7, 19], %) + |> startProfile(at = [-7, 19]) |> line(end = [-10, 0.5]) |> line(end = [0.2, 2.5]) |> line(end = [1.5, 1.5]) @@ -85,7 +85,7 @@ export fn seatSlats(plane, length) { fn backSlatsSketch(plane) { sketch004 = startSketchOn(plane) - |> startProfileAt([22, 38.5], %) + |> startProfile(at = [22, 38.5]) |> angledLine(angle = 173, length = 2) |> line(end = [-1.74, 2.03]) |> angledLine(angle = 82, length = 6.6) @@ -105,7 +105,7 @@ export fn backSlats(plane, length) { fn armRestPath(plane) { sketch005 = startSketchOn(plane) - |> startProfileAt([20, 33], %) + |> startProfile(at = [20, 33]) |> xLine(length = -20) |> arc(angleStart = 90, angleEnd = 180, radius = 10) return sketch005 @@ -113,7 +113,7 @@ fn armRestPath(plane) { fn armRestProfile(plane, offset) { sketch006 = startSketchOn(plane) - |> startProfileAt([offset, 32.4], %) + |> startProfile(at = [offset, 32.4]) |> xLine(length = 1.3) |> line(end = [0.3, 0.6]) |> line(end = [-0.3, 0.6]) diff --git a/public/kcl-samples/bottle/main.kcl b/public/kcl-samples/bottle/main.kcl index 31d7132fd..179ae216e 100644 --- a/public/kcl-samples/bottle/main.kcl +++ b/public/kcl-samples/bottle/main.kcl @@ -14,7 +14,7 @@ wallThickness = 4 // Create a rounded body for the bottle bottleBody = startSketchOn(XY) - |> startProfileAt([-bottleLength / 2, 0], %) + |> startProfile(at = [-bottleLength / 2, 0]) |> yLine(length = bottleWidth / 3) |> arc(endAbsolute = [bottleLength / 2, bottleWidth / 3], interiorAbsolute = [0, bottleWidth / 2]) |> yLine(endAbsolute = 0) diff --git a/public/kcl-samples/bracket/main.kcl b/public/kcl-samples/bracket/main.kcl index 20759eec6..2c15fb6ee 100644 --- a/public/kcl-samples/bracket/main.kcl +++ b/public/kcl-samples/bracket/main.kcl @@ -32,7 +32,7 @@ assert(width, isGreaterThanOrEqual = wallMountingHoleDiameter * 5.5, error = "Ho // Create the body of the bracket bracketBody = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = shelfMountLength - thickness, tag = $seg01) |> yLine(length = thickness, tag = $seg02) |> xLine(length = -shelfMountLength, tag = $seg03) diff --git a/public/kcl-samples/car-wheel-assembly/brake-caliper.kcl b/public/kcl-samples/car-wheel-assembly/brake-caliper.kcl index 15ce94f51..90ca8204b 100644 --- a/public/kcl-samples/car-wheel-assembly/brake-caliper.kcl +++ b/public/kcl-samples/car-wheel-assembly/brake-caliper.kcl @@ -9,10 +9,10 @@ import caliperTolerance, caliperPadLength, caliperThickness, caliperOuterEdgeRad // Sketch the brake caliper profile brakeCaliperSketch = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ rotorDiameter / 2 + caliperTolerance, 0 - ], %) + ]) |> line(end = [ 0, rotorTotalThickness + caliperTolerance - caliperInnerEdgeRadius diff --git a/public/kcl-samples/car-wheel-assembly/car-rotor.kcl b/public/kcl-samples/car-wheel-assembly/car-rotor.kcl index 96b389f48..33d31c017 100644 --- a/public/kcl-samples/car-wheel-assembly/car-rotor.kcl +++ b/public/kcl-samples/car-wheel-assembly/car-rotor.kcl @@ -57,7 +57,7 @@ spacerSketch = startSketchOn(rotor, face = START) spacers = extrude(spacerSketch, length = spacerLength) rotorSlottedSketch = startSketchOn(rotor, face = START) - |> startProfileAt([2.17, 2.56], %) + |> startProfile(at = [2.17, 2.56]) |> xLine(length = 0.12) |> yLine(length = 2.56) |> xLine(length = -0.12) @@ -72,7 +72,7 @@ rotorSlottedSketch = startSketchOn(rotor, face = START) rotorSlotted = extrude(rotorSlottedSketch, length = -rotorSinglePlateThickness / 2) secondRotorSlottedSketch = startSketchOn(secondRotor, face = END) - |> startProfileAt([-2.17, 2.56], %) + |> startProfile(at = [-2.17, 2.56]) |> xLine(length = -0.12) |> yLine(length = 2.56) |> xLine(length = 0.12) diff --git a/public/kcl-samples/car-wheel-assembly/car-tire.kcl b/public/kcl-samples/car-wheel-assembly/car-tire.kcl index 1c20b1ea9..f8a26616e 100644 --- a/public/kcl-samples/car-wheel-assembly/car-tire.kcl +++ b/public/kcl-samples/car-wheel-assembly/car-tire.kcl @@ -9,7 +9,7 @@ import tireInnerDiameter, tireOuterDiameter, tireDepth, bendRadius, tireTreadWid // Create the sketch of the tire tireSketch = startSketchOn(XY) - |> startProfileAt([tireInnerDiameter / 2, tireDepth / 2], %) + |> startProfile(at = [tireInnerDiameter / 2, tireDepth / 2]) |> line( endAbsolute = [ tireOuterDiameter / 2 - bendRadius, diff --git a/public/kcl-samples/car-wheel-assembly/car-wheel.kcl b/public/kcl-samples/car-wheel-assembly/car-wheel.kcl index 604922ba2..c113cfc9b 100644 --- a/public/kcl-samples/car-wheel-assembly/car-wheel.kcl +++ b/public/kcl-samples/car-wheel-assembly/car-wheel.kcl @@ -44,7 +44,7 @@ lugHoles = startSketchOn(lugBase, face = END) // Add detail to the wheel center by revolving curved edge profiles wheelCenterInner = startSketchOn(XY) - |> startProfileAt([(lugSpacing - 1.5) / 2, 0], %) + |> startProfile(at = [(lugSpacing - 1.5) / 2, 0]) |> yLine(length = -wheelWidth / 10 - (wheelWidth / 20)) |> bezierCurve(control1 = [-0.3, 0], control2 = [0, 0.3], end = [-0.4, 0.3]) |> yLine(endAbsolute = 0) @@ -54,7 +54,7 @@ wheelCenterInner = startSketchOn(XY) |> appearance(color = "#ffffff", metalness = 0, roughness = 0) wheelCenterOuter = startSketchOn(XY) - |> startProfileAt([(lugSpacing + 1.5) / 2, 0], %) + |> startProfile(at = [(lugSpacing + 1.5) / 2, 0]) |> yLine(length = -wheelWidth / 10 - (wheelWidth / 20)) |> bezierCurve(control1 = [0.3, 0], control2 = [0.2, -0.3], end = [0.4, -0.1]) |> yLine(endAbsolute = -wheelWidth / 20) @@ -75,7 +75,7 @@ fn spoke(spokeGap, spokeAngle, spokeThickness) { // Spoke cross sections spokeProfile = startSketchOn(plane001) - |> startProfileAt([(lugSpacing + 2) / 2, -0.7], %) + |> startProfile(at = [(lugSpacing + 2) / 2, -0.7]) |> bezierCurve( control1 = [ (wheelDiameter - lugSpacing - 2.9) / 3.5, @@ -126,10 +126,10 @@ spoke(-spokeGap, -spokeAngle, -spokeThickness) // Define and revolve wheel exterior startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ wheelDiameter / 2, -wheelWidth + backSpacing + offset - ], %) + ]) |> yLine(length = wheelWidth * 0.25) |> line(end = [-wheelWidth * 0.02, wheelWidth * 0.02]) |> yLine(length = wheelWidth * 0.25) diff --git a/public/kcl-samples/car-wheel-assembly/lug-nut.kcl b/public/kcl-samples/car-wheel-assembly/lug-nut.kcl index e424dfe2b..be94402ac 100644 --- a/public/kcl-samples/car-wheel-assembly/lug-nut.kcl +++ b/public/kcl-samples/car-wheel-assembly/lug-nut.kcl @@ -20,7 +20,7 @@ customPlane = { fn lug(plane, length, diameter) { lugSketch = startSketchOn(customPlane) - |> startProfileAt([0 + diameter / 2, 0], %) + |> startProfile(at = [0 + diameter / 2, 0]) |> angledLine(angle = 70, lengthY = lugHeadLength) |> xLine(endAbsolute = lugDiameter / 2) |> yLine(endAbsolute = lugLength) diff --git a/public/kcl-samples/color-cube/main.kcl b/public/kcl-samples/color-cube/main.kcl index a05d71de1..433127289 100644 --- a/public/kcl-samples/color-cube/main.kcl +++ b/public/kcl-samples/color-cube/main.kcl @@ -22,7 +22,7 @@ tealPlane = offsetPlane(YZ, offset = -halfSize) // Sketch a rectangle centered at the origin of the profile fn sketchRectangle(profile, color) { return profile - |> startProfileAt([-halfSize, halfSize], %) + |> startProfile(at = [-halfSize, halfSize]) |> angledLine(angle = 0, length = size, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = size, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) diff --git a/public/kcl-samples/cycloidal-gear/main.kcl b/public/kcl-samples/cycloidal-gear/main.kcl index 14488c731..7d121d3d2 100644 --- a/public/kcl-samples/cycloidal-gear/main.kcl +++ b/public/kcl-samples/cycloidal-gear/main.kcl @@ -10,10 +10,10 @@ fn cycloidalGear(gearPitch, gearHeight, holeDiameter, helixAngle) { fn gearSketch(gHeight) { helixAngleP = helixAngle * gHeight / gearHeight gearProfile = startSketchOn(offsetPlane(XY, offset = gHeight)) - |> startProfileAt([ + |> startProfile(at = [ gearPitch * 1.55 * cos(toRadians(helixAngleP)) + gearPitch * sin(toRadians(-helixAngleP)), gearPitch * 1.55 * sin(toRadians(helixAngleP)) + gearPitch * cos(toRadians(-helixAngleP)) - ], %) + ]) |> arc(angleStart = 90 + helixAngleP, angleEnd = -90 + helixAngleP, radius = gearPitch) |> tangentialArc(radius = gearPitch * 1.67, angle = 60) |> tangentialArc(radius = gearPitch, angle = -180) diff --git a/public/kcl-samples/dodecahedron/main.kcl b/public/kcl-samples/dodecahedron/main.kcl index 3baf98a1c..dcf932262 100644 --- a/public/kcl-samples/dodecahedron/main.kcl +++ b/public/kcl-samples/dodecahedron/main.kcl @@ -10,7 +10,7 @@ dihedral = 116.565 // Create a face template function that makes a large thin cube fn createFaceTemplate(dither) { baseSketch = startSketchOn(XY) - |> startProfileAt([-1000 - dither, -1000 - dither], %) + |> startProfile(at = [-1000 - dither, -1000 - dither]) |> line(endAbsolute = [1000 + dither, -1000 - dither]) |> line(endAbsolute = [1000 + dither, 1000 + dither]) |> line(endAbsolute = [-1000 - dither, 1000 + dither]) diff --git a/public/kcl-samples/dual-basin-utility-sink/main.kcl b/public/kcl-samples/dual-basin-utility-sink/main.kcl index 4048cea9e..1b9309357 100644 --- a/public/kcl-samples/dual-basin-utility-sink/main.kcl +++ b/public/kcl-samples/dual-basin-utility-sink/main.kcl @@ -27,7 +27,7 @@ floorPlane = startSketchOn(XY) legHeight = blockHeight - profileThickness legCount = blockCount + 1 -legBody = startProfileAt([0, 0], floorPlane) +legBody = startProfile(floorPlane, at = [0, 0]) |> yLine(length = profileThickness) |> xLine(length = profileThickness) |> yLine(length = -profileThickness) @@ -42,7 +42,7 @@ lowerBeltHeightAboveTheFloor = 150 lowerBeltLengthX = blockWidth - profileThickness lowerBeltPlane = startSketchOn(offsetPlane(XY, offset = lowerBeltHeightAboveTheFloor)) -lowerBeltBodyX = startProfileAt([profileThickness, 0], lowerBeltPlane) +lowerBeltBodyX = startProfile(lowerBeltPlane, at = [profileThickness, 0]) |> yLine(length = profileThickness) |> xLine(length = lowerBeltLengthX) |> yLine(length = -profileThickness) @@ -53,7 +53,7 @@ lowerBeltBodyX = startProfileAt([profileThickness, 0], lowerBeltPlane) |> extrude(length = profileThickness) lowerBeltLengthY = blockDepth - profileThickness -lowerBeltBodyY = startProfileAt([0, profileThickness], lowerBeltPlane) +lowerBeltBodyY = startProfile(lowerBeltPlane, at = [0, profileThickness]) |> yLine(length = lowerBeltLengthY) |> xLine(length = profileThickness) |> yLine(length = -lowerBeltLengthY) @@ -67,7 +67,7 @@ pillarHeightAboveTheFloor = lowerBeltHeightAboveTheFloor + profileThickness pillarPlane = startSketchOn(offsetPlane(XY, offset = pillarHeightAboveTheFloor)) pillarTotalHeight = blockHeight - profileThickness - pillarHeightAboveTheFloor -pillarBody = startProfileAt([blockSubdivisionWidth, 0], pillarPlane) +pillarBody = startProfile(pillarPlane, at = [blockSubdivisionWidth, 0]) |> yLine(length = profileThickness) |> xLine(length = profileThickness) |> yLine(length = -profileThickness) @@ -80,7 +80,7 @@ pillarBody = startProfileAt([blockSubdivisionWidth, 0], pillarPlane) // upper belt upperBeltPlane = startSketchOn(offsetPlane(XY, offset = blockHeight)) -upperBeltBodyX = startProfileAt([0, 0], upperBeltPlane) +upperBeltBodyX = startProfile(upperBeltPlane, at = [0, 0]) |> yLine(length = profileThickness) |> xLine(length = tableWidth) |> yLine(length = -profileThickness) @@ -90,7 +90,7 @@ upperBeltBodyX = startProfileAt([0, 0], upperBeltPlane) |> extrude(length = -profileThickness) upperBeltLengthY = blockDepth - profileThickness -upperBeltBodyY = startProfileAt([0, profileThickness], upperBeltPlane) +upperBeltBodyY = startProfile(upperBeltPlane, at = [0, profileThickness]) |> yLine(length = upperBeltLengthY) |> xLine(length = profileThickness) |> yLine(length = -upperBeltLengthY) @@ -101,7 +101,7 @@ upperBeltBodyY = startProfileAt([0, profileThickness], upperBeltPlane) // sink tableTopPlane = startSketchOn(offsetPlane(XY, offset = tableHeight)) -tableTopBody = startProfileAt([0, 0], tableTopPlane) +tableTopBody = startProfile(tableTopPlane, at = [0, 0]) |> yLine(length = tableDepth) |> xLine(length = tableWidth) |> yLine(length = -tableDepth) @@ -118,7 +118,7 @@ sinkOffsetLeft = 350 sinkSpacing = tableWidth - sinkWidth - (sinkOffsetLeft * 2) sinkPlaneOutside = startSketchOn(tableTopBody, face = START) -sinkBodyOutside = startProfileAt([-sinkOffsetLeft, sinkOffsetFront], sinkPlaneOutside) +sinkBodyOutside = startProfile(sinkPlaneOutside, at = [-sinkOffsetLeft, sinkOffsetFront]) |> yLine(length = sinkLength) |> xLine(length = -sinkWidth) |> yLine(length = -sinkLength) @@ -128,10 +128,13 @@ sinkBodyOutside = startProfileAt([-sinkOffsetLeft, sinkOffsetFront], sinkPlaneOu |> extrude(length = sinkDepth) sinkPlaneInside = startSketchOn(tableTopBody, face = END) -sinkBodyInside = startProfileAt([ - sinkOffsetLeft + metalThickness, - sinkOffsetFront + metalThickness - ], sinkPlaneInside) +sinkBodyInside = startProfile( + sinkPlaneInside, + at = [ + sinkOffsetLeft + metalThickness, + sinkOffsetFront + metalThickness + ], + ) |> yLine(length = sinkLength - (metalThickness * 2)) |> xLine(length = sinkWidth - (metalThickness * 2)) |> yLine(length = -sinkLength + metalThickness * 2) @@ -149,7 +152,7 @@ doorHeight = blockHeight - doorHeightAboveTheFloor - profileThickness - doorGap doorCount = blockCount * blockSubdivisionCount doorPlane = startSketchOn(offsetPlane(XY, offset = doorHeightAboveTheFloor)) -doorBody = startProfileAt([doorStart, 0], doorPlane) +doorBody = startProfile(doorPlane, at = [doorStart, 0]) |> yLine(length = profileThickness) |> xLine(length = doorWidth) |> yLine(length = -profileThickness) @@ -162,7 +165,7 @@ doorBody = startProfileAt([doorStart, 0], doorPlane) panelWidth = blockDepth - profileThickness - (doorGap * 2) panelCount = doorCount + 1 panelSpacing = tableWidth - profileThickness -panelBody = startProfileAt([0, doorStart], doorPlane) +panelBody = startProfile(doorPlane, at = [0, doorStart]) |> yLine(length = panelWidth) |> xLine(length = profileThickness) |> yLine(length = -panelWidth) @@ -182,7 +185,7 @@ handleLengthSegmentB = handleWidth - (handleFillet * 2) handlePlane = startSketchOn(offsetPlane(XY, offset = handleHeightAboveTheFloor)) -handleProfilePath = startProfileAt([0 + handleOffset, 0], handlePlane) +handleProfilePath = startProfile(handlePlane, at = [0 + handleOffset, 0]) |> yLine(length = -handleLengthSegmentA) |> tangentialArc(endAbsolute = [ handleFillet + handleOffset, diff --git a/public/kcl-samples/enclosure/main.kcl b/public/kcl-samples/enclosure/main.kcl index e24fe76cb..76a4dc32e 100644 --- a/public/kcl-samples/enclosure/main.kcl +++ b/public/kcl-samples/enclosure/main.kcl @@ -13,7 +13,7 @@ holeDia = 4 // Model a box with base enclosure dimensions sketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 0, length = width, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = length, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -72,7 +72,7 @@ function001([ // Define lid position and outer surface sketch003 = startSketchOn(XY) - |> startProfileAt([width * 1.2, 0], %) + |> startProfile(at = [width * 1.2, 0]) |> angledLine(angle = 0, length = width, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = length, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC002) @@ -119,10 +119,10 @@ extrude003 = extrude(sketch003, length = wallThickness) // Define lid inner and sealing surfaces sketch004 = startSketchOn(extrude003, face = END) - |> startProfileAt([ + |> startProfile(at = [ width * 1.2 + wallThickness, wallThickness - ], %) + ]) |> angledLine(angle = 0, length = width - (2 * wallThickness), tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) + 90, length = length - (2 * wallThickness), tag = $rectangleSegmentB003) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC003) diff --git a/public/kcl-samples/exhaust-manifold/main.kcl b/public/kcl-samples/exhaust-manifold/main.kcl index c1baec09e..2fd228a37 100644 --- a/public/kcl-samples/exhaust-manifold/main.kcl +++ b/public/kcl-samples/exhaust-manifold/main.kcl @@ -29,7 +29,7 @@ fn primaryTube(n, angle001, length001, length002, length003) { // Draw a path for each sweep sweepPath = startSketchOn(sweepPlane) - |> startProfileAt([0, plateHeight], %) + |> startProfile(at = [0, plateHeight]) |> line(end = [0, length001]) |> tangentialArc(angle = -80, radius = bendRadius, tag = $arc01) |> angledLine(angle = tangentToEnd(arc01), length = length002) @@ -53,7 +53,7 @@ primaryTube(3, 25.2, 5, 5, 3) // Create the mounting flange for the header flangeSketch = startSketchOn(XY) - |> startProfileAt([3 + 1.3, -1.25], %) + |> startProfile(at = [3 + 1.3, -1.25]) |> xLine(length = -2.6, tag = $seg01) |> tangentialArc(radius = .3, angle = -40) |> tangentialArc(radius = .9, angle = 80) diff --git a/public/kcl-samples/focusrite-scarlett-mounting-bracket/main.kcl b/public/kcl-samples/focusrite-scarlett-mounting-bracket/main.kcl index 9b6a91e11..33f3b023f 100644 --- a/public/kcl-samples/focusrite-scarlett-mounting-bracket/main.kcl +++ b/public/kcl-samples/focusrite-scarlett-mounting-bracket/main.kcl @@ -18,7 +18,7 @@ tabThk = 4 // Define a rectangular shape func fn rectShape(pos, w, l) { rr = startSketchOn(XY) - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge01) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge02) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge03) @@ -37,7 +37,7 @@ bracketPlane = { // Build the bracket sketch around the body fn bracketSketch(w, d, t) { s = startSketchOn(bracketPlane) - |> startProfileAt([-w / 2 - t, d + t], %) + |> startProfile(at = [-w / 2 - t, d + t]) |> line(endAbsolute = [-w / 2 - t, -t], tag = $edge1) |> line(endAbsolute = [w / 2 + t, -t], tag = $edge2) |> line(endAbsolute = [w / 2 + t, d + t], tag = $edge3) @@ -73,7 +73,7 @@ tabPlane = { // Build the tabs of the mounting bracket (right side) tabsR = startSketchOn(tabPlane) - |> startProfileAt([width / 2 + thk, length / 2 + thk], %) + |> startProfile(at = [width / 2 + thk, length / 2 + thk]) |> line(end = [tabWidth, -tabLength / 3], tag = $edge11) |> line(end = [0, -tabLength / 3 * 2], tag = $edge12) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge13) @@ -97,7 +97,7 @@ tabsR = startSketchOn(tabPlane) // Build the tabs of the mounting bracket (left side) tabsL = startSketchOn(tabPlane) - |> startProfileAt([-width / 2 - thk, length / 2 + thk], %) + |> startProfile(at = [-width / 2 - thk, length / 2 + thk]) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge21) |> line(end = [0, -tabLength / 3 * 2], tag = $edge22) |> line(end = [tabWidth, -tabLength / 3], tag = $edge23) @@ -129,7 +129,7 @@ retPlane = { // Build the retention bump in the front retFront = startSketchOn(retPlane) - |> startProfileAt([-length / 2 - thk, 0], %) + |> startProfile(at = [-length / 2 - thk, 0]) |> line(end = [0, thk]) |> line(end = [thk, -thk]) |> close() @@ -137,7 +137,7 @@ retFront = startSketchOn(retPlane) // Build the retention bump in the back retBack = startSketchOn(retPlane) - |> startProfileAt([length / 2 + thk, 0], %) + |> startProfile(at = [length / 2 + thk, 0]) |> line(end = [0, thk]) |> line(end = [-thk, 0]) |> line(end = [0, -thk]) diff --git a/public/kcl-samples/food-service-spatula/main.kcl b/public/kcl-samples/food-service-spatula/main.kcl index 6be8bab68..9056546f2 100644 --- a/public/kcl-samples/food-service-spatula/main.kcl +++ b/public/kcl-samples/food-service-spatula/main.kcl @@ -34,7 +34,7 @@ fn slot(sketch1, start, end, width) { dist = sqrt(pow(end[1] - start[1], 2) + pow(end[0] - start[0], 2)) xstart = width / 2 * cos(toRadians(angle - 90)) + start[0] ystart = width / 2 * sin(toRadians(angle - 90)) + start[1] - slotSketch = startProfileAt([xstart, ystart], sketch1) + slotSketch = startProfile(sketch1, at = [xstart, ystart]) |> angledLine(angle = angle, length = dist) |> tangentialArc(radius = width / 2, angle = 180) |> angledLine(angle = angle, length = -dist) @@ -47,7 +47,7 @@ fn slot(sketch1, start, end, width) { flipperSketch = startSketchOn(XY) // Create a profile of the flipper -flipperProfile = startProfileAt([-flipperLength, -32.0], flipperSketch) +flipperProfile = startProfile(flipperSketch, at = [-flipperLength, -32.0]) |> line(end = [flipperLength, 2.0]) |> yLine(length = 60.0, tag = $backEdge) |> line(end = [-flipperLength, 2.0]) @@ -86,7 +86,7 @@ fillet( handleSketch = startSketchOn(offsetPlane(XZ, offset = -handleWidth / 2)) // Create a profile of the spatula handle -handleProfile = startProfileAt([0.0, flipperThickness], handleSketch) +handleProfile = startProfile(handleSketch, at = [0.0, flipperThickness]) |> line(end = [31.819805, 31.819805], tag = $handleBottomEdge) |> line(end = [140.953893, 51.303021]) |> line(end = [-1.710101, 4.698463]) @@ -120,7 +120,7 @@ handlePlane = { gripSketch = startSketchOn(handlePlane) // Create a profile of the grip -gripProfile = startProfileAt([-26.806746, -10.0], gripSketch) +gripProfile = startProfile(gripSketch, at = [-26.806746, -10.0]) |> xLine(length = gripWidth - (2 * gripFilletRadius)) |> arc(angleStart = -90.0, angleEnd = 0.0, radius = gripFilletRadius) |> yLine(length = gripHeight - (2 * gripFilletRadius)) diff --git a/public/kcl-samples/french-press/main.kcl b/public/kcl-samples/french-press/main.kcl index a87e4c562..5a0a7cd5a 100644 --- a/public/kcl-samples/french-press/main.kcl +++ b/public/kcl-samples/french-press/main.kcl @@ -11,7 +11,7 @@ handleThickness = 0.65 // Upper ring of the metal structure sketch001 = startSketchOn(XZ) - |> startProfileAt([carafeDiameter / 2, 5.7], %) + |> startProfile(at = [carafeDiameter / 2, 5.7]) |> angledLine(angle = 0, length = 0.1, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = -0.75, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -29,7 +29,7 @@ plane001 = { // Cross section of the metal supports sketch002 = startSketchOn(plane001) - |> startProfileAt([carafeDiameter / 2, 5.7], %) + |> startProfile(at = [carafeDiameter / 2, 5.7]) |> xLine(length = 0.1) |> yLine(length = -5.2, tag = $edge1) |> arc(angleStart = 180, angleEnd = 205, radius = 0.3) @@ -63,7 +63,7 @@ sketch003 = startSketchOn(offsetPlane(XY, offset = 1)) extrude001 = extrude(sketch003, length = 0.050) sketch004 = startSketchOn(extrude001, face = END) - |> startProfileAt([0.3, 0.17], %) + |> startProfile(at = [0.3, 0.17]) |> yLine(length = 1.2) |> arc(angleStart = 90, angleEnd = -30, radius = 1.2) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -79,7 +79,7 @@ extrude002 = extrude(sketch004, length = -0.050) // Filter screen sketch005 = startSketchOn(XZ) - |> startProfileAt([0.15, 1.11], %) + |> startProfile(at = [0.15, 1.11]) |> xLine(endAbsolute = carafeDiameter / 2 - 0.2) |> angledLine(angle = 30, endAbsoluteX = carafeDiameter / 2 - 0.07, tag = $seg1) |> angledLine(angle = -60, length = 0.050) @@ -91,7 +91,7 @@ sketch005 = startSketchOn(XZ) // Plunger and stem sketch006 = startSketchOn(XZ) - |> startProfileAt([0.1, 1], %) + |> startProfile(at = [0.1, 1]) |> line(end = [0.1, 0]) |> angledLine(angle = 10, endAbsoluteX = 0.05) |> yLine(length = 10) @@ -143,7 +143,7 @@ extrude006 = extrude(sketch010, length = carafeHeight) // Draw and revolve the lid sketch011 = startSketchOn(XZ) - |> startProfileAt([0.2, carafeHeight - 0.7], %) + |> startProfile(at = [0.2, carafeHeight - 0.7]) |> xLine(length = carafeDiameter / 2 - 0.3) |> yLine(length = 0.7) |> xLine(length = 0.3) @@ -156,7 +156,7 @@ sketch011 = startSketchOn(XZ) // Draw and extrude handle sketch012 = startSketchOn(offsetPlane(XZ, offset = handleThickness / 2)) - |> startProfileAt([2.3, 6.4], %) + |> startProfile(at = [2.3, 6.4]) |> line(end = [0.56, 0]) |> tangentialArc(endAbsolute = [4.1, 5.26]) |> tangentialArc(endAbsolute = [4.17, 1.6]) diff --git a/public/kcl-samples/gear-rack/main.kcl b/public/kcl-samples/gear-rack/main.kcl index 972e943ff..1578b3acc 100644 --- a/public/kcl-samples/gear-rack/main.kcl +++ b/public/kcl-samples/gear-rack/main.kcl @@ -13,7 +13,7 @@ minHeight = 10.875 // Create the body of the rack rackBody = startSketchOn(XY) - |> startProfileAt([-length / 2, 0], %) + |> startProfile(at = [-length / 2, 0]) |> line(end = [length, 0]) |> line(end = [0, minHeight]) |> line(end = [-length, 0]) @@ -23,7 +23,7 @@ rackBody = startSketchOn(XY) // Create a function for sketch of a single tooth fn tooth() { toothSketch = startSketchOn(XY) - |> startProfileAt([-length / 2 + 0.567672, minHeight], %) + |> startProfile(at = [-length / 2 + 0.567672, minHeight]) |> tangentialArc(end = [0.157636, 0.110378]) |> line(end = [0.329118, 0.904244]) |> tangentialArc(end = [0.157636, 0.110378]) @@ -42,7 +42,7 @@ teeth = tooth() // Sketch and extrude the first end cap. This is a partial tooth endCapTooth = startSketchOn(XY) - |> startProfileAt([-length / 2, 11.849525], %) + |> startProfile(at = [-length / 2, 11.849525]) |> line(end = [0.314524, -0.864147]) |> tangentialArc(end = [0.157636, -0.110378]) |> line(endAbsolute = [-length / 2, minHeight]) @@ -51,7 +51,7 @@ endCapTooth = startSketchOn(XY) // Sketch and extrude the second end cap. This is a partial tooth endCapTooth2 = startSketchOn(XY) - |> startProfileAt([length / 2, 11.849525], %) + |> startProfile(at = [length / 2, 11.849525]) |> line(end = [-0.314524, -0.864147]) |> tangentialArc(end = [-0.157636, -0.110378]) |> line(endAbsolute = [length / 2, minHeight]) diff --git a/public/kcl-samples/gear/main.kcl b/public/kcl-samples/gear/main.kcl index 45d73fc8f..65b985e4f 100644 --- a/public/kcl-samples/gear/main.kcl +++ b/public/kcl-samples/gear/main.kcl @@ -61,7 +61,7 @@ fn rightInvolute(i, sg) { // Draw gear teeth start = startSketchOn(XY) - |> startProfileAt([xs[101], ys[101]], %) + |> startProfile(at = [xs[101], ys[101]]) teeth = reduce([0..100], start, leftInvolute) |> arc(angleStart = 0, angleEnd = toothAngle, radius = baseDiameter / 2) |> reduce([1..101], %, rightInvolute) @@ -84,10 +84,10 @@ startAngle = asin(keywayWidth / 2 / holeRadius) // Sketch the keyway and center hole and extrude keyWay = startSketchOn(body, face = END) - |> startProfileAt([ + |> startProfile(at = [ holeRadius * cos(startAngle), holeRadius * sin(startAngle) - ], %) + ]) |> xLine(length = keywayDepth) |> yLine(length = -keywayWidth) |> xLine(length = -keywayDepth) diff --git a/public/kcl-samples/gridfinity-baseplate-magnets/main.kcl b/public/kcl-samples/gridfinity-baseplate-magnets/main.kcl index 77a805b77..91b9fc062 100644 --- a/public/kcl-samples/gridfinity-baseplate-magnets/main.kcl +++ b/public/kcl-samples/gridfinity-baseplate-magnets/main.kcl @@ -24,7 +24,7 @@ height = firstStep + secondStep + thirdStep // Define a function which builds the profile of the baseplate bin fn face(plane) { faceSketch = startSketchOn(plane) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = height) |> angledLine(angle = -45, lengthY = thirdStep) |> yLine(length = -secondStep) @@ -86,10 +86,10 @@ basePlateCorners = patternLinear3d( // Create the center cutout for the magnet profile fn magnetCenterCutout(plane) { magnetSketch = startSketchOn(plane) - |> startProfileAt([ + |> startProfile(at = [ firstStep + thirdStep, 2 * magOuterDiam - ], %) + ]) |> xLine(length = 2 * magOuterDiam - (firstStep + thirdStep) - (magOuterDiam / 2)) |> arc(angleStart = 90.0, angleEnd = 0.0, radius = magOuterDiam / 2) |> yLine(length = -(2 * magOuterDiam - (firstStep + thirdStep) - (magOuterDiam / 2))) @@ -113,7 +113,7 @@ fn magnetCenterCutout(plane) { // Create the outside profile of the magnets fn magnetBase(plane) { magnetBaseSketch = startSketchOn(plane) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = binLength, tag = $line001) |> yLine(length = binLength, tag = $line002) |> xLine(endAbsolute = profileStartX(%), tag = $line003) diff --git a/public/kcl-samples/gridfinity-baseplate/main.kcl b/public/kcl-samples/gridfinity-baseplate/main.kcl index 4f03353aa..1d1281fbe 100644 --- a/public/kcl-samples/gridfinity-baseplate/main.kcl +++ b/public/kcl-samples/gridfinity-baseplate/main.kcl @@ -21,7 +21,7 @@ height = firstStep + secondStep + thirdStep // Define a function which builds the profile of the baseplate bin fn face(plane) { faceSketch = startSketchOn(plane) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = height) |> angledLine(angle = -45, lengthY = thirdStep) |> yLine(length = -secondStep) diff --git a/public/kcl-samples/gridfinity-bins-stacking-lip/main.kcl b/public/kcl-samples/gridfinity-bins-stacking-lip/main.kcl index 96b8555f4..0f63cdfa0 100644 --- a/public/kcl-samples/gridfinity-bins-stacking-lip/main.kcl +++ b/public/kcl-samples/gridfinity-bins-stacking-lip/main.kcl @@ -36,7 +36,7 @@ lipHeight = lipStep1 + lipStep2 + lipStep3 + lipStep4 + lipStep5 // Define a function which builds the profile of the baseplate bin fn face(plane) { faceSketch = startSketchOn(plane) - |> startProfileAt([binBaseLength + binTol, 0], %) + |> startProfile(at = [binBaseLength + binTol, 0]) |> yLine(length = height) |> xLine(length = -binBaseLength) |> angledLine(angle = -45, lengthY = thirdStep) @@ -90,10 +90,10 @@ corners = patternCircular3d( ) singleBinFill = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ binBaseLength + binTol, binBaseLength + binTol - ], %) + ]) |> line(end = [binLength - (binBaseLength * 2), 0], tag = $line000) |> line(end = [0, binLength - (binBaseLength * 2)], tag = $line001) |> xLine(endAbsolute = profileStartX(%), tag = $line002) @@ -156,7 +156,7 @@ binFill = patternLinear3d( |> patternLinear3d(axis = [0.0, 1.0, 0.0], instances = countBinLength, distance = binLength + binTol * 2) binTop = startSketchOn(offsetPlane(XY, offset = height)) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = (binLength + 2 * binTol) * countBinWidth, tag = $line010) |> yLine(length = (binLength + 2 * binTol) * countBinLength, tag = $line011) |> xLine(endAbsolute = profileStartX(%), tag = $line012) @@ -176,7 +176,7 @@ binTop = startSketchOn(offsetPlane(XY, offset = height)) // Define a function which builds the profile of the baseplate bin fn lipFace(plane) { faceSketch = startSketchOn(plane) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // |> yLine(length = lipHeight, tag = $line100) |> line(end = [0.0, 5.792893], tag = $line000) |> arc( diff --git a/public/kcl-samples/gridfinity-bins/main.kcl b/public/kcl-samples/gridfinity-bins/main.kcl index 2be98afa6..1fbad9966 100644 --- a/public/kcl-samples/gridfinity-bins/main.kcl +++ b/public/kcl-samples/gridfinity-bins/main.kcl @@ -29,7 +29,7 @@ height = firstStep + secondStep + thirdStep // Define a function which builds the profile of the baseplate bin fn face(plane) { faceSketch = startSketchOn(plane) - |> startProfileAt([binBaseLength + binTol, 0], %) + |> startProfile(at = [binBaseLength + binTol, 0]) |> yLine(length = height) |> xLine(length = -binBaseLength) |> angledLine(angle = -45, lengthY = thirdStep) @@ -83,10 +83,10 @@ corners = patternCircular3d( ) singleBinFill = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ binBaseLength + binTol, binBaseLength + binTol - ], %) + ]) |> line(end = [binLength - (binBaseLength * 2), 0], tag = $line000) |> line(end = [0, binLength - (binBaseLength * 2)], tag = $line001) |> xLine(endAbsolute = profileStartX(%), tag = $line002) @@ -150,7 +150,7 @@ binFill = patternLinear3d( // Create the top of the bin binTop = startSketchOn(offsetPlane(XY, offset = height)) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = (binLength + 2 * binTol) * countBinWidth, tag = $line010) |> yLine(length = (binLength + 2 * binTol) * countBinLength, tag = $line011) |> xLine(endAbsolute = profileStartX(%), tag = $line012) diff --git a/public/kcl-samples/hex-nut/main.kcl b/public/kcl-samples/hex-nut/main.kcl index 29197c874..7b4abb294 100644 --- a/public/kcl-samples/hex-nut/main.kcl +++ b/public/kcl-samples/hex-nut/main.kcl @@ -12,7 +12,7 @@ diameter = 0.3125 // Define a function for the hex nut fn hexNut(start, thk, innerDia) { hexNutSketch = startSketchOn(-XZ) - |> startProfileAt([start[0] + innerDia, start[1]], %) + |> startProfile(at = [start[0] + innerDia, start[1]]) |> angledLine(angle = 240, length = innerDia) |> angledLine(angle = 180, length = innerDia) |> angledLine(angle = 120, length = innerDia) diff --git a/public/kcl-samples/i-beam/main.kcl b/public/kcl-samples/i-beam/main.kcl index 544a43b18..95436e4ff 100644 --- a/public/kcl-samples/i-beam/main.kcl +++ b/public/kcl-samples/i-beam/main.kcl @@ -14,7 +14,7 @@ rootRadius = 0.457 // Sketch a quadrant of the beam cross section, then mirror for symmetry across each axis. Extrude to the appropriate length iBeam = startSketchOn(-XZ) - |> startProfileAt([0, beamHeight / 2], %) + |> startProfile(at = [0, beamHeight / 2]) |> xLine(length = flangeWidth / 2) |> yLine(length = -flangeThickness) |> xLine(endAbsolute = webThickness / 2 + rootRadius) diff --git a/public/kcl-samples/keyboard/main.kcl b/public/kcl-samples/keyboard/main.kcl index 1e02fe5ac..6cd650929 100644 --- a/public/kcl-samples/keyboard/main.kcl +++ b/public/kcl-samples/keyboard/main.kcl @@ -20,7 +20,7 @@ row6 = row5 + keyHeight + spacing // Sketch the side profile of the keyboard base and extrude to total width sketch001 = startSketchOn(YZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [-0.14, 0.68], tag = $seg01) |> angledLine(angle = 7, length = row6 + 3 * spacing + keyHeight, tag = $seg02) |> line(endAbsolute = [5.13, 0], tag = $seg03) @@ -65,7 +65,7 @@ plane001 = { // Create a function to build a key. Parameterize for position, width, height, number of instances, and appearance color. fn keyFn(originStart, keyWidth, keyHeight, repeats, color) { sketch002 = startSketchOn(plane001) - profile002 = startProfileAt([originStart[0], originStart[1]], sketch002) + profile002 = startProfile(sketch002, at = [originStart[0], originStart[1]]) |> arc(angleStart = 180, angleEnd = 270, radius = 0.1) |> angledLine(angle = 0, length = keyWidth - .2, tag = $rectangleSegmentA001) |> tangentialArc(radius = 0.1, angle = 90) @@ -131,10 +131,10 @@ plane002 = { // Define a function to draw the ZOO 'Z' fn z(origin, scale, depth) { z = startSketchOn(plane002) - |> startProfileAt([ + |> startProfile(at = [ 0 + origin[0], 0.15 * scale + origin[1] - ], %) + ]) |> yLine(length = -0.15 * scale) |> xLine(length = 0.15 * scale) |> angledLine(angle = 47.15, endAbsoluteX = 0.3 * scale + origin[0], tag = $seg1) @@ -159,10 +159,10 @@ fn z(origin, scale, depth) { // Define a function to draw the ZOO 'O' fn o(origin, scale, depth) { oSketch001 = startSketchOn(plane002) - |> startProfileAt([ + |> startProfile(at = [ .788 * scale + origin[0], .921 * scale + origin[1] - ], %) + ]) |> arc(angleStart = 47.15 + 6, angleEnd = 47.15 - 6 + 180, radius = .525 * scale) |> angledLine(angle = 47.15, length = .24 * scale) |> arc(angleStart = 47.15 - 11 + 180, angleEnd = 47.15 + 11, radius = .288 * scale) @@ -171,10 +171,10 @@ fn o(origin, scale, depth) { |> appearance(color = baseColor) o = startSketchOn(plane002) - |> startProfileAt([ + |> startProfile(at = [ .16 * scale + origin[0], .079 * scale + origin[1] - ], %) + ]) |> arc(angleStart = 47.15 + 6 - 180, angleEnd = 47.15 - 6, radius = .525 * scale) |> angledLine(angle = 47.15, length = -.24 * scale) |> arc(angleStart = 47.15 - 11, angleEnd = 47.15 + 11 - 180, radius = .288 * scale) diff --git a/public/kcl-samples/kitt/main.kcl b/public/kcl-samples/kitt/main.kcl index 3425cee48..dbc62717e 100644 --- a/public/kcl-samples/kitt/main.kcl +++ b/public/kcl-samples/kitt/main.kcl @@ -4,7 +4,7 @@ // Pixel box function fn pixelBox(kitExtrude, extrudeTag, positionY, positionZ, width, height, depth) { pixelBoxBody = startSketchOn(kitExtrude, face = extrudeTag) - |> startProfileAt([positionY, positionZ], %) + |> startProfile(at = [positionY, positionZ]) |> line(end = [0, height]) |> line(end = [width, 0]) |> line(end = [0, -height]) @@ -21,7 +21,7 @@ kitBodyHeight = 25 kitBodyDepth = 18 kitBody = startSketchOn(XZ) - |> startProfileAt([-kitBodyWidth / 2, kitBodyElevation], %) + |> startProfile(at = [-kitBodyWidth / 2, kitBodyElevation]) |> line(end = [0, kitBodyHeight]) |> line(end = [kitBodyWidth, 0], tag = $seg01) |> line(end = [0, -kitBodyHeight], tag = $seg02) @@ -46,7 +46,7 @@ kitFaceHeight = kitHeadElevation + kitHeadHeight - kitFaceElevation - 3 kitFaceDepth = 2 kitFace = startSketchOn(kitHead, face = END) - |> startProfileAt([-kitFaceWidth / 2, kitFaceElevation], %) + |> startProfile(at = [-kitFaceWidth / 2, kitFaceElevation]) |> line(end = [0, 1]) // left lower corner up |> line(end = [-1, 0]) // left lower corner left |> line(end = [0, kitFaceHeight]) // left side up @@ -79,7 +79,7 @@ kitLeftEye3 = pixelBox(kitFace, START, -kitEyeOffset + 4, kitEyeHeihgt, 1, 1, ki kitRightEye = pixelBox(kitFace, START, kitEyeOffset - 3, kitEyeHeihgt - 1, 2, 4, kitEyeDepth) kitNoseElevation = kitEyeHeihgt - 5 kitNose = startSketchOn(kitFace, face = START) - |> startProfileAt([-2, kitNoseElevation], %) // H V + |> startProfile(at = [-2, kitNoseElevation]) // H V |> line(end = [0, 1]) // lower-left up |> line(end = [2, 0]) // lower-left right |> line(end = [0, 2]) // mid-left up @@ -160,7 +160,7 @@ fn kitLeg(offsetFront, offsetSide) { kitShoeOffsetFront = kitShoeLength / 2 - (kitBodyDepth / 2) - offsetFront kitFootPrint = startSketchOn(XY) - |> startProfileAt([offsetSide, kitShoeOffsetFront], %) + |> startProfile(at = [offsetSide, kitShoeOffsetFront]) |> line(end = [kitShoeWidth, 0]) |> line(end = [0, -kitShoeLength]) |> line(end = [-kitShoeWidth, 0]) diff --git a/public/kcl-samples/lego/main.kcl b/public/kcl-samples/lego/main.kcl index 79edf94b1..d1b67700b 100644 --- a/public/kcl-samples/lego/main.kcl +++ b/public/kcl-samples/lego/main.kcl @@ -27,7 +27,7 @@ assert(wbumps, isGreaterThan = 1, error = "wbumps must be greater than 1") // Make the base base = startSketchOn(XY) - |> startProfileAt([-totalWidth / 2, -totalLength / 2], %) + |> startProfile(at = [-totalWidth / 2, -totalLength / 2]) |> line(end = [totalWidth, 0]) |> line(end = [0, totalLength]) |> line(end = [-totalWidth, 0]) @@ -36,10 +36,10 @@ base = startSketchOn(XY) // Sketch and extrude a rectangular shape to create the shell underneath the lego. Will replace with shell function when able to call a face created from shell. shellExtrude = startSketchOn(base, face = START) - |> startProfileAt([ + |> startProfile(at = [ -(totalWidth / 2 - t), -(totalLength / 2 - t) - ], %) + ]) |> line(end = [totalWidth - (2 * t), 0]) |> line(end = [0, totalLength - (2 * t)]) |> line(end = [-(totalWidth - (2 * t)), 0]) diff --git a/public/kcl-samples/makeup-mirror/main.kcl b/public/kcl-samples/makeup-mirror/main.kcl index 00ceb0d1a..a2586ab97 100644 --- a/public/kcl-samples/makeup-mirror/main.kcl +++ b/public/kcl-samples/makeup-mirror/main.kcl @@ -56,7 +56,7 @@ fn mirrorFn(plane, offsetX, offsetY, altitude, radius, tiefe, gestellR, gestellD armBody = circle(armPlane, center = [offsetX, altitude], radius = radius) |> extrude(length = tiefe) - archBody = startProfileAt([offsetX - gestellR, altitude], armPlane) + archBody = startProfile(armPlane, at = [offsetX - gestellR, altitude]) |> xLine(length = gestellD) |> arc(interiorAbsolute = [offsetX, altitude - gestellR], endAbsolute = [offsetX + gestellR, altitude]) |> xLine(length = gestellD) diff --git a/public/kcl-samples/mounting-plate/main.kcl b/public/kcl-samples/mounting-plate/main.kcl index 3c86913f7..4f4005fa1 100644 --- a/public/kcl-samples/mounting-plate/main.kcl +++ b/public/kcl-samples/mounting-plate/main.kcl @@ -14,7 +14,7 @@ centerHoleDiameter = 2 // Create a function that defines the body width and length of the mounting plate. Tag the corners so they can be passed through the fillet function. fn rectShape(pos, w, l) { rr = startSketchOn(XY) - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge1) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge2) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge3) diff --git a/public/kcl-samples/multi-axis-robot/robot-arm-base.kcl b/public/kcl-samples/multi-axis-robot/robot-arm-base.kcl index fe598370e..586ceafbd 100644 --- a/public/kcl-samples/multi-axis-robot/robot-arm-base.kcl +++ b/public/kcl-samples/multi-axis-robot/robot-arm-base.kcl @@ -8,7 +8,7 @@ import basePlateRadius, basePlateThickness, baseChamfer, baseHeight from "global // Base Plate sketch001 = startSketchOn(XY) - |> startProfileAt([-basePlateRadius, -basePlateRadius], %) + |> startProfile(at = [-basePlateRadius, -basePlateRadius]) |> angledLine(angle = 0, length = 2 * basePlateRadius, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 2 * basePlateRadius, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) diff --git a/public/kcl-samples/multi-axis-robot/robot-arm-j2.kcl b/public/kcl-samples/multi-axis-robot/robot-arm-j2.kcl index 71efa8bfa..0efb54d09 100644 --- a/public/kcl-samples/multi-axis-robot/robot-arm-j2.kcl +++ b/public/kcl-samples/multi-axis-robot/robot-arm-j2.kcl @@ -7,10 +7,10 @@ import axisJ1, axisJ2, axisJ2ArmWidth, axisJ2ArmLength, axisJ2ArmThickness, plan // Create Body of J2 Robot Arm sketch011 = startSketchOn(plane003) - |> startProfileAt([ + |> startProfile(at = [ 1.75 - (axisJ2ArmWidth / 2 * sin(toRadians(axisJ2))), 8 + axisJ2ArmWidth / 2 * cos(toRadians(axisJ2)) - ], %) + ]) |> arc(angleStart = 90 + axisJ2, angleEnd = 270 + axisJ2, radius = axisJ2ArmWidth / 2) |> angledLine(angle = axisJ2, length = axisJ2ArmLength) |> arc(angleStart = -90 + axisJ2, angleEnd = 90 + axisJ2, radius = axisJ2ArmWidth / 2) diff --git a/public/kcl-samples/multi-axis-robot/robot-arm-j3.kcl b/public/kcl-samples/multi-axis-robot/robot-arm-j3.kcl index eb9b480a3..d8c01137e 100644 --- a/public/kcl-samples/multi-axis-robot/robot-arm-j3.kcl +++ b/public/kcl-samples/multi-axis-robot/robot-arm-j3.kcl @@ -7,10 +7,10 @@ import plane002, axisJ2, axisJ3C, axisJ4, axisJ2ArmLength, axisJ3CArmLength, axi // Create Body of J3 Robot Arm sketch017 = startSketchOn(plane002) - |> startProfileAt([ + |> startProfile(at = [ 1.75 + axisJ2ArmLength * cos(toRadians(axisJ2)) - (axisJ3CArmWidth / 2 * sin(toRadians(axisJ3C))), 8 + axisJ2ArmLength * sin(toRadians(axisJ2)) + axisJ3CArmWidth / 2 * cos(toRadians(axisJ3C)) - ], %) + ]) |> arc(angleStart = 90 + axisJ3C, angleEnd = 270 + axisJ3C, radius = axisJ3CArmWidth / 2) |> angledLine(angle = axisJ3C, length = axisJ3CArmLength) |> arc(angleStart = 270 + axisJ3C, angleEnd = 90 + axisJ3C, radius = axisJ3CArmWidth / 2) @@ -84,10 +84,10 @@ extrude022 = extrude(sketch022, length = -0.01) // Build Upper Claw Finger sketch023 = startSketchOn(extrude022, face = START) - |> startProfileAt([ + |> startProfile(at = [ 1.75 + axisJ2ArmLength * cos(toRadians(axisJ2)) + axisJ3CArmLength * cos(toRadians(axisJ3C)), 8 + axisJ2ArmLength * sin(toRadians(axisJ2)) + axisJ3CArmLength * sin(toRadians(axisJ3C)) - ], %) + ]) |> angledLine(angle = axisJ3C + axisJ4 / 2, length = grabberLength / 4) |> arc(angleStart = 150 + axisJ3C + axisJ4 / 2, angleEnd = 30 + axisJ3C + axisJ4 / 2, radius = grabberLength / 3) |> angledLine(angle = axisJ3C + axisJ4 / 2, length = grabberLength / 6) @@ -101,10 +101,10 @@ extrude023 = extrude(sketch023, length = -1.5) // Build Lower Claw Finger sketch024 = startSketchOn(extrude022, face = START) - |> startProfileAt([ + |> startProfile(at = [ 1.75 + axisJ2ArmLength * cos(toRadians(axisJ2)) + axisJ3CArmLength * cos(toRadians(axisJ3C)), 8 + axisJ2ArmLength * sin(toRadians(axisJ2)) + axisJ3CArmLength * sin(toRadians(axisJ3C)) - ], %) + ]) |> angledLine(angle = axisJ3C - (axisJ4 / 2), length = grabberLength / 4) |> arc(angleStart = 210 + axisJ3C - (axisJ4 / 2), angleEnd = 330 + axisJ3C - (axisJ4 / 2), radius = grabberLength / 3) |> angledLine(angle = axisJ3C - (axisJ4 / 2), length = grabberLength / 6) diff --git a/public/kcl-samples/multi-axis-robot/robot-rotating-base.kcl b/public/kcl-samples/multi-axis-robot/robot-rotating-base.kcl index bafab7c21..85b05eeb9 100644 --- a/public/kcl-samples/multi-axis-robot/robot-rotating-base.kcl +++ b/public/kcl-samples/multi-axis-robot/robot-rotating-base.kcl @@ -13,7 +13,7 @@ extrude005 = extrude(sketch005, length = 1.5 - 0.1) |> appearance(color = "#4f7d54", metalness = 90, roughness = 90) sketch006 = startSketchOn(plane002) - |> startProfileAt([3.5, baseHeight], %) + |> startProfile(at = [3.5, baseHeight]) |> angledLine(angle = 60, length = 1.75) |> arc(angleStart = -30, angleEnd = -30 + 180, radius = 3) |> angledLine(angle = 60, endAbsoluteY = baseHeight) diff --git a/public/kcl-samples/parametric-bearing-pillow-block/main.kcl b/public/kcl-samples/parametric-bearing-pillow-block/main.kcl index 98effaabd..c0832d846 100644 --- a/public/kcl-samples/parametric-bearing-pillow-block/main.kcl +++ b/public/kcl-samples/parametric-bearing-pillow-block/main.kcl @@ -16,7 +16,7 @@ bearingDia = 3 // Sketch the block body body = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2]) |> line(endAbsolute = [width / 2, length / 2]) |> line(endAbsolute = [-width / 2, length / 2]) diff --git a/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl b/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl index 779e2dbf2..a2ce55de2 100644 --- a/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl +++ b/public/kcl-samples/pipe-flange-assembly/91251a404-bolt.kcl @@ -17,10 +17,10 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head and extrude into the head hexPatternSketch = startSketchOn(boltHead, face = START) - |> startProfileAt([ + |> startProfile(at = [ boltHexDrive / 2, boltHexFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = boltHexFlatLength) |> angledLine(angle = 210, length = boltHexFlatLength) |> angledLine(angle = 150, length = boltHexFlatLength) diff --git a/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl b/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl index 4e089d996..e5eaa16b3 100644 --- a/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl +++ b/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl @@ -11,10 +11,10 @@ import hexNutDiameter, hexNutFlatToFlat, hexNutThickness, hexNutFlatLength from export fn hexNut() { // Create the base of the hex nut hexNutBase = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ hexNutFlatToFlat / 2, hexNutFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = hexNutFlatLength) |> angledLine(angle = 210, length = hexNutFlatLength) |> angledLine(angle = 150, length = hexNutFlatLength) diff --git a/public/kcl-samples/poopy-shoe/main.kcl b/public/kcl-samples/poopy-shoe/main.kcl index 2159e7aaa..5c2686775 100644 --- a/public/kcl-samples/poopy-shoe/main.kcl +++ b/public/kcl-samples/poopy-shoe/main.kcl @@ -15,7 +15,7 @@ frontLength = 7 // Create the curved portion that catches the printer poop sketch001 = startSketchOn(-YZ) - |> startProfileAt([wallsWidth / 2, 0], %) + |> startProfile(at = [wallsWidth / 2, 0]) |> xLine(length = wallThickness / 2) |> angledLine(angle = 60, endAbsoluteX = wallsWidth, tag = $seg01) |> yLine(endAbsolute = height) @@ -39,7 +39,7 @@ part001 = revolve( ) sketch002 = startSketchOn(-YZ) - |> startProfileAt([wallsWidth / 2, 0], %) + |> startProfile(at = [wallsWidth / 2, 0]) |> xLine(length = wallThickness / 2) |> angledLine(angle = 60, endAbsoluteX = wallsWidth, tag = $seg02) |> yLine(endAbsolute = height) @@ -65,7 +65,7 @@ customPlane = { yAxis = { x = 0, y = 0, z = 1 } } sketch003 = startSketchOn(customPlane) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> tangentialArc(angle = 60, radius = height) |> angledLine(angle = 60, endAbsoluteY = 0) |> close() @@ -73,7 +73,7 @@ sketch003 = startSketchOn(customPlane) // Create the right side wall of the tub sketch004 = startSketchOn(sketch002, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(endAbsolute = height) |> xLine(endAbsolute = wallThickness) |> yLine(endAbsolute = segEndY(seg01)) @@ -101,7 +101,7 @@ customPlane2 = { yAxis = { x = 0, y = 0, z = 1 } } sketch005 = startSketchOn(customPlane2) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(endAbsolute = height) |> xLine(endAbsolute = -wallsWidth) |> tangentialArc(endAbsolute = [ @@ -114,7 +114,7 @@ sketch005 = startSketchOn(customPlane2) |> extrude(length = wallThickness) sketch006 = startSketchOn(sketch005, face = seg03) - |> startProfileAt([0, -1 * (backLength - height)], %) + |> startProfile(at = [0, -1 * (backLength - height)]) |> xLine(endAbsolute = -exitHeight) |> yLine(length = -wallsWidth) |> xLine(endAbsolute = 0) @@ -122,7 +122,7 @@ sketch006 = startSketchOn(sketch005, face = seg03) |> extrude(length = wallThickness) sketch007 = startSketchOn(sketch004, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(endAbsolute = wallThickness) |> yLine(endAbsolute = height) |> xLine(endAbsolute = 0) @@ -140,7 +140,7 @@ customPlane3 = { } sketch008 = startSketchOn(customPlane3) - |> startProfileAt([wallThickness, wallThickness], %) + |> startProfile(at = [wallThickness, wallThickness]) |> xLine(endAbsolute = frontLength) |> yLine(length = wallsWidth - (2 * wallThickness)) |> xLine(endAbsolute = wallThickness) diff --git a/public/kcl-samples/router-template-cross-bar/main.kcl b/public/kcl-samples/router-template-cross-bar/main.kcl index 3abce3de3..c3710f647 100644 --- a/public/kcl-samples/router-template-cross-bar/main.kcl +++ b/public/kcl-samples/router-template-cross-bar/main.kcl @@ -19,7 +19,7 @@ distanceToInsideEdge = slateWidthHalf + templateThickness + templateGap // Create the first sketch sketch001 = startSketchOn(XZ) - |> startProfileAt([0, depth + templateGap], %) + |> startProfile(at = [0, depth + templateGap]) |> xLine(length = slateWidthHalf - radius, tag = $seg01) |> arc( angleStart = 90, @@ -52,7 +52,7 @@ extrude001 = extrude(sketch001, length = 5) // Create the second sketch sketch002 = startSketchOn(extrude001, face = START) - |> startProfileAt([distanceToInsideEdge, 0], %) + |> startProfile(at = [distanceToInsideEdge, 0]) |> angledLine(angle = 180, length = templateThickness, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) + 90, length = templateThickness, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC002) @@ -64,7 +64,7 @@ extrude002 = extrude(sketch002, length = 13) // Create the third sketch sketch003 = startSketchOn(extrude001, face = START) - |> startProfileAt([-distanceToInsideEdge, 0], %) + |> startProfile(at = [-distanceToInsideEdge, 0]) |> angledLine(angle = 0, length = templateThickness, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = templateThickness, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -76,7 +76,7 @@ extrude003 = extrude(sketch003, length = 13) // Create the fourth sketch sketch004 = startSketchOn(extrude002, face = END) - |> startProfileAt([-distanceToInsideEdge, 0], %) + |> startProfile(at = [-distanceToInsideEdge, 0]) |> angledLine(angle = 0, length = distanceToInsideEdge * 2, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = templateThickness, tag = $rectangleSegmentB003) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC003) diff --git a/public/kcl-samples/router-template-slate/main.kcl b/public/kcl-samples/router-template-slate/main.kcl index 06245aad3..0b3c2dc9f 100644 --- a/public/kcl-samples/router-template-slate/main.kcl +++ b/public/kcl-samples/router-template-slate/main.kcl @@ -20,7 +20,7 @@ length002 = depth + minClampingDistance // Create the first sketch sketch001 = startSketchOn(XZ) - |> startProfileAt([0, depth - templateGap], %) + |> startProfile(at = [0, depth - templateGap]) |> xLine(length = length001, tag = $seg01) |> arc(angleStart = 90, angleEnd = 0, radius = radius - templateGap) |> yLine(endAbsolute = -templateGap * 2 - (templateDiameter / 2), tag = $seg05) @@ -41,10 +41,10 @@ extrude001 = extrude(sketch001, length = 5) // Create the second sketch sketch002 = startSketchOn(extrude001, face = START) - |> startProfileAt([ + |> startProfile(at = [ -slateWidthHalf, -templateGap * 2 - (templateDiameter / 2) - ], %) + ]) |> xLine(length = -7, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = minClampingDistance, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -56,10 +56,10 @@ extrude002 = extrude(sketch002, length = 7.5) // Create the third sketch sketch003 = startSketchOn(extrude001, face = START) - |> startProfileAt([ + |> startProfile(at = [ slateWidthHalf, -templateGap * 2 - (templateDiameter / 2) - ], %) + ]) |> xLine(length = 7, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = minClampingDistance) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) diff --git a/public/kcl-samples/sheet-metal-bracket/main.kcl b/public/kcl-samples/sheet-metal-bracket/main.kcl index 367bf15e1..ee7862bf3 100644 --- a/public/kcl-samples/sheet-metal-bracket/main.kcl +++ b/public/kcl-samples/sheet-metal-bracket/main.kcl @@ -32,10 +32,10 @@ flangeExtrusion = if mountingBoltPatternY > componentBoltPatternY { // Draw the extrusion profile of the sheet metal bracket bracketProfile = startSketchOn(XZ) - |> startProfileAt([ + |> startProfile(at = [ -mountingBoltPatternX / 2 - overhang, 0 - ], %) + ]) |> xLine(length = flangeLength) |> tangentialArc(radius = exteriorBendRadius, angle = bendAngle) |> angledLine(angle = bendAngle, endAbsoluteY = hatHeight - thickness, tag = $seg01) diff --git a/public/kcl-samples/socket-head-cap-screw/main.kcl b/public/kcl-samples/socket-head-cap-screw/main.kcl index d805f844d..589a8f7d7 100644 --- a/public/kcl-samples/socket-head-cap-screw/main.kcl +++ b/public/kcl-samples/socket-head-cap-screw/main.kcl @@ -20,10 +20,10 @@ boltHead = startSketchOn(XZ) // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = START) - |> startProfileAt([ + |> startProfile(at = [ boltHexDrive / 2, boltHexFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = boltHexFlatLength) |> angledLine(angle = 210, length = boltHexFlatLength) |> angledLine(angle = 150, length = boltHexFlatLength) diff --git a/public/kcl-samples/walkie-talkie/antenna.kcl b/public/kcl-samples/walkie-talkie/antenna.kcl index f3d05e3b8..156af6168 100644 --- a/public/kcl-samples/walkie-talkie/antenna.kcl +++ b/public/kcl-samples/walkie-talkie/antenna.kcl @@ -9,7 +9,7 @@ import antennaLength, antennaBaseWidth, antennaBaseHeight, antennaTopWidth, ante // Create the antenna base sketch antennaBaseSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [antennaBaseWidth, 0]) |> line(end = [0, -antennaBaseHeight]) |> line(end = [-antennaBaseWidth, 0]) @@ -18,10 +18,10 @@ antennaBaseSketch = startSketchOn(XY) // Create the antenna top sketch loftPlane = offsetPlane(XY, offset = antennaLength) antennaTopSketch = startSketchOn(loftPlane) - |> startProfileAt([ + |> startProfile(at = [ (antennaBaseWidth - antennaTopWidth) / 2, (antennaBaseHeight - antennaTopHeight) / 2 - ], %) + ]) |> xLine(length = antennaTopWidth) |> yLine(length = -antennaTopHeight) |> xLine(length = -antennaTopWidth) diff --git a/public/kcl-samples/walkie-talkie/body.kcl b/public/kcl-samples/walkie-talkie/body.kcl index c598904c1..e04527626 100644 --- a/public/kcl-samples/walkie-talkie/body.kcl +++ b/public/kcl-samples/walkie-talkie/body.kcl @@ -9,7 +9,7 @@ import height, width, thickness, chamferLength, offset, screenWidth, screenHeigh // Sketch and extrude the body of the walkie talkie body = startSketchOn(XZ) - |> startProfileAt([-width / 2, height / 2], %) + |> startProfile(at = [-width / 2, height / 2]) |> xLine(length = width, tag = $chamfer1) |> yLine(length = -height, tag = $chamfer2) |> xLine(length = -width, tag = $chamfer3) @@ -27,10 +27,10 @@ body = startSketchOn(XZ) // Cut out the indentation for the case caseIndentSketch = startSketchOn(body, face = END) - |> startProfileAt([ + |> startProfile(at = [ -width / 2 + offset, height / 2 - (chamferLength + offset / 2 * cos(toRadians(45))) - ], %) + ]) |> angledLine(angle = 45, endAbsoluteY = height / 2 - offset) |> line(endAbsolute = [ width / 2 - (chamferLength + offset / 2 * cos(toRadians(45))), @@ -52,7 +52,7 @@ extrude002 = extrude(caseIndentSketch, length = -0.0625) // Create the pocket for the screen screenCutout = startSketchOn(extrude002, face = START) - |> startProfileAt([-screenWidth / 2, screenYPosition], %) + |> startProfile(at = [-screenWidth / 2, screenYPosition]) |> xLine(length = screenWidth, tag = $seg01) |> yLine(length = -screenHeight) |> xLine(length = -segLen(seg01)) @@ -62,7 +62,7 @@ extrude003 = extrude(screenCutout, length = screenDepth) // Create the speaker box speakerBox = startSketchOn(extrude002, face = START) - |> startProfileAt([-1.25 / 2, -.125], %) + |> startProfile(at = [-1.25 / 2, -.125]) |> xLine(length = speakerBoxWidth) |> yLine(length = -speakerBoxHeight) |> xLine(length = -speakerBoxWidth) diff --git a/public/kcl-samples/walkie-talkie/button.kcl b/public/kcl-samples/walkie-talkie/button.kcl index c266c4525..947d6b581 100644 --- a/public/kcl-samples/walkie-talkie/button.kcl +++ b/public/kcl-samples/walkie-talkie/button.kcl @@ -13,7 +13,7 @@ import buttonWidth, buttonHeight, buttonThickness from "parameters.kcl" export fn button() { // Sketch the button profile and extrude buttonSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 180, length = buttonWidth, tag = $tag1) |> angledLine(angle = 270, length = buttonHeight, tag = $tag2) |> angledLine(angle = 0, length = buttonWidth) diff --git a/public/kcl-samples/walkie-talkie/case.kcl b/public/kcl-samples/walkie-talkie/case.kcl index 488f66783..fa727315f 100644 --- a/public/kcl-samples/walkie-talkie/case.kcl +++ b/public/kcl-samples/walkie-talkie/case.kcl @@ -10,7 +10,7 @@ import zLogo, oLogo, oLogo2 from "zoo-logo.kcl" // Sketch the profile of the screen screenSketch = startSketchOn(XZ) - |> startProfileAt([-screenWidth / 2, screenYPosition], %) + |> startProfile(at = [-screenWidth / 2, screenYPosition]) |> xLine(length = screenWidth) |> yLine(length = -screenHeight) |> xLine(length = -screenWidth) @@ -27,7 +27,7 @@ fn transformY(i) { // Sketch the square hole grid pattern squareHolePatternSketch = startSketchOn(XZ) - |> startProfileAt([-screenWidth / 2 + .100, 0], %) + |> startProfile(at = [-screenWidth / 2 + .100, 0]) |> line(end = [squareHoleSideLength / 2, 0]) |> line(end = [0, -squareHoleSideLength / 2]) |> line(end = [-squareHoleSideLength / 2, 0]) @@ -37,10 +37,10 @@ squareHolePatternSketch = startSketchOn(XZ) // Sketch the outer profile of the case and extrude with holes using the previously made profiles case = startSketchOn(XZ) - |> startProfileAt([ + |> startProfile(at = [ -width / 2 + offset + caseTolerance, height / 2 - (chamferLength + (offset + caseTolerance) / 2 * cos(toRadians(45))) - ], %) + ]) |> angledLine(angle = 45, endAbsoluteY = height / 2 - (offset + caseTolerance)) |> line(endAbsolute = [ width / 2 - (chamferLength + (offset + caseTolerance) / 2 * cos(toRadians(45))), diff --git a/public/kcl-samples/walkie-talkie/knob.kcl b/public/kcl-samples/walkie-talkie/knob.kcl index 735b6c219..4aa463785 100644 --- a/public/kcl-samples/walkie-talkie/knob.kcl +++ b/public/kcl-samples/walkie-talkie/knob.kcl @@ -9,7 +9,7 @@ import width, thickness, height, knobDiameter, knobHeight, knobRadius from "para // Create the knob sketch and revolve startSketchOn(XZ) - |> startProfileAt([0.0001, 0], %) + |> startProfile(at = [0.0001, 0]) |> xLine(length = knobDiameter / 2) |> yLine(length = knobHeight - 0.05) |> arc(angleStart = 0, angleEnd = 90, radius = .05) diff --git a/public/kcl-samples/walkie-talkie/talk-button.kcl b/public/kcl-samples/walkie-talkie/talk-button.kcl index 9b5828568..6fd131ecf 100644 --- a/public/kcl-samples/walkie-talkie/talk-button.kcl +++ b/public/kcl-samples/walkie-talkie/talk-button.kcl @@ -8,10 +8,10 @@ import width, thickness, talkButtonSideLength, talkButtonHeight from "parameters // Create the talk button sketch talkButtonSketch = startSketchOn(YZ) - |> startProfileAt([ + |> startProfile(at = [ -talkButtonSideLength / 2, talkButtonSideLength / 2 - ], %) + ]) |> xLine(length = talkButtonSideLength, tag = $tag1) |> yLine(length = -talkButtonSideLength, tag = $tag2) |> xLine(length = -talkButtonSideLength, tag = $tag3) diff --git a/public/kcl-samples/walkie-talkie/zoo-logo.kcl b/public/kcl-samples/walkie-talkie/zoo-logo.kcl index 794eaf6d7..26100f0dd 100644 --- a/public/kcl-samples/walkie-talkie/zoo-logo.kcl +++ b/public/kcl-samples/walkie-talkie/zoo-logo.kcl @@ -3,10 +3,10 @@ // define a function to draw the ZOO "Z" export fn zLogo(surface, origin, scale) { zSketch = surface - |> startProfileAt([ + |> startProfile(at = [ 0 + origin[0], 0.15 * scale + origin[1] - ], %) + ]) |> yLine(length = -0.15 * scale) |> xLine(length = 0.15 * scale) |> angledLine(angle = 47.15, endAbsoluteX = 0.3 * scale + origin[0], tag = $seg1) @@ -29,10 +29,10 @@ export fn zLogo(surface, origin, scale) { // define a function to draw the ZOO "O" export fn oLogo(surface, origin, scale) { oSketch001 = surface - |> startProfileAt([ + |> startProfile(at = [ .788 * scale + origin[0], .921 * scale + origin[1] - ], %) + ]) |> arc(angleStart = 47.15 + 6, angleEnd = 47.15 - 6 + 180, radius = .525 * scale) |> angledLine(angle = 47.15, length = .24 * scale) |> arc(angleStart = 47.15 - 11 + 180, angleEnd = 47.15 + 11, radius = .288 * scale) @@ -42,10 +42,10 @@ export fn oLogo(surface, origin, scale) { export fn oLogo2(surface, origin, scale) { oSketch002 = surface - |> startProfileAt([ + |> startProfile(at = [ .16 * scale + origin[0], .079 * scale + origin[1] - ], %) + ]) |> arc(angleStart = 47.15 + 6 - 180, angleEnd = 47.15 - 6, radius = .525 * scale) |> angledLine(angle = 47.15, length = -.24 * scale) |> arc(angleStart = 47.15 - 11, angleEnd = 47.15 + 11 - 180, radius = .288 * scale) diff --git a/rust/kcl-lib/common.kcl b/rust/kcl-lib/common.kcl index 97b9cbb09..790e3d3fd 100644 --- a/rust/kcl-lib/common.kcl +++ b/rust/kcl-lib/common.kcl @@ -12,7 +12,7 @@ export fn buildSketch = (plane, offset) => { w = width() h = height() return startSketchOn(plane) - |> startProfileAt(offset, %) + |> startProfile(at = offset) |> line(end = [w, 0]) |> line(end = [0, h]) |> line(end = [-w, 0]) diff --git a/rust/kcl-lib/e2e/executor/cache.rs b/rust/kcl-lib/e2e/executor/cache.rs index 4263e9e26..dd893e9e5 100644 --- a/rust/kcl-lib/e2e/executor/cache.rs +++ b/rust/kcl-lib/e2e/executor/cache.rs @@ -79,7 +79,7 @@ async fn cache_test( #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cache_change_grid_visualizes_grid_off_to_on() { let code = r#"part001 = startSketchOn('XY') - |> startProfileAt([5.5229, 5.25217], %) + |> startProfile(at = [5.5229, 5.25217]) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) |> line(end = [-1.02877, -6.76825]) @@ -120,7 +120,7 @@ async fn kcl_test_cache_change_grid_visualizes_grid_off_to_on() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cache_change_grid_visualizes_grid_on_to_off() { let code = r#"part001 = startSketchOn('XY') - |> startProfileAt([5.5229, 5.25217], %) + |> startProfile(at = [5.5229, 5.25217]) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) |> line(end = [-1.02877, -6.76825]) @@ -161,7 +161,7 @@ async fn kcl_test_cache_change_grid_visualizes_grid_on_to_off() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cache_change_highlight_edges_changes_visual() { let code = r#"part001 = startSketchOn('XY') - |> startProfileAt([5.5229, 5.25217], %) + |> startProfile(at = [5.5229, 5.25217]) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) |> line(end = [-1.02877, -6.76825]) @@ -206,7 +206,7 @@ async fn kcl_test_cache_multi_file_same_code_dont_reexecute() { importedCube sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-134.53, -56.17], sketch001) +profile001 = startProfile(sketch001, at = [-134.53, -56.17]) |> angledLine(angle = 0, length = 79.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 76.28) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $seg01) @@ -220,7 +220,7 @@ sketch002 = startSketchOn(extrude001, face = seg01) let other_file = ( std::path::PathBuf::from("toBeImported.kcl"), r#"sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([281.54, 305.81], sketch001) +profile001 = startProfile(sketch001, at = [281.54, 305.81]) |> angledLine(angle = 0, length = 123.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 85.99) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -254,7 +254,7 @@ extrude(profile001, length = 100)"# #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cache_add_line_preserves_artifact_commands() { let code = r#"sketch001 = startSketchOn('XY') - |> startProfileAt([5.5229, 5.25217], %) + |> startProfile(at = [5.5229, 5.25217]) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) |> line(end = [-1.02877, -6.76825]) @@ -375,7 +375,7 @@ async fn kcl_test_cache_multi_file_after_empty_with_export() { importedCube sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-134.53, -56.17], sketch001) +profile001 = startProfile(sketch001, at = [-134.53, -56.17]) |> angledLine(angle = 0, length = 79.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 76.28) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $seg01) @@ -389,7 +389,7 @@ sketch002 = startSketchOn(extrude001, face = seg01) let other_file = ( std::path::PathBuf::from("toBeImported.kcl"), r#"sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([281.54, 305.81], sketch001) +profile001 = startProfile(sketch001, at = [281.54, 305.81]) |> angledLine(angle = 0, length = 123.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 85.99) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -428,7 +428,7 @@ async fn kcl_test_cache_multi_file_after_empty_with_woo() { importedCube sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-134.53, -56.17], sketch001) +profile001 = startProfile(sketch001, at = [-134.53, -56.17]) |> angledLine(angle = 0, length = 79.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 76.28) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $seg01) @@ -442,7 +442,7 @@ sketch002 = startSketchOn(extrude001, face = seg01) let other_file = ( std::path::PathBuf::from("toBeImported.kcl"), r#"sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([281.54, 305.81], sketch001) +profile001 = startProfile(sketch001, at = [281.54, 305.81]) |> angledLine(angle = 0, length = 123.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 85.99) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) diff --git a/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl b/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl index 9bc5044f0..d08a8ea3c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([4.83, 12.56], %) + |> startProfile(at = [4.83, 12.56]) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) diff --git a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_close_opposite.kcl b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_close_opposite.kcl index da85cb418..0c1ba260f 100644 --- a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_close_opposite.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_close_opposite.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_end.kcl b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_end.kcl index 431759464..bcac6a104 100644 --- a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_end.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_end.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_next_adjacent.kcl b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_next_adjacent.kcl index 7a4309eef..3d8d5f8f6 100644 --- a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_next_adjacent.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_next_adjacent.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_previous_adjacent.kcl b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_previous_adjacent.kcl index eeeb9adea..74bfb3f48 100644 --- a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_previous_adjacent.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_previous_adjacent.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_start.kcl b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_start.kcl index 7212d7fed..6e2813dc9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_start.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/basic_fillet_cube_start.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_x.kcl b/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_x.kcl new file mode 100644 index 000000000..44af27c9b --- /dev/null +++ b/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_x.kcl @@ -0,0 +1,9 @@ +const part001 = startSketchOn(XY) + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angled( + angle = -angleToMatchLengthX(seg01, 3, %), + endAbsoluteX = 3, + ) + |> close() + |> extrude(length = 10) diff --git a/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_y.kcl b/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_y.kcl new file mode 100644 index 000000000..00691a8fe --- /dev/null +++ b/rust/kcl-lib/e2e/executor/inputs/big_number_angle_to_match_length_y.kcl @@ -0,0 +1,9 @@ +const part001 = startSketchOn(XY) + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angledLine( + angle = -angleToMatchLengthY(seg01, 3, %), + endAbsoluteX = 3, + ) + |> close() + |> extrude(length = 10) diff --git a/rust/kcl-lib/e2e/executor/inputs/boolean-setup-with-sketch-on-faces.kcl b/rust/kcl-lib/e2e/executor/inputs/boolean-setup-with-sketch-on-faces.kcl index 95dd01cb3..2d1e414a4 100644 --- a/rust/kcl-lib/e2e/executor/inputs/boolean-setup-with-sketch-on-faces.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/boolean-setup-with-sketch-on-faces.kcl @@ -4,7 +4,7 @@ sketch001 = startSketchOn(XZ) profile001 = circle(sketch001, center = [154.36, 113.92], radius = 41.09) extrude001 = extrude(profile001, length = 200) sketch002 = startSketchOn(XY) -profile002 = startProfileAt([72.24, -52.05], sketch002) +profile002 = startProfile(sketch002, at = [72.24, -52.05]) |> angledLine(angle = 0, length = 181.26, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 21.54) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $mySeg) @@ -19,7 +19,7 @@ extrude002 = extrude(profile002, length = 150) ) sketch003 = startSketchOn(extrude002, face = mySeg) -profile003 = startProfileAt([207.36, 126.19], sketch003) +profile003 = startProfile(sketch003, at = [207.36, 126.19]) |> angledLine(angle = 0, length = 33.57, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 99.11) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $seg01) @@ -27,7 +27,7 @@ profile003 = startProfileAt([207.36, 126.19], sketch003) |> close() extrude003 = extrude(profile003, length = -20) sketch004 = startSketchOn(extrude003, face = seg01) -profile004 = startProfileAt([-235.38, 66.16], sketch004) +profile004 = startProfile(sketch004, at = [-235.38, 66.16]) |> angledLine(angle = 0, length = 24.21, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 3.72) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003)) @@ -36,7 +36,7 @@ profile004 = startProfileAt([-235.38, 66.16], sketch004) extrude004 = extrude(profile004, length = 30) sketch005 = startSketchOn(extrude002, face = seg02) -profile005 = startProfileAt([-129.93, -59.19], sketch005) +profile005 = startProfile(sketch005, at = [-129.93, -59.19]) |> xLine(length = 48.79) |> line(end = [1.33, 11.03]) |> xLine(length = -60.56, tag = $seg03) @@ -44,7 +44,7 @@ profile005 = startProfileAt([-129.93, -59.19], sketch005) |> close() extrude005 = extrude(profile005, length = -10) sketch006 = startSketchOn(extrude005, face = seg03) -profile006 = startProfileAt([-95.86, 38.73], sketch006) +profile006 = startProfile(sketch006, at = [-95.86, 38.73]) |> angledLine(angle = 0, length = 3.48, tag = $rectangleSegmentA004) |> angledLine(angle = segAng(rectangleSegmentA004) - 90, length = 3.36) |> angledLine(angle = segAng(rectangleSegmentA004), length = -segLen(rectangleSegmentA004)) diff --git a/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl b/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl index 883fa21da..9b864ecbc 100644 --- a/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl @@ -21,7 +21,7 @@ const filletR = 0.25 // Sketch the bracket and extrude with fillets const bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL], tag = 'outerEdge') |> line(end = [-shelfMountL, 0]) |> line(end = [0, -thickness]) diff --git a/rust/kcl-lib/e2e/executor/inputs/circular_pattern3d_a_pattern.kcl b/rust/kcl-lib/e2e/executor/inputs/circular_pattern3d_a_pattern.kcl index 20e085499..98971e966 100644 --- a/rust/kcl-lib/e2e/executor/inputs/circular_pattern3d_a_pattern.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/circular_pattern3d_a_pattern.kcl @@ -1,5 +1,5 @@ exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl b/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl index 890d634df..4ee4c26de 100644 --- a/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl @@ -3,7 +3,7 @@ const radius = 40 const height = 3 const body = startSketchOn(XY) - |> startProfileAt([center[0]+radius, center[1]], %) + |> startProfile(at = [center[0]+radius, center[1]]) |> arc(angleEnd = 360, angleStart = 0, radius = radius) |> close() |> extrude(length = height) diff --git a/rust/kcl-lib/e2e/executor/inputs/cube.kcl b/rust/kcl-lib/e2e/executor/inputs/cube.kcl index 6d337428f..236ccb38f 100644 --- a/rust/kcl-lib/e2e/executor/inputs/cube.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/cube.kcl @@ -8,7 +8,7 @@ fn cube(length, center) { p3 = [ l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl b/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl index fed26eb9e..f34831ea9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) 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 63e7b1006..cd013a5fc 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,6 +1,6 @@ @settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) + |> startProfile(at = [75.8, 317.2]) |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $yo) 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 440f88be7..768bf9932 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,6 +1,6 @@ @settings(defaultLengthUnit = in) sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $yo) diff --git a/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl b/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl index c676cf80e..3f1db2b35 100644 --- a/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl @@ -1,6 +1,6 @@ // create a sketch with name sketch000 const sketch000 = startSketchOn(XY) - |> startProfileAt([0.0, 0.0], %) + |> startProfile(at = [0.0, 0.0]) |> line(end = [1.0, 1.0], tag = $line000) |> line(end = [0.0, -1.0], tag = $line001) |> line(end = [-1.0, 0.0], tag = $line002) @@ -18,7 +18,7 @@ const plane005 = { // create a sketch with name sketch001 const sketch001 = startSketchOn(plane005) - |> startProfileAt([0.100000, 0.250000], %) + |> startProfile(at = [0.100000, 0.250000]) |> line(end = [0.075545, 0.494260], tag = $line003) |> line(end = [0.741390, -0.113317], tag = $line004) |> line(end = [-0.816935, -0.380943], tag = $line005) diff --git a/rust/kcl-lib/e2e/executor/inputs/extrude-inside-fn-with-tags.kcl b/rust/kcl-lib/e2e/executor/inputs/extrude-inside-fn-with-tags.kcl index 754c3076f..4a68c366a 100644 --- a/rust/kcl-lib/e2e/executor/inputs/extrude-inside-fn-with-tags.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/extrude-inside-fn-with-tags.kcl @@ -16,7 +16,7 @@ const tabThk = 4 // define a rectangular shape func fn rectShape = (pos, w, l) => { const rr = startSketchOn(XY) - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge01) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge02) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge03) @@ -35,7 +35,7 @@ const bracketPlane = { // build the bracket sketch around the body fn bracketSketch = (w, d, t) => { const s = startSketchOn(bracketPlane) - |> startProfileAt([-w / 2 - t, d + t], %) + |> startProfile(at = [-w / 2 - t, d + t]) |> line(endAbsolute = [-w / 2 - t, -t], tag = $edge1) |> line(endAbsolute = [w / 2 + t, -t], tag = $edge2) |> line(endAbsolute = [w / 2 + t, d + t], tag = $edge3) @@ -64,7 +64,7 @@ const bracketBody = bs // sketch on the face const retBack = startSketchOn(bs, face = bs.sketch.tags.edge4) - |> startProfileAt([length / 2 + thk, 0], %) + |> startProfile(at = [length / 2 + thk, 0]) |> line(end = [0, thk]) |> line(end = [-thk, 0]) |> line(end = [0, -thk]) diff --git a/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl b/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl index 7cd53de80..d91defe0d 100644 --- a/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl @@ -23,10 +23,7 @@ microUsbWidth = 7.4 connectorPadding = 4 miniHdmiHole = startSketchOn(XY) - |> startProfileAt([ - 0, - border + miniHdmiDistance - (miniHdmiWidth / 2) - ], %) + |> startProfile(at = [0, border + miniHdmiDistance - (miniHdmiWidth / 2)]) |> lineTo([ 0, border + miniHdmiDistance + miniHdmiWidth / 2 @@ -42,7 +39,7 @@ miniHdmiHole = startSketchOn(XY) |> close() case = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [caseWidth, 0], $edge1) |> line(endAbsolute = [caseWidth, caseLength], $edge2) |> line(endAbsolute = [0, caseLength], $edge3) @@ -61,7 +58,7 @@ case = startSketchOn(XY) fn m25Screw = (x, y, height) => { screw = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle(center= [x, y], radius=2.5) |> hole(circle(center= [x, y], radius = 1.25), %) |> extrude(length = height) diff --git a/rust/kcl-lib/e2e/executor/inputs/fillet_duplicate_tags.kcl b/rust/kcl-lib/e2e/executor/inputs/fillet_duplicate_tags.kcl index a33d3a5f1..a58a90b9b 100644 --- a/rust/kcl-lib/e2e/executor/inputs/fillet_duplicate_tags.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/fillet_duplicate_tags.kcl @@ -1,4 +1,4 @@ -startProfileAt([0, 0], startSketchOn("XY")) +startProfile(startSketchOn("XY"), at = [0, 0]) |> xLine(length = 10, tag = $line000) |> yLine(length = 10, tag = $line001) |> xLine(endAbsolute = profileStartX(%), tag = $line002) diff --git a/rust/kcl-lib/e2e/executor/inputs/focusrite_scarlett_mounting_braket.kcl b/rust/kcl-lib/e2e/executor/inputs/focusrite_scarlett_mounting_braket.kcl index 4ec89b27e..d2f0be6d9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/focusrite_scarlett_mounting_braket.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/focusrite_scarlett_mounting_braket.kcl @@ -16,7 +16,7 @@ const tabThk = 4 // define a rectangular shape func fn rectShape = (pos, w, l) => { const rr = startSketchOn('xy') - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge01) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge02) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge03) @@ -35,7 +35,7 @@ const bracketPlane = { // build the bracket sketch around the body fn bracketSketch = (w, d, t) => { const s = startSketchOn(bracketPlane) - |> startProfileAt([-w / 2 - t, d + t], %) + |> startProfile(at = [-w / 2 - t, d + t]) |> line(endAbsolute = [-w / 2 - t, -t], tag = $edge1) |> line(endAbsolute = [w / 2 + t, -t], tag = $edge2) |> line(endAbsolute = [w / 2 + t, d + t], tag = $edge3) @@ -71,7 +71,7 @@ const tabPlane = { // build the tabs of the mounting bracket (right side) const tabsR = startSketchOn(tabPlane) - |> startProfileAt([width / 2 + thk, length / 2 + thk], %) + |> startProfile(at = [width / 2 + thk, length / 2 + thk]) |> line(end = [tabWidth, -tabLength / 3], tag = $edge11) |> line(end = [0, -tabLength / 3 * 2], tag = $edge12) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge13) @@ -99,7 +99,7 @@ const tabsR = startSketchOn(tabPlane) // build the tabs of the mounting bracket (left side) const tabsL = startSketchOn(tabPlane) - |> startProfileAt([-width / 2 - thk, length / 2 + thk], %) + |> startProfile(at = [-width / 2 - thk, length / 2 + thk]) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge21) |> line(end = [0, -tabLength / 3 * 2], tag = $edge22) |> line(end = [tabWidth, -tabLength / 3], tag = $edge23) @@ -135,7 +135,7 @@ const retPlane = { // build the retention bump in the front const retFront = startSketchOn(retPlane) - |> startProfileAt([-length / 2 - thk, 0], %) + |> startProfile(at = [-length / 2 - thk, 0]) |> line(end = [0, thk]) |> line(end = [thk, -thk]) |> close() @@ -143,7 +143,7 @@ const retFront = startSketchOn(retPlane) // build the retention bump in the back const retBack = startSketchOn(retPlane) - |> startProfileAt([length / 2 + thk, 0], %) + |> startProfile(at = [length / 2 + thk, 0]) |> line(end = [0, thk]) |> line(end = [-thk, 0]) |> line(end = [0, -thk]) diff --git a/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl b/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl index 01b9e0eac..4e43edb25 100644 --- a/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl @@ -1,6 +1,6 @@ fn box = (h, l, w) => { const myBox = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/e2e/executor/inputs/function_sketch_with_position.kcl b/rust/kcl-lib/e2e/executor/inputs/function_sketch_with_position.kcl index b54642210..8c6c17661 100644 --- a/rust/kcl-lib/e2e/executor/inputs/function_sketch_with_position.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/function_sketch_with_position.kcl @@ -1,6 +1,6 @@ fn box = (p, h, l, w) => { const myBox = startSketchOn(XY) - |> startProfileAt(p, %) + |> startProfile(at = p) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/e2e/executor/inputs/global-tags.kcl b/rust/kcl-lib/e2e/executor/inputs/global-tags.kcl index 25fa5dd51..f8a1c3fb0 100644 --- a/rust/kcl-lib/e2e/executor/inputs/global-tags.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/global-tags.kcl @@ -16,7 +16,7 @@ const tabThk = 4 // define a rectangular shape func fn rectShape = (pos, w, l) => { const rr = startSketchOn('xy') - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge01) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge02) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge03) @@ -35,7 +35,7 @@ const bracketPlane = { // build the bracket sketch around the body fn bracketSketch = (w, d, t) => { const s = startSketchOn(bracketPlane) - |> startProfileAt([-w / 2 - t, d + t], %) + |> startProfile(at = [-w / 2 - t, d + t]) |> line(endAbsolute = [-w / 2 - t, -t], tag = $edge1) |> line(endAbsolute = [w / 2 + t, -t], tag = $edge2) |> line(endAbsolute = [w / 2 + t, d + t], tag = $edge3) @@ -71,7 +71,7 @@ const tabPlane = { // build the tabs of the mounting bracket (right side) const tabsR = startSketchOn(tabPlane) - |> startProfileAt([width / 2 + thk, length / 2 + thk], %) + |> startProfile(at = [width / 2 + thk, length / 2 + thk]) |> line(end = [tabWidth, -tabLength / 3], tag = $edge11) |> line(end = [0, -tabLength / 3 * 2], tag = $edge12) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge13) @@ -99,7 +99,7 @@ const tabsR = startSketchOn(tabPlane) // build the tabs of the mounting bracket (left side) const tabsL = startSketchOn(tabPlane) - |> startProfileAt([-width / 2 - thk, length / 2 + thk], %) + |> startProfile(at = [-width / 2 - thk, length / 2 + thk]) |> line(end = [-tabWidth, -tabLength / 3], tag = $edge21) |> line(end = [0, -tabLength / 3 * 2], tag = $edge22) |> line(end = [tabWidth, -tabLength / 3], tag = $edge23) @@ -135,7 +135,7 @@ const retPlane = { // build the retention bump in the front const retFront = startSketchOn(retPlane) - |> startProfileAt([-length / 2 - thk, 0], %) + |> startProfile(at = [-length / 2 - thk, 0]) |> line(end = [0, thk]) |> line(end = [thk, -thk]) |> close() @@ -143,7 +143,7 @@ const retFront = startSketchOn(retPlane) // build the retention bump in the back const retBack = startSketchOn(retPlane) - |> startProfileAt([length / 2 + thk, 0], %) + |> startProfile(at = [length / 2 + thk, 0]) |> line(end = [0, thk]) |> line(end = [-thk, 0]) |> line(end = [0, -thk]) diff --git a/rust/kcl-lib/e2e/executor/inputs/i_shape.kcl b/rust/kcl-lib/e2e/executor/inputs/i_shape.kcl index 424df231e..092469446 100644 --- a/rust/kcl-lib/e2e/executor/inputs/i_shape.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/i_shape.kcl @@ -8,7 +8,7 @@ let corner_radius = 5.0 // but I measured intentionally to not be symmetric, // because your wrist isn't a perfect cylindrical surface let brace_base = startSketchOn(XY) - |> startProfileAt([corner_radius, 0], %) + |> startProfile(at = [corner_radius, 0]) |> line(end = [width - corner_radius, 0.0]) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - corner_radius) @@ -36,7 +36,7 @@ let brace_base = startSketchOn(XY) |> close() let inner = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 1.0) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - (corner_radius * 2)) diff --git a/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl b/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl index 431421f21..2f2443572 100644 --- a/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl @@ -1,5 +1,5 @@ const svg = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [2.52, -26.04]) // MoveAbsolute |> line(endAbsolute = [2.52, -25.2]) // VerticalLineAbsolute diff --git a/rust/kcl-lib/e2e/executor/inputs/lego.kcl b/rust/kcl-lib/e2e/executor/inputs/lego.kcl index ed2f021b7..299ead324 100644 --- a/rust/kcl-lib/e2e/executor/inputs/lego.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/lego.kcl @@ -20,7 +20,7 @@ const wSegments = total_width / (wbumps + 1) // make the base const s = startSketchOn(XY) - |> startProfileAt([-total_width / 2, -total_length / 2], %) + |> startProfile(at = [-total_width / 2, -total_length / 2]) |> line(end = [total_width, 0]) |> line(end = [0, total_length]) |> line(end = [-total_width, 0]) @@ -28,10 +28,7 @@ const s = startSketchOn(XY) |> extrude(length = height) const shellExtrude = startSketchOn(s, face = "start") - |> startProfileAt([ - -(total_width / 2 - t), - -(total_length / 2 - t) - ], %) + |> startProfile(at = [-(total_width / 2 - t), -(total_length / 2 - t)]) |> line(end = [total_width - (2 * t), 0]) |> line(end = [0, total_length - (2 * t)]) |> line(end = [-(total_width - (2 * t)), 0]) diff --git a/rust/kcl-lib/e2e/executor/inputs/linear_pattern3d_a_pattern.kcl b/rust/kcl-lib/e2e/executor/inputs/linear_pattern3d_a_pattern.kcl index 9103d13d6..6ce4d951d 100644 --- a/rust/kcl-lib/e2e/executor/inputs/linear_pattern3d_a_pattern.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/linear_pattern3d_a_pattern.kcl @@ -1,5 +1,5 @@ exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/e2e/executor/inputs/lsystem.kcl b/rust/kcl-lib/e2e/executor/inputs/lsystem.kcl index 06ba1986a..da1662393 100644 --- a/rust/kcl-lib/e2e/executor/inputs/lsystem.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/lsystem.kcl @@ -101,7 +101,7 @@ fn F = (state, F) => { fn LSystem = (args, axioms) => { myThing = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) return axioms({ depthMax: args.iterations, depth: 0, diff --git a/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl b/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl index 1a0291af9..586317b4c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl @@ -1,6 +1,6 @@ fn square = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl b/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl index 27bb6d9ba..913b510f0 100644 --- a/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl @@ -1,5 +1,5 @@ const part001 = startSketchOn(XY) - |> startProfileAt([0.0, 0.0], %) + |> startProfile(at = [0.0, 0.0]) |> line(end = [-0.3670208139314082, 0.21201331909674526]) |> line(end = [-0.4707511307971115, 0.4905279615419764]) |> line(end = [-0.8328324229085962, 0.4677492878818803]) diff --git a/rust/kcl-lib/e2e/executor/inputs/neg_xz_plane.kcl b/rust/kcl-lib/e2e/executor/inputs/neg_xz_plane.kcl index 0fe26b3a9..037537f37 100644 --- a/rust/kcl-lib/e2e/executor/inputs/neg_xz_plane.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/neg_xz_plane.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('-XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close() diff --git a/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl b/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl index 969064596..2bd250e63 100644 --- a/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl @@ -4,7 +4,7 @@ const length = 12 fn box = (sk1, sk2, scale) => { const boxSketch = startSketchOn(XY) - |> startProfileAt([sk1, sk2], %) + |> startProfile(at = [sk1, sk2]) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/e2e/executor/inputs/no_visuals/export_side_effect.kcl b/rust/kcl-lib/e2e/executor/inputs/no_visuals/export_side_effect.kcl index b76fe3cfe..12b5189c4 100644 --- a/rust/kcl-lib/e2e/executor/inputs/no_visuals/export_side_effect.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/no_visuals/export_side_effect.kcl @@ -2,4 +2,4 @@ export fn foo = () => { return 0 } // This interacts with the engine. part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) diff --git a/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-in-order.kcl b/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-in-order.kcl index 595db503e..16636573a 100644 --- a/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-in-order.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-in-order.kcl @@ -16,7 +16,7 @@ const plane94894440791888 = { // create a sketch with UID 94894440902176 const sketch94894440902176 = startSketchOn('-XZ') - |> startProfileAt([-0.005, -0.005], %) + |> startProfile(at = [-0.005, -0.005]) |> line(end = [0.01, 0.0], tag = $line94894439494384) |> line(end = [0.0, 0.01], tag = $line94894439429616) |> line(end = [-0.01, 0.0], tag = $line94894439638160) @@ -27,10 +27,7 @@ const extrude94894439487136 = extrude(sketch94894440902176, length = 0.01) // create a sketch with UID 94894439448464 const sketch94894439448464 = startSketchOn(plane94894440791888) - |> startProfileAt([ - 0.00074557205559017, - 0.00306415853984399 - ], %) + |> startProfile(at = [0.00074557205559017, 0.00306415853984399]) |> line(end = [0.004999999999999999, 0.0], tag = $line94894440230336) |> line(end = [0.0, -0.005], tag = $line94894439497168) |> line(end = [-0.004999999999999999, 0.0], tag = $line94894439496768) diff --git a/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-out-of-order.kcl b/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-out-of-order.kcl index f9d7286f6..120435495 100644 --- a/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-out-of-order.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/order-sketch-extrude-out-of-order.kcl @@ -16,7 +16,7 @@ const plane94894440791888 = { // create a sketch with UID 94894440902176 const sketch94894440902176 = startSketchOn('-XZ') - |> startProfileAt([-0.005, -0.005], %) + |> startProfile(at = [-0.005, -0.005]) |> line(end = [0.01, 0.0], tag = $line94894439494384) |> line(end = [0.0, 0.01], tag = $line94894439429616) |> line(end = [-0.01, 0.0], tag = $line94894439638160) @@ -24,10 +24,7 @@ const sketch94894440902176 = startSketchOn('-XZ') // create a sketch with UID 94894439448464 const sketch94894439448464 = startSketchOn(plane94894440791888) - |> startProfileAt([ - 0.00074557205559017, - 0.00306415853984399 - ], %) + |> startProfile(at = [0.00074557205559017, 0.00306415853984399]) |> line(end = [0.004999999999999999, 0.0], tag = $line94894440230336) |> line(end = [0.0, -0.005], tag = $line94894439497168) |> line(end = [-0.004999999999999999, 0.0], tag = $line94894439496768) diff --git a/rust/kcl-lib/e2e/executor/inputs/parametric.kcl b/rust/kcl-lib/e2e/executor/inputs/parametric.kcl index 8ea8f5908..477a4340c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/parametric.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/parametric.kcl @@ -8,7 +8,7 @@ const leg1 = 5 // inches const leg2 = 8 // inches const thickness = sqrt(distance * p * FOS * 6 / sigmaAllow / width) // inches const bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) diff --git a/rust/kcl-lib/e2e/executor/inputs/parametric_with_tan_arc.kcl b/rust/kcl-lib/e2e/executor/inputs/parametric_with_tan_arc.kcl index 6fe6d3359..b19fe6a6b 100644 --- a/rust/kcl-lib/e2e/executor/inputs/parametric_with_tan_arc.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/parametric_with_tan_arc.kcl @@ -9,7 +9,7 @@ const shelfMountL = 9 const wallMountL = 8 const bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL]) |> tangentialArc( radius = filletR, diff --git a/rust/kcl-lib/e2e/executor/inputs/pentagon_fillet_sugar.kcl b/rust/kcl-lib/e2e/executor/inputs/pentagon_fillet_sugar.kcl index bf8b5b3ba..598a1920f 100644 --- a/rust/kcl-lib/e2e/executor/inputs/pentagon_fillet_sugar.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/pentagon_fillet_sugar.kcl @@ -4,7 +4,7 @@ let radius = 80 let triangleLen = 500 const p = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = triangleLen, tag = $a) |> angledLine(angle = 180, length = triangleLen, tag = $b) |> angledLine(angle = 300, length = triangleLen, tag = $c) @@ -12,7 +12,7 @@ const p = startSketchOn(XY) fn circl = (x, face) => { return startSketchOn(p, face = face) - |> startProfileAt([x + radius, triangleHeight/2], %) + |> startProfile(at = [x + radius, triangleHeight/2]) |> arc( angleStart = 0, angleEnd = 360, diff --git a/rust/kcl-lib/e2e/executor/inputs/pipe_as_arg.kcl b/rust/kcl-lib/e2e/executor/inputs/pipe_as_arg.kcl index 88c7114f3..379ff7644 100644 --- a/rust/kcl-lib/e2e/executor/inputs/pipe_as_arg.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/pipe_as_arg.kcl @@ -8,7 +8,7 @@ fn cube = (length, center) => { let p3 = [ l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl b/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl index 7730c3f31..ae55268c9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl @@ -1,5 +1,5 @@ const svg = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [22.687663, -2.7664351]) // MoveRelative |> line(endAbsolute = [15.687664000000002, -5.7664351]) // MoveRelative diff --git a/rust/kcl-lib/e2e/executor/inputs/poop_chute.kcl b/rust/kcl-lib/e2e/executor/inputs/poop_chute.kcl new file mode 100644 index 000000000..57206423a --- /dev/null +++ b/rust/kcl-lib/e2e/executor/inputs/poop_chute.kcl @@ -0,0 +1,52 @@ +wall_thickness = 0.125 +back_walls_width = 2 +front_walls_width = 2.5 +height = 5.5 +filletRadius = 0.050 +back_length = 7 +exit_height = 1 +front_length = 6 +Fx = 0.5 +Fy = 0.5 + +sketch001 = startSketchOn('-YZ') + |> startProfile(at = [back_walls_width / 2, 0]) + |> xLine(length = wall_thickness / 2) + |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg01) + |> yLine(endAbsolute = height) + |> xLine(length = -wall_thickness) + |> yLine(endAbsolute = segEndY(seg01)) + |> angledLine(angle = 45, endAbsoluteX = back_walls_width / 2 + wall_thickness / 2) + |> xLine(length = -wall_thickness) + |> angledLine(angle = 180 - 45, endAbsoluteX = wall_thickness) + |> yLine(endAbsolute = height) + |> xLine(endAbsolute = 0) + |> yLine(endAbsolute = segEndY(seg01)) + |> angledLine(angle = 180 - 45, endAbsoluteY = 0) + |> close() +part001 = revolve({ + angle: 90, + axis: { + custom: { + axis: [1.0, 0.0], + origin: [0.0, height + .0000001] + } + } +}, sketch001) + +sketch002 = startSketchOn('-YZ') + |> startProfile(at = [back_walls_width / 2, 0]) + |> xLine(length = wall_thickness / 2) + |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg02) + |> yLine(endAbsolute = height) + |> xLine(length = -wall_thickness) + |> yLine(endAbsolute = segEndY(seg01)) + |> angledLine(angle = 45, endAbsoluteX = back_walls_width / 2 + wall_thickness / 2) + |> xLine(length = -wall_thickness) + |> angledLine(angle = 180 - 45, endAbsoluteX = wall_thickness) + |> yLine(endAbsolute = height) + |> xLine(endAbsolute = 0) + |> yLine(endAbsolute = segEndY(seg02)) + |> angledLine(angle = 180 - 45, endAbsoluteY = 0) + |> close() + |> extrude(length = back_length - height) \ No newline at end of file diff --git a/rust/kcl-lib/e2e/executor/inputs/riddle.kcl b/rust/kcl-lib/e2e/executor/inputs/riddle.kcl index 19480e19f..1530ed14c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/riddle.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/riddle.kcl @@ -7,7 +7,7 @@ fn p = (xs, ys) => { let ox = 35 - (m(xs) % 70) let oy = 35 - (m(ys) % 70) const r = startSketchOn(XZ) - |> startProfileAt([ox, oy], %) + |> startProfile(at = [ox, oy]) |> line(end = [1, 0]) |> line(end = [0, -1]) |> line(end = [-1, 0]) diff --git a/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl b/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl index 50e31c1ce..d9aa7b783 100644 --- a/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl @@ -9,7 +9,7 @@ let ys = 71816 let ox = 35 - (t(xs) % 70) let oy = 35 - (t(ys) % 70) const r = startSketchOn(XZ) - |> startProfileAt([ox, oy], %) + |> startProfile(at = [ox, oy]) |> line(end = [1, 0]) |> line(end = [0, -1]) |> line(end = [-1, 0]) diff --git a/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl b/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl index b08c8019b..ddc8af622 100644 --- a/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl @@ -10,7 +10,7 @@ const depth = 30 const length001 = slateWidthHalf - radius const length002 = depth + minClampingDistance const sketch001 = startSketchOn(XZ) - |> startProfileAt([0, depth - templateGap], %) + |> startProfile(at = [0, depth - templateGap]) |> xLine(length = length001, tag = $seg01) |> arc( angleEnd = 0, @@ -34,10 +34,7 @@ const sketch001 = startSketchOn(XZ) |> close() const extrude001 = extrude(sketch001, length = 5) const sketch002 = startSketchOn(extrude001, face = 'START') - |> startProfileAt([ - -slateWidthHalf, - -templateGap * 2 - (templateDiameter / 2) - ], %) + |> startProfile(at = [-slateWidthHalf, -templateGap * 2 - (templateDiameter / 2)]) |> xLine(length = -7, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001, %) + 90, length = minClampingDistance, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001, %), length = -segLen(rectangleSegmentA001, %), tag = $rectangleSegmentC001) @@ -45,10 +42,7 @@ const sketch002 = startSketchOn(extrude001, face = 'START') |> close() const extrude002 = extrude(sketch002, length = 7.5) const sketch003 = startSketchOn(extrude001, face = 'START') - |> startProfileAt([ - slateWidthHalf, - -templateGap * 2 - (templateDiameter / 2) - ], %) + |> startProfile(at = [slateWidthHalf, -templateGap * 2 - (templateDiameter / 2)]) |> xLine(length = 7, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002, %) - 90, length = minClampingDistance) |> angledLine(angle = segAng(rectangleSegmentA002, %), length = -segLen(rectangleSegmentA002, %)) diff --git a/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl b/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl index 8ee46e93a..4ffeb89bf 100644 --- a/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl @@ -1,6 +1,6 @@ fn rect = (origin) => { return startSketchOn(XZ) - |> startProfileAt(origin, %) + |> startProfile(at = origin) |> angledLine( angle = 0, length = 191.26, diff --git a/rust/kcl-lib/e2e/executor/inputs/server-rack-heavy.kcl b/rust/kcl-lib/e2e/executor/inputs/server-rack-heavy.kcl index b79a57e31..5b65e7ef1 100644 --- a/rust/kcl-lib/e2e/executor/inputs/server-rack-heavy.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/server-rack-heavy.kcl @@ -22,7 +22,7 @@ fn caster = (originStart) => { } const sketch001c = startSketchOn(plane001c) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 3.543) |> yLine(length = 3.543) |> xLine(length = -3.543) @@ -47,7 +47,7 @@ fn caster = (originStart) => { |> extrude(length = -.25) const sketch002c = startSketchOn(sketch001c, face = 'START') - |> startProfileAt([-originStart[0], 2.2 + originStart[1]], %) + |> startProfile(at = [-originStart[0], 2.2 + originStart[1]]) |> arc( angle_start = 30, angle_end = 330, @@ -103,7 +103,7 @@ const plane001 = { } const sketch001l = startSketchOn(plane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = serverDepth + .8) |> angledLine(angle = -45, endAbsoluteY = 1) |> xLine(length = -serverDepth + 2 - .8, tag = $seg01) @@ -112,7 +112,7 @@ const sketch001l = startSketchOn(plane001) const extrude001l = extrude(sketch001l, length = 1) const sketch002l = startSketchOn(plane001) - |> startProfileAt([serverDepth + .8, 0], %) + |> startProfile(at = [serverDepth + .8, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = -135, endAbsoluteX = serverDepth - 1 + .8) |> yLine(length = -railHeight * 1.75) @@ -121,10 +121,7 @@ const sketch002l = startSketchOn(plane001) const extrude002l = extrude(sketch002l, length = 1) const sketch003l = startSketchOn(plane001) - |> startProfileAt([ - serverDepth + .8, - railHeight * 1.75 + 2 - ], %) + |> startProfile(at = [serverDepth + .8, railHeight * 1.75 + 2]) |> xLine(length = -serverDepth - .8, tag = $seg02) |> angledLine(angle = -45, endAbsoluteY = railHeight * 1.75 - 1 + 2) |> xLine(length = serverDepth - 2 + .8) @@ -133,7 +130,7 @@ const sketch003l = startSketchOn(plane001) const extrude003l = extrude(sketch003l, length = 1) const sketch004l = startSketchOn(plane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = 135, endAbsoluteY = railHeight * 1.75 + 2 - 1) |> yLine(length = -railHeight * 1.75) @@ -142,7 +139,7 @@ const sketch004l = startSketchOn(plane001) const extrude004l = extrude(sketch004l, length = 1) const sketch005l = startSketchOn(plane001) - |> startProfileAt([serverDepth - 1.25, 1], %) + |> startProfile(at = [serverDepth - 1.25, 1]) |> line(end = [-serverDepth + 2.25, railHeight * 1.75], tag = $lineToIntersect4) |> xLine(length = 1) |> line(end = [serverDepth - 2.25, -railHeight * 1.75], tag = $lineToIntersect5) @@ -151,7 +148,7 @@ const sketch005l = startSketchOn(plane001) const extrude005l = extrude(sketch005l, length = 1) const sketch006l = startSketchOn(plane001) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> angledLineThatIntersects( angle = 70, intersectTag = lineToIntersect4, @@ -164,10 +161,7 @@ const sketch006l = startSketchOn(plane001) const extrude006l = extrude(sketch006l, length = 1) const sketch007l = startSketchOn(plane001) - |> startProfileAt([ - serverDepth - 1.2, - railHeight * 1.75 + 1 - ], %) + |> startProfile(at = [serverDepth - 1.2, railHeight * 1.75 + 1]) |> angledLineThatIntersects( angle = 70, intersectTag = lineToIntersect5, @@ -192,7 +186,7 @@ const plane002 = { } const sketch001w = startSketchOn(plane002) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = depth) |> angledLine(angle = -45, endAbsoluteY = 1) |> xLine(length = -depth + 2, tag = $seg01w) @@ -201,7 +195,7 @@ const sketch001w = startSketchOn(plane002) const extrude001w = extrude(sketch001w, length = 1) const sketch002w = startSketchOn(plane002) - |> startProfileAt([depth, 0], %) + |> startProfile(at = [depth, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = -135, endAbsoluteX = depth - 1) |> yLine(length = -railHeight * 1.75) @@ -210,7 +204,7 @@ const sketch002w = startSketchOn(plane002) const extrude002w = extrude(sketch002w, length = 1) const sketch003w = startSketchOn(plane002) - |> startProfileAt([depth, railHeight * 1.75 + 2], %) + |> startProfile(at = [depth, railHeight * 1.75 + 2]) |> xLine(length = -depth, tag = $seg02w) |> angledLine(angle = -45, endAbsoluteY = railHeight * 1.75 - 1 + 2) |> xLine(length = depth - 2) @@ -219,7 +213,7 @@ const sketch003w = startSketchOn(plane002) const extrude003w = extrude(sketch003w, length = 1) const sketch004w = startSketchOn(plane002) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = 135, endAbsoluteY = railHeight * 1.75 + 2 - 1) |> yLine(length = -railHeight * 1.75) @@ -228,7 +222,7 @@ const sketch004w = startSketchOn(plane002) const extrude004w = extrude(sketch004w, length = 1) const sketch005w = startSketchOn(plane002) - |> startProfileAt([1, 40.6 + 1.75 / 2], %) + |> startProfile(at = [1, 40.6 + 1.75 / 2]) |> angledLine(angle = -23, length = 35.5 ) |> angledLine(angle = -23 + 90 + 45, length = 1.413 ) |> angledLine(angle = -23, endAbsoluteX = 1, tag = $lineToIntersect) @@ -237,10 +231,7 @@ const sketch005w = startSketchOn(plane002) const extrude005w = extrude(sketch005w, length = 1) const sketch006w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 35.5 * cos(23 * pi() / 180), - 40.6 - (35.5 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 35.5 * cos(23 * pi() / 180), 40.6 - (35.5 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 + 90, endAbsoluteX = depth - 1) |> yLine(length = 2.56) |> angledLineThatIntersects( @@ -254,7 +245,7 @@ const sketch006w = startSketchOn(plane002) const extrude006w = extrude(sketch006w, length = 1) const sketch007w = startSketchOn(plane002) - |> startProfileAt([depth - 1, 60.65 + 1.75 / 2], %) + |> startProfile(at = [depth - 1, 60.65 + 1.75 / 2]) |> angledLine(angle = -23 + 180, length = 34.93 , tag = $lineToIntersect3) |> angledLine(angle = 23 - 90, length = 1.414 ) |> angledLineThatIntersects( @@ -267,7 +258,7 @@ const sketch007w = startSketchOn(plane002) const extrude007w = extrude(sketch007w, length = 1) const sketch008w = startSketchOn(plane002) - |> startProfileAt([1, 41.7 + 1.75 / 2], %) + |> startProfile(at = [1, 41.7 + 1.75 / 2]) |> angledLineThatIntersects( angle = -23 + 90, intersectTag = lineToIntersect3, @@ -284,7 +275,7 @@ const sketch008w = startSketchOn(plane002) const extrude008w = extrude(sketch008w, length = 1) const sketch009w = startSketchOn(plane002) - |> startProfileAt([31.2, 33.3 + 1.75 / 2], %) + |> startProfile(at = [31.2, 33.3 + 1.75 / 2]) |> angledLine(angle = -23 - 45, length = 1.414 ) |> angledLine(angle = 90 - 23, length = 28 ) |> angledLine(angle = -23 + 45, length = -1.414 ) @@ -293,7 +284,7 @@ const sketch009w = startSketchOn(plane002) const extrude009w = extrude(sketch009w, length = 1) const sketch010w = startSketchOn(plane002) - |> startProfileAt([31.2, 33.3 + 1.75 / 2], %) + |> startProfile(at = [31.2, 33.3 + 1.75 / 2]) |> angledLine(angle = -23 - 45, length = 1.414 ) |> angledLine(angle = 180 - 23, length = 28 ) |> angledLine(angle = -23 + 45, length = 1.414 ) @@ -302,10 +293,7 @@ const sketch010w = startSketchOn(plane002) const extrude010w = extrude(sketch010w, length = 1) const sketch011w = startSketchOn(plane002) - |> startProfileAt([ - 31.2 - ((28 - 2) * cos(23 * pi() / 180)), - 33.3 + (28 - 2) * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [31.2 - ((28 - 2) * cos(23 * pi() / 180)), 33.3 + (28 - 2) * sin(23 * pi() / 180) + 1.75 / 2]) |> angledLine(angle = 90 - 23, length = 28 - 2 ) |> angledLine(angle = -23 - 45, length = -1.414 ) |> angledLine(angle = 90 - 23 + 180, length = 28 ) @@ -314,10 +302,7 @@ const sketch011w = startSketchOn(plane002) const extrude011w = extrude(sketch011w, length = 1) const sketch012w = startSketchOn(plane002) - |> startProfileAt([ - 31.2 + (28 - 2) * sin(23 * pi() / 180), - 33.3 + (28 - 2) * cos(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [31.2 + (28 - 2) * sin(23 * pi() / 180), 33.3 + (28 - 2) * cos(23 * pi() / 180) + 1.75 / 2]) |> angledLine(angle = 180 - 23, length = 28 - 2 ) |> angledLine(angle = -23 - 45, length = -1.414 ) |> angledLine(angle = -23, length = 28 ) @@ -326,10 +311,7 @@ const sketch012w = startSketchOn(plane002) const extrude012w = extrude(sketch012w, length = 1) const sketch013w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 4 * cos(23 * pi() / 180), - 40.6 - (4 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 4 * cos(23 * pi() / 180), 40.6 - (4 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 + 90, endAbsoluteX = 1) |> yLine(length = 2.56) @@ -338,10 +320,7 @@ const sketch013w = startSketchOn(plane002) const extrude013w = extrude(sketch013w, length = 1) const sketch014w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 12 * cos(23 * pi() / 180), - 40.6 - (12 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 12 * cos(23 * pi() / 180), 40.6 - (12 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -350,10 +329,7 @@ const sketch014w = startSketchOn(plane002) const extrude014w = extrude(sketch014w, length = 1) const sketch015w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.55 - 8) * cos(23 * pi() / 180), - 40.6 - ((36 - 5.55 - 8) * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + (36 - 5.55 - 8) * cos(23 * pi() / 180), 40.6 - ((36 - 5.55 - 8) * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -362,10 +338,7 @@ const sketch015w = startSketchOn(plane002) const extrude015w = extrude(sketch015w, length = 1) const sketch016w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.5) * cos(23 * pi() / 180), - 40.6 - ((36 - 5.5) * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + (36 - 5.5) * cos(23 * pi() / 180), 40.6 - ((36 - 5.5) * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -374,10 +347,7 @@ const sketch016w = startSketchOn(plane002) const extrude016w = extrude(sketch016w, length = 1) const sketch017w = startSketchOn(plane002) - |> startProfileAt([ - depth - 1 - (3.7 * cos(23 * pi() / 180)), - 60.65 + 3.7 * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [depth - 1 - (3.7 * cos(23 * pi() / 180)), 60.65 + 3.7 * sin(23 * pi() / 180) + 1.75 / 2]) |> arc(angleStart = -23, angleEnd = 180 - 23, radius = 7 / 2 + 2) |> angledLine(angle = -23 + 180, length = -1 ) |> arc(angleStart = 180 - 23, angleEnd = -23, radius = 7 / 2 + 1) @@ -386,10 +356,7 @@ const sketch017w = startSketchOn(plane002) const extrude017w = extrude(sketch017w, length = 1) const sketch018w = startSketchOn(plane002) - |> startProfileAt([ - depth - 1 - (19.3 * cos(23 * pi() / 180)), - 60.65 + 19.3 * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [depth - 1 - (19.3 * cos(23 * pi() / 180)), 60.65 + 19.3 * sin(23 * pi() / 180) + 1.75 / 2]) |> arc(angleStart = -23, angleEnd = 180 - 23, radius = 7 / 2 + 2) |> angledLine(angle = -23 + 180, length = -1 ) |> arc(angleStart = 180 - 23, angleEnd = -23, radius = 7 / 2 + 1) @@ -398,7 +365,7 @@ const sketch018w = startSketchOn(plane002) const extrude018w = extrude(sketch018w, length = 1) const sketch019w = startSketchOn(plane002) - |> startProfileAt([1, 27.8 + 1.75 / 2], %) + |> startProfile(at = [1, 27.8 + 1.75 / 2]) |> angledLine(angle = -23, length = 7 ) |> angledLine(angle = -23 + 90, length = -1 ) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -407,10 +374,7 @@ const sketch019w = startSketchOn(plane002) const extrude019w = extrude(sketch019w, length = 1) const sketch020w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.53 - 12) * cos(23 * pi() / 180), - 27.8 + 1.75 / 2 - ((36 - 5.53 - 12) * sin(23 * pi() / 180)) - ], %) + |> startProfile(at = [1 + (36 - 5.53 - 12) * cos(23 * pi() / 180), 27.8 + 1.75 / 2 - ((36 - 5.53 - 12) * sin(23 * pi() / 180))]) |> angledLine(angle = -23, length = 7 ) |> angledLine(angle = -23 + 90, length = -1 ) |> angledLine(angle = -23 + 180, length = 7 ) @@ -419,7 +383,7 @@ const sketch020w = startSketchOn(plane002) const extrude020w = extrude(sketch020w, length = 1) const sketch021w = startSketchOn(plane002) - |> startProfileAt([1, 21.9], %) + |> startProfile(at = [1, 21.9]) |> angledLine(angle = -23, endAbsoluteX = depth - 1) |> yLine(length = -1.1) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -428,7 +392,7 @@ const sketch021w = startSketchOn(plane002) const extrude021w = extrude(sketch021w, length = 1) const sketch022w = startSketchOn(plane002) - |> startProfileAt([depth - 1, 74.1], %) + |> startProfile(at = [depth - 1, 74.1]) |> angledLine(angle = 180 - 23, endAbsoluteY = railHeight * 1.75 + 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = depth - 1) @@ -437,7 +401,7 @@ const sketch022w = startSketchOn(plane002) const extrude022w = extrude(sketch022w, length = 1) const sketch023w = startSketchOn(plane002) - |> startProfileAt([1, 69.53 + 1.75], %) + |> startProfile(at = [1, 69.53 + 1.75]) |> angledLine(angle = 90 - 23, endAbsoluteY = railHeight * 1.75 + 1) |> xLine(length = 1.086) |> angledLine(angle = 90 - 23, endAbsoluteX = 1) @@ -446,7 +410,7 @@ const sketch023w = startSketchOn(plane002) const extrude023w = extrude(sketch023w, length = 1) const sketch024w = startSketchOn(plane002) - |> startProfileAt([1, 16.5], %) + |> startProfile(at = [1, 16.5]) |> angledLine(angle = -23, endAbsoluteY = 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -455,7 +419,7 @@ const sketch024w = startSketchOn(plane002) const extrude024w = extrude(sketch024w, length = 1) const sketch025w = startSketchOn(plane002) - |> startProfileAt([1, 4], %) + |> startProfile(at = [1, 4]) |> angledLine(angle = -23, endAbsoluteY = 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -472,7 +436,7 @@ const plane003 = { } const sketch005 = startSketchOn(plane003) - |> startProfileAt([width - 1, 0], %) + |> startProfile(at = [width - 1, 0]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -482,7 +446,7 @@ const sketch005 = startSketchOn(plane003) const extrude005 = extrude(sketch005, length = 1) const sketch006 = startSketchOn(plane003) - |> startProfileAt([width - 1, 0 + 2.756], %) + |> startProfile(at = [width - 1, 0 + 2.756]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -492,7 +456,7 @@ const sketch006 = startSketchOn(plane003) const extrude006 = extrude(sketch006, length = 1) const sketch007 = startSketchOn(plane003) - |> startProfileAt([width - 1, depth], %) + |> startProfile(at = [width - 1, depth]) |> line(end = [-width + 1, -depth + serverDepth + 3.8]) |> line(end = [1, 0]) |> line(end = [0, -.75]) @@ -505,7 +469,7 @@ const sketch007 = startSketchOn(plane003) const extrude007 = extrude(sketch007, length = 1) const sketch008 = startSketchOn(plane003) - |> startProfileAt([width - 1, depth - 2.8], %) + |> startProfile(at = [width - 1, depth - 2.8]) |> line(end = [-width + 2, -depth + serverDepth + 4.4]) |> line(end = [0, -1.32]) |> line(end = [width - 2, depth - serverDepth - 4.4]) @@ -523,7 +487,7 @@ const plane004 = { } const sketch005t = startSketchOn(plane004) - |> startProfileAt([width - 1, 0], %) + |> startProfile(at = [width - 1, 0]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -533,7 +497,7 @@ const sketch005t = startSketchOn(plane004) const extrude005t = extrude(sketch005t, length = -1) const sketch007t = startSketchOn(plane004) - |> startProfileAt([width - 1, depth], %) + |> startProfile(at = [width - 1, depth]) |> line(end = [-width + 1, -depth + serverDepth + 3.8]) |> line(end = [1, 0]) |> line(end = [0, -.75]) @@ -546,7 +510,7 @@ const sketch007t = startSketchOn(plane004) const extrude007t = extrude(sketch007t, length = -1) const sketch008t = startSketchOn(plane004) - |> startProfileAt([width - 1, 0 + 2.756], %) + |> startProfile(at = [width - 1, 0 + 2.756]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -555,7 +519,7 @@ const sketch008t = startSketchOn(plane004) const extrude008t = extrude(sketch008t, length = -1) const sketch009t = startSketchOn(plane004) - |> startProfileAt([width - 1, depth - 2.8], %) + |> startProfile(at = [width - 1, depth - 2.8]) |> line(end = [-width + 2, -depth + serverDepth + 4.4]) |> line(end = [0, -1.32]) |> line(end = [width - 2, depth - serverDepth - 4.4]) @@ -589,7 +553,7 @@ const planeYZfl = { // Base flange const sketch001fl = startSketchOn(planeXZfl) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001fl) |> angledLine(angle = segAng(rectangleSegmentA001fl) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001fl) |> angledLine(angle = segAng(rectangleSegmentA001fl), length = -segLen(rectangleSegmentA001fl), tag = $rectangleSegmentC001fl) @@ -599,7 +563,7 @@ const extrude001fl = extrude(sketch001fl, length = thickness) // First flange const sketch002fl = startSketchOn(planeYZfl) - |> startProfileAt([-bendRad - thickness, 0], %) + |> startProfile(at = [-bendRad - thickness, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002fl) |> angledLine(angle = segAng(rectangleSegmentA002fl) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002fl) |> angledLine(angle = segAng(rectangleSegmentA002fl), length = -segLen(rectangleSegmentA002fl), tag = $rectangleSegmentC002fl) @@ -610,7 +574,7 @@ const extrude002fl = extrude(sketch002fl, length = thickness) // Bend const sketch003fl = startSketchOn(planeXYfl) - |> startProfileAt([0 + thickness + bendRad+originStart[1], originStart[0]], %) + |> startProfile(at = [0 + thickness + bendRad+originStart[1], originStart[0]]) |> arc(angleStart = 270, angleEnd = 180, radius = bendRad + thickness) |> xLine(length = thickness) |> arc(angleStart = 180, angleEnd = 270, radius = bendRad) @@ -621,7 +585,7 @@ const extrude003fl = extrude(sketch003fl, length = railHeight * 1.75) // EIA-310-D standard hole pattern const sketch004fl = startSketchOn(extrude002fl, face = 'START') - |> startProfileAt([0.72 + originStart[1], originStart[2] + 0.15], %) + |> startProfile(at = [0.72 + originStart[1], originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA003fl) |> angledLine(angle = segAng(rectangleSegmentA003fl) - 90, length = 0.375, tag = $rectangleSegmentB003fl) |> angledLine(angle = segAng(rectangleSegmentA003fl), length = -segLen(rectangleSegmentA003fl), tag = $rectangleSegmentC003fl) @@ -636,7 +600,7 @@ const extrude004fl = extrude(sketch004fl, length = -thickness) // EIA-310-D standard hole pattern const sketch005fl = startSketchOn(extrude002fl, face = 'START') - |> startProfileAt([0.72 + originStart[1],originStart[2] + 0.15 + .62], %) + |> startProfile(at = [0.72 + originStart[1],originStart[2] + 0.15 + .62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA004fl) |> angledLine(angle = segAng(rectangleSegmentA004fl) - 90, length = 0.375, tag = $rectangleSegmentB004fl) |> angledLine(angle = segAng(rectangleSegmentA004fl), length = -segLen(rectangleSegmentA004fl), tag = $rectangleSegmentC004fl) @@ -651,10 +615,7 @@ const extrude005fl = extrude(sketch005fl, length = -thickness) // EIA-310-D standard hole pattern const sketch006fl = startSketchOn(extrude002fl, face = 'START') - |> startProfileAt([ - 0.72 + originStart[1], - originStart[2] + 0.15 + 0.62 + 0.50 - ], %) + |> startProfile(at = [0.72 + originStart[1], originStart[2] + 0.15 + 0.62 + 0.50]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA005fl) |> angledLine(angle = segAng(rectangleSegmentA005fl) - 90, length = 0.375, tag = $rectangleSegmentB005fl) |> angledLine(angle = segAng(rectangleSegmentA005fl), length = -segLen(rectangleSegmentA005fl), tag = $rectangleSegmentC005fl) @@ -669,7 +630,7 @@ const extrude006fl = extrude(sketch006fl, length = -thickness) // EIA-310-D standard hole pattern const sketch007fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([-1.45 - originStart[0], originStart[2] + 0.15], %) + |> startProfile(at = [-1.45 - originStart[0], originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA006fl) |> angledLine(angle = segAng(rectangleSegmentA006fl) - 90, length = 0.375, tag = $rectangleSegmentB006fl) |> angledLine(angle = segAng(rectangleSegmentA006fl), length = -segLen(rectangleSegmentA006fl), tag = $rectangleSegmentC006fl) @@ -684,7 +645,7 @@ const extrude007fl = extrude(sketch007fl, length = -thickness) // EIA-310-D standard hole pattern const sketch008fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([-1.45 - originStart[0],originStart[2] + 0.15 + 0.62], %) + |> startProfile(at = [-1.45 - originStart[0],originStart[2] + 0.15 + 0.62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA007fl) |> angledLine(angle = segAng(rectangleSegmentA007fl) - 90, length = 0.375, tag = $rectangleSegmentB007fl) |> angledLine(angle = segAng(rectangleSegmentA007fl), length = -segLen(rectangleSegmentA007fl), tag = $rectangleSegmentC007fl) @@ -699,10 +660,7 @@ const extrude008fl = extrude(sketch008fl, length = -thickness) // EIA-310-D standard hole pattern const sketch009fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.45 - originStart[0], - originStart[2] + 0.15 + 0.62 + 0.5 - ], %) + |> startProfile(at = [-1.45 - originStart[0], originStart[2] + 0.15 + 0.62 + 0.5]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA008fl) |> angledLine(angle = segAng(rectangleSegmentA008fl) - 90, length = 0.375, tag = $rectangleSegmentB008fl) |> angledLine(angle = segAng(rectangleSegmentA008fl), length = -segLen(rectangleSegmentA008fl), tag = $rectangleSegmentC008fl) @@ -717,10 +675,7 @@ const extrude009fl = extrude(sketch009fl, length = -thickness) // define slots const sketch010fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [-0.66 - originStart[0],originStart[2] + .81 + .438 / 2]) |> xLine(length = -0.75 + .438) @@ -735,10 +690,7 @@ const extrude010fl = extrude(sketch010fl, length = -thickness) // define slots const sketch011fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -752,10 +704,10 @@ const extrude011fl = extrude(sketch011fl, length = -thickness) // define slots const sketch012fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ + |> startProfile(at = [ -1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + ]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], originStart[2]+ @@ -804,7 +756,7 @@ const planeYZfr = { // Base flange const sketch001fr = startSketchOn(planeXZfr) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001fr) |> angledLine(angle = segAng(rectangleSegmentA001fr) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001fr) |> angledLine(angle = segAng(rectangleSegmentA001fr), length = -segLen(rectangleSegmentA001fr), tag = $rectangleSegmentC001fr) @@ -814,7 +766,7 @@ const extrude001fr = extrude(sketch001fr, length = thickness) // First flange const sketch002fr = startSketchOn(planeYZfr) - |> startProfileAt([0.89, 0], %) + |> startProfile(at = [0.89, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002fr) |> angledLine(angle = segAng(rectangleSegmentA002fr) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002fr) |> angledLine(angle = segAng(rectangleSegmentA002fr), length = -segLen(rectangleSegmentA002fr), tag = $rectangleSegmentC002fr) @@ -825,10 +777,7 @@ const extrude002fr = extrude(sketch002fr, length = thickness) // Bend const sketch003fr = startSketchOn(planeXYfr) - |> startProfileAt([ - bendRad + originStart[1] + width - 2 - thickness - bendRad, - originStart[0] + bendRad + thickness - ], %) + |> startProfile(at = [bendRad + originStart[1] + width - 2 - thickness - bendRad, originStart[0] + bendRad + thickness]) |> arc(angleStart = 0, angleEnd = -90, radius = bendRad) |> yLine(length = -thickness) |> arc(angleStart = -90, angleEnd = 0, radius = bendRad + thickness) @@ -838,10 +787,7 @@ const extrude003fr = extrude(sketch003fr, length = railHeight * 1.75) // EIA-310-D standard hole pattern const sketch004fr = startSketchOn(extrude002fr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA003fr) |> angledLine(angle = segAng(rectangleSegmentA003fr) - 90, length = 0.375, tag = $rectangleSegmentB003fr) |> angledLine(angle = segAng(rectangleSegmentA003fr), length = -segLen(rectangleSegmentA003fr), tag = $rectangleSegmentC003fr) @@ -856,10 +802,7 @@ const extrude004fr = extrude(sketch004fr, length = -thickness) // EIA-310-D standard hole pattern const sketch005fr = startSketchOn(extrude002fr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 + .62 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15 + .62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA004fr) |> angledLine(angle = segAng(rectangleSegmentA004fr) - 90, length = 0.375, tag = $rectangleSegmentB004fr) |> angledLine(angle = segAng(rectangleSegmentA004fr), length = -segLen(rectangleSegmentA004fr), tag = $rectangleSegmentC004fr) @@ -874,10 +817,7 @@ const extrude005fr = extrude(sketch005fr, length = -thickness) // EIA-310-D standard hole pattern const sketch006fr = startSketchOn(extrude002fr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 + 0.62 + 0.50 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15 + 0.62 + 0.50]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA005fr) |> angledLine(angle = segAng(rectangleSegmentA005fr) - 90, length = 0.375, tag = $rectangleSegmentB005fr) |> angledLine(angle = segAng(rectangleSegmentA005fr), length = -segLen(rectangleSegmentA005fr), tag = $rectangleSegmentC005fr) @@ -892,10 +832,7 @@ const extrude006fr = extrude(sketch006fr, length = -thickness) // EIA-310-D standard hole pattern const sketch007fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.45 - originStart[0], - originStart[2] + 0.15 - ], %) + |> startProfile(at = [-1.45 - originStart[0], originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA006fr) |> angledLine(angle = segAng(rectangleSegmentA006fr) - 90, length = 0.375, tag = $rectangleSegmentB006fr) |> angledLine(angle = segAng(rectangleSegmentA006fr), length = -segLen(rectangleSegmentA006fr), tag = $rectangleSegmentC006fr) @@ -910,10 +847,7 @@ const extrude007fr = extrude(sketch007fr, length = -thickness) // EIA-310-D standard hole pattern const sketch008fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.45 - originStart[0], - originStart[2] + 0.15 + 0.62 - ], %) + |> startProfile(at = [-1.45 - originStart[0], originStart[2] + 0.15 + 0.62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA007fr) |> angledLine(angle = segAng(rectangleSegmentA007fr) - 90, length = 0.375, tag = $rectangleSegmentB007fr) |> angledLine(angle = segAng(rectangleSegmentA007fr), length = -segLen(rectangleSegmentA007fr), tag = $rectangleSegmentC007fr) @@ -928,10 +862,7 @@ const extrude008fr = extrude(sketch008fr, length = -thickness) // EIA-310-D standard hole pattern const sketch009fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.45 - originStart[0], - originStart[2] + 0.15 + 0.62 + 0.5 - ], %) + |> startProfile(at = [-1.45 - originStart[0], originStart[2] + 0.15 + 0.62 + 0.5]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA008fr) |> angledLine(angle = segAng(rectangleSegmentA008fr) - 90, length = 0.375, tag = $rectangleSegmentB008fr) |> angledLine(angle = segAng(rectangleSegmentA008fr), length = -segLen(rectangleSegmentA008fr), tag = $rectangleSegmentC008fr) @@ -946,10 +877,7 @@ const extrude009fr = extrude(sketch009fr, length = -thickness) // define slots const sketch010fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -967,10 +895,7 @@ const extrude010fr = extrude(sketch010fr, length = -thickness) // define slots const sketch011fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -984,10 +909,7 @@ const extrude011fr = extrude(sketch011fr, length = -thickness) // define slots const sketch012fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -1036,7 +958,7 @@ const planeYZrr = { // Base flange const sketch001rr = startSketchOn(planeXZrr) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001rr) |> angledLine(angle = segAng(rectangleSegmentA001rr) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001rr) |> angledLine(angle = segAng(rectangleSegmentA001rr), length = -segLen(rectangleSegmentA001rr), tag = $rectangleSegmentC001rr) @@ -1046,7 +968,7 @@ const extrude001rr = extrude(sketch001rr, length = thickness) // First flange const sketch002rr = startSketchOn(planeYZrr) - |> startProfileAt([0.89, 0], %) + |> startProfile(at = [0.89, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002rr) |> angledLine(angle = segAng(rectangleSegmentA002rr) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002rr) |> angledLine(angle = segAng(rectangleSegmentA002rr), length = -segLen(rectangleSegmentA002rr), tag = $rectangleSegmentC002rr) @@ -1057,10 +979,7 @@ const extrude002rr = extrude(sketch002rr, length = thickness) // Bend const sketch003rr = startSketchOn(planeXYrr) - |> startProfileAt([ - bendRad + originStart[1] + width - 2-bendRad, - originStart[0]-bendRad - ], %) + |> startProfile(at = [bendRad + originStart[1] + width - 2-bendRad, originStart[0]-bendRad]) |> arc(angleStart = 0, angleEnd = 90, radius = bendRad+thickness) |> yLine(length = -thickness) |> arc(angleStart = 90, angleEnd = 0, radius = bendRad) @@ -1070,10 +989,7 @@ const extrude003rr = extrude(sketch003rr, length = railHeight * 1.75) // EIA-310-D standard hole pattern const sketch004rr = startSketchOn(extrude002rr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA003rr) |> angledLine(angle = segAng(rectangleSegmentA003rr) - 90, length = 0.375, tag = $rectangleSegmentB003rr) |> angledLine(angle = segAng(rectangleSegmentA003rr), length = -segLen(rectangleSegmentA003rr), tag = $rectangleSegmentC003rr) @@ -1088,10 +1004,7 @@ const extrude004rr = extrude(sketch004rr, length = -thickness) // EIA-310-D standard hole pattern const sketch005rr = startSketchOn(extrude002rr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 + .62 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15 + .62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA004rr) |> angledLine(angle = segAng(rectangleSegmentA004rr) - 90, length = 0.375, tag = $rectangleSegmentB004rr) |> angledLine(angle = segAng(rectangleSegmentA004rr), length = -segLen(rectangleSegmentA004rr), tag = $rectangleSegmentC004rr) @@ -1106,10 +1019,7 @@ const extrude005rr = extrude(sketch005rr, length = -thickness) // EIA-310-D standard hole pattern const sketch006rr = startSketchOn(extrude002rr, face = 'START') - |> startProfileAt([ - -0.35 + originStart[1] + width - 2, - originStart[2] + 0.15 + 0.62 + 0.50 - ], %) + |> startProfile(at = [-0.35 + originStart[1] + width - 2, originStart[2] + 0.15 + 0.62 + 0.50]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA005rr) |> angledLine(angle = segAng(rectangleSegmentA005rr) - 90, length = 0.375, tag = $rectangleSegmentB005rr) |> angledLine(angle = segAng(rectangleSegmentA005rr), length = -segLen(rectangleSegmentA005rr), tag = $rectangleSegmentC005rr) @@ -1124,10 +1034,7 @@ const extrude006rr = extrude(sketch006rr, length = -thickness) // EIA-310-D standard hole pattern const sketch007rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -originStart[0]-serverDepth+1.7, - originStart[2] + 0.15 - ], %) + |> startProfile(at = [-originStart[0]-serverDepth+1.7, originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA006rr) |> angledLine(angle = segAng(rectangleSegmentA006rr) - 90, length = 0.375, tag = $rectangleSegmentB006rr) |> angledLine(angle = segAng(rectangleSegmentA006rr), length = -segLen(rectangleSegmentA006rr), tag = $rectangleSegmentC006rr) @@ -1142,10 +1049,7 @@ const extrude007rr = extrude(sketch007rr, length = -thickness) // EIA-310-D standard hole pattern const sketch008rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -originStart[0]-serverDepth+1.7, - originStart[2] + 0.15 + 0.62 - ], %) + |> startProfile(at = [-originStart[0]-serverDepth+1.7, originStart[2] + 0.15 + 0.62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA007rr) |> angledLine(angle = segAng(rectangleSegmentA007rr) - 90, length = 0.375, tag = $rectangleSegmentB007rr) |> angledLine(angle = segAng(rectangleSegmentA007rr), length = -segLen(rectangleSegmentA007rr), tag = $rectangleSegmentC007rr) @@ -1160,10 +1064,7 @@ const extrude008rr = extrude(sketch008rr, length = -thickness) // EIA-310-D standard hole pattern const sketch009rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -originStart[0]-serverDepth+1.7, - originStart[2] + 0.15 + 0.62 + 0.5 - ], %) + |> startProfile(at = [-originStart[0]-serverDepth+1.7, originStart[2] + 0.15 + 0.62 + 0.5]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA008rr) |> angledLine(angle = segAng(rectangleSegmentA008rr) - 90, length = 0.375, tag = $rectangleSegmentB008rr) |> angledLine(angle = segAng(rectangleSegmentA008rr), length = -segLen(rectangleSegmentA008rr), tag = $rectangleSegmentC008rr) @@ -1178,10 +1079,7 @@ const extrude009rr = extrude(sketch009rr, length = -thickness) // define slots const sketch010rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0]+1.5-serverDepth, @@ -1199,10 +1097,7 @@ const extrude010rr = extrude(sketch010rr, length = -thickness) // define slots const sketch011rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0]+1.5-serverDepth, @@ -1216,10 +1111,7 @@ const extrude011rr = extrude(sketch011rr, length = -thickness) // define slots const sketch012rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0]+1.5-serverDepth, originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0]+1.5-serverDepth, @@ -1267,7 +1159,7 @@ const planeYZrl = { } // Base flange const sketch001rl = startSketchOn(planeXZrl) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001rl) |> angledLine(angle = segAng(rectangleSegmentA001rl) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001rl) |> angledLine(angle = segAng(rectangleSegmentA001rl), length = -segLen(rectangleSegmentA001rl), tag = $rectangleSegmentC001rl) @@ -1277,7 +1169,7 @@ const extrude001rl = extrude(sketch001rl, length = thickness) // First flange const sketch002rl = startSketchOn(planeYZrl) - |> startProfileAt([-bendRad - thickness, 0], %) + |> startProfile(at = [-bendRad - thickness, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002rl) |> angledLine(angle = segAng(rectangleSegmentA002rl) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002rl) |> angledLine(angle = segAng(rectangleSegmentA002rl), length = -segLen(rectangleSegmentA002rl), tag = $rectangleSegmentC002rl) @@ -1288,10 +1180,7 @@ const extrude002rl = extrude(sketch002rl, length = thickness) // Bend const sketch003rl = startSketchOn(planeXYrl) - |> startProfileAt([ - bendRad + originStart[1] + thickness, - originStart[0] - ], %) + |> startProfile(at = [bendRad + originStart[1] + thickness, originStart[0]]) |> arc(angleStart = 90, angleEnd = 180, radius = bendRad) |> xLine(length = -thickness) |> arc(angleStart = 180, angleEnd = 90, radius = bendRad + thickness) @@ -1301,10 +1190,7 @@ const extrude003rl = extrude(sketch003rl, length = railHeight * 1.75) // EIA-310-D standard hole pattern const sketch004rl = startSketchOn(extrude002rl, face = 'START') - |> startProfileAt([ - -1.38 + 2 + thickness + originStart[1], - originStart[2] + 0.15 - ], %) + |> startProfile(at = [-1.38 + 2 + thickness + originStart[1], originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA003rl) |> angledLine(angle = segAng(rectangleSegmentA003rl) - 90, length = 0.375, tag = $rectangleSegmentB003rl) |> angledLine(angle = segAng(rectangleSegmentA003rl), length = -segLen(rectangleSegmentA003rl), tag = $rectangleSegmentC003rl) @@ -1319,10 +1205,7 @@ const extrude004rl = extrude(sketch004rl, length = -thickness) // EIA-310-D standard hole pattern const sketch005rl = startSketchOn(extrude002rl, face = 'START') - |> startProfileAt([ - -1.38 + 2 + thickness + originStart[1], - originStart[2] + 0.15 + .62 - ], %) + |> startProfile(at = [-1.38 + 2 + thickness + originStart[1], originStart[2] + 0.15 + .62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA004rl) |> angledLine(angle = segAng(rectangleSegmentA004rl) - 90, length = 0.375, tag = $rectangleSegmentB004rl) |> angledLine(angle = segAng(rectangleSegmentA004rl), length = -segLen(rectangleSegmentA004rl), tag = $rectangleSegmentC004rl) @@ -1337,10 +1220,7 @@ const extrude005rl = extrude(sketch005rl, length = -thickness) // EIA-310-D standard hole pattern const sketch006rl = startSketchOn(extrude002rl, face = 'START') - |> startProfileAt([ - -1.38 + 2 + thickness + originStart[1], - originStart[2] + 0.15 + 0.62 + 0.50 - ], %) + |> startProfile(at = [-1.38 + 2 + thickness + originStart[1], originStart[2] + 0.15 + 0.62 + 0.50]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA005rl) |> angledLine(angle = segAng(rectangleSegmentA005rl) - 90, length = 0.375, tag = $rectangleSegmentB005rl) |> angledLine(angle = segAng(rectangleSegmentA005rl), length = -segLen(rectangleSegmentA005rl), tag = $rectangleSegmentC005rl) @@ -1355,10 +1235,7 @@ const extrude006rl = extrude(sketch006rl, length = -thickness) // EIA-310-D standard hole pattern const sketch007rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - 1.75 - originStart[0] - serverDepth, - originStart[2] + 0.15 - ], %) + |> startProfile(at = [1.75 - originStart[0] - serverDepth, originStart[2] + 0.15]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA006rl) |> angledLine(angle = segAng(rectangleSegmentA006rl) - 90, length = 0.375, tag = $rectangleSegmentB006rl) |> angledLine(angle = segAng(rectangleSegmentA006rl), length = -segLen(rectangleSegmentA006rl), tag = $rectangleSegmentC006rl) @@ -1373,10 +1250,7 @@ const extrude007rl = extrude(sketch007rl, length = -thickness) // EIA-310-D standard hole pattern const sketch008rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - 1.75 - originStart[0] - serverDepth, - originStart[2] + 0.15 + 0.62 - ], %) + |> startProfile(at = [1.75 - originStart[0] - serverDepth, originStart[2] + 0.15 + 0.62]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA007rl) |> angledLine(angle = segAng(rectangleSegmentA007rl) - 90, length = 0.375, tag = $rectangleSegmentB007rl) |> angledLine(angle = segAng(rectangleSegmentA007rl), length = -segLen(rectangleSegmentA007rl), tag = $rectangleSegmentC007rl) @@ -1391,10 +1265,7 @@ const extrude008rl = extrude(sketch008rl, length = -thickness) // EIA-310-D standard hole pattern const sketch009rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - 1.75 - originStart[0] - serverDepth, - originStart[2] + 0.15 + 0.62 + 0.5 - ], %) + |> startProfile(at = [1.75 - originStart[0] - serverDepth, originStart[2] + 0.15 + 0.62 + 0.5]) |> angledLine(angle = 0, length = -0.375, tag = $rectangleSegmentA008rl) |> angledLine(angle = segAng(rectangleSegmentA008rl) - 90, length = 0.375, tag = $rectangleSegmentB008rl) |> angledLine(angle = segAng(rectangleSegmentA008rl), length = -segLen(rectangleSegmentA008rl), tag = $rectangleSegmentC008rl) @@ -1409,10 +1280,7 @@ const extrude009rl = extrude(sketch009rl, length = -thickness) // define slots const sketch010rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1430,10 +1298,7 @@ const extrude010rl = extrude(sketch010rl, length = -thickness) // define slots const sketch011rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1447,10 +1312,7 @@ const extrude011rl = extrude(sketch011rl, length = -thickness) // define slots const sketch012rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1490,7 +1352,7 @@ fn streamServer = (serverPos) => { } const sketch001s = startSketchOn(planeXYs) - |> startProfileAt([1 + 1.2, 1], %) + |> startProfile(at = [1 + 1.2, 1]) |> angledLine(angle = 0, length = 17.2, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 29, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -1499,7 +1361,7 @@ fn streamServer = (serverPos) => { const extrude001s = extrude(sketch001s, length = 7) const sketch002s = startSketchOn(planeXZs) - |> startProfileAt([-1, 4.114 + 1 + serverPos * 1.75], %) + |> startProfile(at = [-1, 4.114 + 1 + serverPos * 1.75]) |> yLine(length = 6.98) |> xLine(length = 0.2) |> yLine(length = -0.36) @@ -1523,7 +1385,7 @@ fn streamServer = (serverPos) => { const extrude002s = extrude(sketch002s, length = 1.8 / 2) const sketch003s = startSketchOn(planeXZs2) - |> startProfileAt([-1, 4.114 + 1 + serverPos * 1.75], %) + |> startProfile(at = [-1, 4.114 + 1 + serverPos * 1.75]) |> yLine(length = 6.98) |> xLine(length = 0.2) |> yLine(length = -0.36) diff --git a/rust/kcl-lib/e2e/executor/inputs/server-rack-lite.kcl b/rust/kcl-lib/e2e/executor/inputs/server-rack-lite.kcl index fffb5f312..98847445f 100644 --- a/rust/kcl-lib/e2e/executor/inputs/server-rack-lite.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/server-rack-lite.kcl @@ -20,7 +20,7 @@ fn caster = (originStart) => { } const sketch001c = startSketchOn(plane001c) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 3.543) |> yLine(length = 3.543) |> xLine(length = -3.543) @@ -45,7 +45,7 @@ fn caster = (originStart) => { |> extrude(length = -.25) const sketch002c = startSketchOn(sketch001c, face = 'START') - |> startProfileAt([-originStart[0], 2.2 + originStart[1]], %) + |> startProfile(at = [-originStart[0], 2.2 + originStart[1]]) |> arc( angle_start = 30, angle_end = 330, @@ -101,7 +101,7 @@ const plane001 = { } const sketch001l = startSketchOn(plane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = serverDepth + .8) |> angledLine(angle = -45, endAbsoluteY = 1) |> xLine(length = -serverDepth + 2 - .8, tag = $seg01) @@ -110,7 +110,7 @@ const sketch001l = startSketchOn(plane001) const extrude001l = extrude(sketch001l, length = 1) const sketch002l = startSketchOn(plane001) - |> startProfileAt([serverDepth + .8, 0], %) + |> startProfile(at = [serverDepth + .8, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = -135, endAbsoluteX = serverDepth - 1 + .8) |> yLine(length = -railHeight * 1.75) @@ -119,10 +119,7 @@ const sketch002l = startSketchOn(plane001) const extrude002l = extrude(sketch002l, length = 1) const sketch003l = startSketchOn(plane001) - |> startProfileAt([ - serverDepth + .8, - railHeight * 1.75 + 2 - ], %) + |> startProfile(at = [serverDepth + .8, railHeight * 1.75 + 2]) |> xLine(length = -serverDepth - .8, tag = $seg02) |> angledLine(angle = -45, endAbsoluteY = railHeight * 1.75 - 1 + 2) |> xLine(length = serverDepth - 2 + .8) @@ -131,7 +128,7 @@ const sketch003l = startSketchOn(plane001) const extrude003l = extrude(sketch003l, length = 1) const sketch004l = startSketchOn(plane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = 135, endAbsoluteY = railHeight * 1.75 + 2 - 1) |> yLine(length = -railHeight * 1.75) @@ -140,7 +137,7 @@ const sketch004l = startSketchOn(plane001) const extrude004l = extrude(sketch004l, length = 1) const sketch005l = startSketchOn(plane001) - |> startProfileAt([serverDepth - 1.25, 1], %) + |> startProfile(at = [serverDepth - 1.25, 1]) |> line(end = [-serverDepth + 2.25, railHeight * 1.75], tag = $lineToIntersect4) |> xLine(length = 1) |> line(end = [serverDepth - 2.25, -railHeight * 1.75], tag = $lineToIntersect5) @@ -149,7 +146,7 @@ const sketch005l = startSketchOn(plane001) const extrude005l = extrude(sketch005l, length = 1) const sketch006l = startSketchOn(plane001) - |> startProfileAt([1, 1], %) + |> startProfile(at = [1, 1]) |> angledLineThatIntersects(angle = 70, intersectTag = lineToIntersect4, offset = 0) |> angledLine(angle = -70, length = 1.414 ) |> angledLine(angle = 70 + 180, endAbsoluteY = 2 - 1) @@ -158,10 +155,7 @@ const sketch006l = startSketchOn(plane001) const extrude006l = extrude(sketch006l, length = 1) const sketch007l = startSketchOn(plane001) - |> startProfileAt([ - serverDepth - 1.2, - railHeight * 1.75 + 1 - ], %) + |> startProfile(at = [serverDepth - 1.2, railHeight * 1.75 + 1]) |> angledLineThatIntersects(angle = 70, intersectTag = lineToIntersect5, offset = 0) |> angledLine(angle = -70, length = 1.414 ) |> angledLine(angle = 70 + 180, endAbsoluteY = railHeight * 1.75 + 1) @@ -182,7 +176,7 @@ const plane002 = { } const sketch001w = startSketchOn(plane002) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = depth) |> angledLine(angle = -45, endAbsoluteY = 1) |> xLine(length = -depth + 2, tag = $seg01w) @@ -191,7 +185,7 @@ const sketch001w = startSketchOn(plane002) const extrude001w = extrude(sketch001w, length = 1) const sketch002w = startSketchOn(plane002) - |> startProfileAt([depth, 0], %) + |> startProfile(at = [depth, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = -135, endAbsoluteX = depth - 1) |> yLine(length = -railHeight * 1.75) @@ -200,7 +194,7 @@ const sketch002w = startSketchOn(plane002) const extrude002w = extrude(sketch002w, length = 1) const sketch003w = startSketchOn(plane002) - |> startProfileAt([depth, railHeight * 1.75 + 2], %) + |> startProfile(at = [depth, railHeight * 1.75 + 2]) |> xLine(length = -depth, tag = $seg02w) |> angledLine(angle = -45, endAbsoluteY = railHeight * 1.75 - 1 + 2) |> xLine(length = depth - 2) @@ -209,7 +203,7 @@ const sketch003w = startSketchOn(plane002) const extrude003w = extrude(sketch003w, length = 1) const sketch004w = startSketchOn(plane002) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(length = railHeight * 1.75 + 2) |> angledLine(angle = 135, endAbsoluteY = railHeight * 1.75 + 2 - 1) |> yLine(length = -railHeight * 1.75) @@ -218,7 +212,7 @@ const sketch004w = startSketchOn(plane002) const extrude004w = extrude(sketch004w, length = 1) const sketch005w = startSketchOn(plane002) - |> startProfileAt([1, 40.6 + 1.75 / 2], %) + |> startProfile(at = [1, 40.6 + 1.75 / 2]) |> angledLine(angle = -23, length = 35.5 ) |> angledLine(angle = -23 + 90 + 45, length = 1.413 ) |> angledLine(angle = -23, endAbsoluteX = 1, tag = $lineToIntersect) @@ -227,10 +221,7 @@ const sketch005w = startSketchOn(plane002) const extrude005w = extrude(sketch005w, length = 1) const sketch006w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 35.5 * cos(23 * pi() / 180), - 40.6 - (35.5 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 35.5 * cos(23 * pi() / 180), 40.6 - (35.5 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 + 90, endAbsoluteX = depth - 1) |> yLine(length = 2.56) |> angledLineThatIntersects( @@ -244,7 +235,7 @@ const sketch006w = startSketchOn(plane002) const extrude006w = extrude(sketch006w, length = 1) const sketch007w = startSketchOn(plane002) - |> startProfileAt([depth - 1, 60.65 + 1.75 / 2], %) + |> startProfile(at = [depth - 1, 60.65 + 1.75 / 2]) |> angledLine(angle = -23 + 180, length = 34.93 , tag = $lineToIntersect3) |> angledLine(angle = 23 - 90, length = 1.414 ) |> angledLineThatIntersects( @@ -257,7 +248,7 @@ const sketch007w = startSketchOn(plane002) const extrude007w = extrude(sketch007w, length = 1) const sketch008w = startSketchOn(plane002) - |> startProfileAt([1, 41.7 + 1.75 / 2], %) + |> startProfile(at = [1, 41.7 + 1.75 / 2]) |> angledLineThatIntersects( angle = -23 + 90, intersectTag = lineToIntersect3, @@ -274,7 +265,7 @@ const sketch008w = startSketchOn(plane002) const extrude008w = extrude(sketch008w, length = 1) const sketch009w = startSketchOn(plane002) - |> startProfileAt([31.2, 33.3 + 1.75 / 2], %) + |> startProfile(at = [31.2, 33.3 + 1.75 / 2]) |> angledLine(angle = -23 - 45, length = 1.414 ) |> angledLine(angle = 90 - 23, length = 28 ) |> angledLine(angle = -23 + 45, length = -1.414 ) @@ -283,7 +274,7 @@ const sketch009w = startSketchOn(plane002) const extrude009w = extrude(sketch009w, length = 1) const sketch010w = startSketchOn(plane002) - |> startProfileAt([31.2, 33.3 + 1.75 / 2], %) + |> startProfile(at = [31.2, 33.3 + 1.75 / 2]) |> angledLine(angle = -23 - 45, length = 1.414 ) |> angledLine(angle = 180 - 23, length = 28 ) |> angledLine(angle = -23 + 45, length = 1.414 ) @@ -292,10 +283,7 @@ const sketch010w = startSketchOn(plane002) const extrude010w = extrude(sketch010w, length = 1) const sketch011w = startSketchOn(plane002) - |> startProfileAt([ - 31.2 - ((28 - 2) * cos(23 * pi() / 180)), - 33.3 + (28 - 2) * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [31.2 - ((28 - 2) * cos(23 * pi() / 180)), 33.3 + (28 - 2) * sin(23 * pi() / 180) + 1.75 / 2]) |> angledLine(angle = 90 - 23, length = 28 - 2 ) |> angledLine(angle = -23 - 45, length = -1.414 ) |> angledLine(angle = 90 - 23 + 180, length = 28 ) @@ -304,10 +292,7 @@ const sketch011w = startSketchOn(plane002) const extrude011w = extrude(sketch011w, length = 1) const sketch012w = startSketchOn(plane002) - |> startProfileAt([ - 31.2 + (28 - 2) * sin(23 * pi() / 180), - 33.3 + (28 - 2) * cos(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [31.2 + (28 - 2) * sin(23 * pi() / 180), 33.3 + (28 - 2) * cos(23 * pi() / 180) + 1.75 / 2]) |> angledLine(angle = 180 - 23, length = 28 - 2 ) |> angledLine(angle = -23 - 45, length = -1.414 ) |> angledLine(angle = -23, length = 28 ) @@ -316,10 +301,7 @@ const sketch012w = startSketchOn(plane002) const extrude012w = extrude(sketch012w, length = 1) const sketch013w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 4 * cos(23 * pi() / 180), - 40.6 - (4 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 4 * cos(23 * pi() / 180), 40.6 - (4 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 + 90, endAbsoluteX = 1) |> yLine(length = 2.56) @@ -328,10 +310,7 @@ const sketch013w = startSketchOn(plane002) const extrude013w = extrude(sketch013w, length = 1) const sketch014w = startSketchOn(plane002) - |> startProfileAt([ - 1 + 12 * cos(23 * pi() / 180), - 40.6 - (12 * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + 12 * cos(23 * pi() / 180), 40.6 - (12 * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -340,10 +319,7 @@ const sketch014w = startSketchOn(plane002) const extrude014w = extrude(sketch014w, length = 1) const sketch015w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.55 - 8) * cos(23 * pi() / 180), - 40.6 - ((36 - 5.55 - 8) * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + (36 - 5.55 - 8) * cos(23 * pi() / 180), 40.6 - ((36 - 5.55 - 8) * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -352,10 +328,7 @@ const sketch015w = startSketchOn(plane002) const extrude015w = extrude(sketch015w, length = 1) const sketch016w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.5) * cos(23 * pi() / 180), - 40.6 - ((36 - 5.5) * sin(23 * pi() / 180)) + 1.75 / 2 - ], %) + |> startProfile(at = [1 + (36 - 5.5) * cos(23 * pi() / 180), 40.6 - ((36 - 5.5) * sin(23 * pi() / 180)) + 1.75 / 2]) |> angledLine(angle = -23 - 90, length = 36 / 2 ) |> angledLine(angle = -23, length = 1 ) |> angledLine(angle = -23 - 90, length = -36 / 2 ) @@ -364,10 +337,7 @@ const sketch016w = startSketchOn(plane002) const extrude016w = extrude(sketch016w, length = 1) const sketch017w = startSketchOn(plane002) - |> startProfileAt([ - depth - 1 - (3.7 * cos(23 * pi() / 180)), - 60.65 + 3.7 * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [depth - 1 - (3.7 * cos(23 * pi() / 180)), 60.65 + 3.7 * sin(23 * pi() / 180) + 1.75 / 2]) |> arc(angleStart = -23, angleEnd = 180 - 23, radius = 7 / 2 + 2) |> angledLine(angle = -23 + 180, length = -1 ) |> arc(angleStart = 180 - 23, angleEnd = -23, radius = 7 / 2 + 1) @@ -376,10 +346,7 @@ const sketch017w = startSketchOn(plane002) const extrude017w = extrude(sketch017w, length = 1) const sketch018w = startSketchOn(plane002) - |> startProfileAt([ - depth - 1 - (19.3 * cos(23 * pi() / 180)), - 60.65 + 19.3 * sin(23 * pi() / 180) + 1.75 / 2 - ], %) + |> startProfile(at = [depth - 1 - (19.3 * cos(23 * pi() / 180)), 60.65 + 19.3 * sin(23 * pi() / 180) + 1.75 / 2]) |> arc(angleStart = -23, angleEnd = 180 - 23, radius = 7 / 2 + 2) |> angledLine(angle = -23 + 180, length = -1 ) |> arc(angleStart = 180 - 23, angleEnd = -23, radius = 7 / 2 + 1) @@ -388,7 +355,7 @@ const sketch018w = startSketchOn(plane002) const extrude018w = extrude(sketch018w, length = 1) const sketch019w = startSketchOn(plane002) - |> startProfileAt([1, 27.8 + 1.75 / 2], %) + |> startProfile(at = [1, 27.8 + 1.75 / 2]) |> angledLine(angle = -23, length = 7 ) |> angledLine(angle = -23 + 90, length = -1 ) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -397,10 +364,7 @@ const sketch019w = startSketchOn(plane002) const extrude019w = extrude(sketch019w, length = 1) const sketch020w = startSketchOn(plane002) - |> startProfileAt([ - 1 + (36 - 5.53 - 12) * cos(23 * pi() / 180), - 27.8 + 1.75 / 2 - ((36 - 5.53 - 12) * sin(23 * pi() / 180)) - ], %) + |> startProfile(at = [1 + (36 - 5.53 - 12) * cos(23 * pi() / 180), 27.8 + 1.75 / 2 - ((36 - 5.53 - 12) * sin(23 * pi() / 180))]) |> angledLine(angle = -23, length = 7 ) |> angledLine(angle = -23 + 90, length = -1 ) |> angledLine(angle = -23 + 180, length = 7 ) @@ -409,7 +373,7 @@ const sketch020w = startSketchOn(plane002) const extrude020w = extrude(sketch020w, length = 1) const sketch021w = startSketchOn(plane002) - |> startProfileAt([1, 21.9], %) + |> startProfile(at = [1, 21.9]) |> angledLine(angle = -23, endAbsoluteX = depth - 1) |> yLine(length = -1.1) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -418,7 +382,7 @@ const sketch021w = startSketchOn(plane002) const extrude021w = extrude(sketch021w, length = 1) const sketch022w = startSketchOn(plane002) - |> startProfileAt([depth - 1, 74.1], %) + |> startProfile(at = [depth - 1, 74.1]) |> angledLine(angle = 180 - 23, endAbsoluteY = railHeight * 1.75 + 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = depth - 1) @@ -427,7 +391,7 @@ const sketch022w = startSketchOn(plane002) const extrude022w = extrude(sketch022w, length = 1) const sketch023w = startSketchOn(plane002) - |> startProfileAt([1, 69.53 + 1.75], %) + |> startProfile(at = [1, 69.53 + 1.75]) |> angledLine(angle = 90 - 23, endAbsoluteY = railHeight * 1.75 + 1) |> xLine(length = 1.086) |> angledLine(angle = 90 - 23, endAbsoluteX = 1) @@ -436,7 +400,7 @@ const sketch023w = startSketchOn(plane002) const extrude023w = extrude(sketch023w, length = 1) const sketch024w = startSketchOn(plane002) - |> startProfileAt([1, 16.5], %) + |> startProfile(at = [1, 16.5]) |> angledLine(angle = -23, endAbsoluteY = 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -445,7 +409,7 @@ const sketch024w = startSketchOn(plane002) const extrude024w = extrude(sketch024w, length = 1) const sketch025w = startSketchOn(plane002) - |> startProfileAt([1, 4], %) + |> startProfile(at = [1, 4]) |> angledLine(angle = -23, endAbsoluteY = 1) |> xLine(length = -2.56) |> angledLine(angle = -23, endAbsoluteX = 1) @@ -462,7 +426,7 @@ const plane003 = { } const sketch005 = startSketchOn(plane003) - |> startProfileAt([width - 1, 0], %) + |> startProfile(at = [width - 1, 0]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -472,7 +436,7 @@ const sketch005 = startSketchOn(plane003) const extrude005 = extrude(sketch005, length = 1) const sketch006 = startSketchOn(plane003) - |> startProfileAt([width - 1, 0 + 2.756], %) + |> startProfile(at = [width - 1, 0 + 2.756]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -482,7 +446,7 @@ const sketch006 = startSketchOn(plane003) const extrude006 = extrude(sketch006, length = 1) const sketch007 = startSketchOn(plane003) - |> startProfileAt([width - 1, depth], %) + |> startProfile(at = [width - 1, depth]) |> line(end = [-width + 1, -depth + serverDepth + 3.8]) |> line(end = [1, 0]) |> line(end = [0, -.75]) @@ -495,7 +459,7 @@ const sketch007 = startSketchOn(plane003) const extrude007 = extrude(sketch007, length = 1) const sketch008 = startSketchOn(plane003) - |> startProfileAt([width - 1, depth - 2.8], %) + |> startProfile(at = [width - 1, depth - 2.8]) |> line(end = [-width + 2, -depth + serverDepth + 4.4]) |> line(end = [0, -1.32]) |> line(end = [width - 2, depth - serverDepth - 4.4]) @@ -513,7 +477,7 @@ const plane004 = { } const sketch005t = startSketchOn(plane004) - |> startProfileAt([width - 1, 0], %) + |> startProfile(at = [width - 1, 0]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -523,7 +487,7 @@ const sketch005t = startSketchOn(plane004) const extrude005t = extrude(sketch005t, length = -1) const sketch007t = startSketchOn(plane004) - |> startProfileAt([width - 1, depth], %) + |> startProfile(at = [width - 1, depth]) |> line(end = [-width + 1, -depth + serverDepth + 3.8]) |> line(end = [1, 0]) |> line(end = [0, -.75]) @@ -536,7 +500,7 @@ const sketch007t = startSketchOn(plane004) const extrude007t = extrude(sketch007t, length = -1) const sketch008t = startSketchOn(plane004) - |> startProfileAt([width - 1, 0 + 2.756], %) + |> startProfile(at = [width - 1, 0 + 2.756]) |> line(end = [-width + 2, 3]) |> line(end = [0, 1]) |> line(end = [width - 2, -3]) @@ -545,7 +509,7 @@ const sketch008t = startSketchOn(plane004) const extrude008t = extrude(sketch008t, length = -1) const sketch009t = startSketchOn(plane004) - |> startProfileAt([width - 1, depth - 2.8], %) + |> startProfile(at = [width - 1, depth - 2.8]) |> line(end = [-width + 2, -depth + serverDepth + 4.4]) |> line(end = [0, -1.32]) |> line(end = [width - 2, depth - serverDepth - 4.4]) @@ -587,7 +551,7 @@ const planeYZfl = { // Base flange const sketch001fl = startSketchOn(planeXZfl) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001fl) |> angledLine(angle = segAng(rectangleSegmentA001fl) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001fl) |> angledLine(angle = segAng(rectangleSegmentA001fl), length = -segLen(rectangleSegmentA001fl), tag = $rectangleSegmentC001fl) @@ -597,7 +561,7 @@ const extrude001fl = extrude(sketch001fl, length = thickness) // First flange const sketch002fl = startSketchOn(planeYZfl) - |> startProfileAt([-bendRad - thickness, 0], %) + |> startProfile(at = [-bendRad - thickness, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002fl) |> angledLine(angle = segAng(rectangleSegmentA002fl) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002fl) |> angledLine(angle = segAng(rectangleSegmentA002fl), length = -segLen(rectangleSegmentA002fl), tag = $rectangleSegmentC002fl) @@ -608,10 +572,7 @@ const extrude002fl = extrude(sketch002fl, length = thickness) // Bend const sketch003fl = startSketchOn(planeXYfl) - |> startProfileAt([ - 0 + thickness + bendRad + originStart[1], - originStart[0] - ], %) + |> startProfile(at = [0 + thickness + bendRad + originStart[1], originStart[0]]) |> arc(angleStart = 270, angleEnd = 180, radius = bendRad + thickness) |> xLine(length = thickness) |> arc(angleStart = 180, angleEnd = 270, radius = bendRad) @@ -622,10 +583,7 @@ const extrude003fl = extrude(sketch003fl, length = railHeight * 1.75) // define slots const sketch010fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -643,10 +601,7 @@ const extrude010fl = extrude(sketch010fl, length = -thickness) // define slots const sketch011fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -660,10 +615,7 @@ const extrude011fl = extrude(sketch011fl, length = -thickness) // define slots const sketch012fl = startSketchOn(extrude001fl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -712,7 +664,7 @@ const planeYZfr = { // Base flange const sketch001fr = startSketchOn(planeXZfr) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001fr) |> angledLine(angle = segAng(rectangleSegmentA001fr) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001fr) |> angledLine(angle = segAng(rectangleSegmentA001fr), length = -segLen(rectangleSegmentA001fr), tag = $rectangleSegmentC001fr) @@ -722,7 +674,7 @@ const extrude001fr = extrude(sketch001fr, length = thickness) // First flange const sketch002fr = startSketchOn(planeYZfr) - |> startProfileAt([0.89, 0], %) + |> startProfile(at = [0.89, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002fr) |> angledLine(angle = segAng(rectangleSegmentA002fr) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002fr) |> angledLine(angle = segAng(rectangleSegmentA002fr), length = -segLen(rectangleSegmentA002fr), tag = $rectangleSegmentC002fr) @@ -733,10 +685,7 @@ const extrude002fr = extrude(sketch002fr, length = thickness) // Bend const sketch003fr = startSketchOn(planeXYfr) - |> startProfileAt([ - bendRad + originStart[1] + width - 2 - thickness - bendRad, - originStart[0] + bendRad + thickness - ], %) + |> startProfile(at = [bendRad + originStart[1] + width - 2 - thickness - bendRad, originStart[0] + bendRad + thickness]) |> arc(angleStart = 0, angleEnd = -90, radius = bendRad) |> yLine(length = -thickness) |> arc(angleStart = -90, angleEnd = 0, radius = bendRad + thickness) @@ -746,10 +695,7 @@ const extrude003fr = extrude(sketch003fr, length = railHeight * 1.75) // define slots const sketch010fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -767,10 +713,7 @@ const extrude010fr = extrude(sketch010fr, length = -thickness) // define slots const sketch011fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -784,10 +727,7 @@ const extrude011fr = extrude(sketch011fr, length = -thickness) // define slots const sketch012fr = startSketchOn(extrude001fr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0], - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0], originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0], @@ -836,7 +776,7 @@ const planeYZrr = { // Base flange const sketch001rr = startSketchOn(planeXZrr) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001rr) |> angledLine(angle = segAng(rectangleSegmentA001rr) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001rr) |> angledLine(angle = segAng(rectangleSegmentA001rr), length = -segLen(rectangleSegmentA001rr), tag = $rectangleSegmentC001rr) @@ -846,7 +786,7 @@ const extrude001rr = extrude(sketch001rr, length = thickness) // First flange const sketch002rr = startSketchOn(planeYZrr) - |> startProfileAt([0.89, 0], %) + |> startProfile(at = [0.89, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002rr) |> angledLine(angle = segAng(rectangleSegmentA002rr) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002rr) |> angledLine(angle = segAng(rectangleSegmentA002rr), length = -segLen(rectangleSegmentA002rr), tag = $rectangleSegmentC002rr) @@ -857,10 +797,7 @@ const extrude002rr = extrude(sketch002rr, length = thickness) // Bend const sketch003rr = startSketchOn(planeXYrr) - |> startProfileAt([ - bendRad + originStart[1] + width - 2 - bendRad, - originStart[0] - bendRad - ], %) + |> startProfile(at = [bendRad + originStart[1] + width - 2 - bendRad, originStart[0] - bendRad]) |> arc(angleStart = 0, angleEnd = 90, radius = bendRad + thickness) |> yLine(length = -thickness) |> arc(angleStart = 90, angleEnd = 0, radius = bendRad) @@ -870,10 +807,7 @@ const extrude003rr = extrude(sketch003rr, length = railHeight * 1.75) // define slots const sketch010rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] + 1.5 - serverDepth, @@ -891,10 +825,7 @@ const extrude010rr = extrude(sketch010rr, length = -thickness) // define slots const sketch011rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] + 1.5 - serverDepth, @@ -908,10 +839,7 @@ const extrude011rr = extrude(sketch011rr, length = -thickness) // define slots const sketch012rr = startSketchOn(extrude001rr, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] + 1.5 - serverDepth, originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] + 1.5 - serverDepth, @@ -959,7 +887,7 @@ const planeYZrl = { } // Base flange const sketch001rl = startSketchOn(planeXZrl) - |> startProfileAt([bendRad + thickness, 0], %) + |> startProfile(at = [bendRad + thickness, 0]) |> angledLine(angle = 0, length = 2 - bendRad - thickness, tag = $rectangleSegmentA001rl) |> angledLine(angle = segAng(rectangleSegmentA001rl) + 90, length = railHeight * 1.75, tag = $rectangleSegmentB001rl) |> angledLine(angle = segAng(rectangleSegmentA001rl), length = -segLen(rectangleSegmentA001rl), tag = $rectangleSegmentC001rl) @@ -969,7 +897,7 @@ const extrude001rl = extrude(sketch001rl, length = thickness) // First flange const sketch002rl = startSketchOn(planeYZrl) - |> startProfileAt([-bendRad - thickness, 0], %) + |> startProfile(at = [-bendRad - thickness, 0]) |> angledLine(angle = 180, length = 0.89 - bendRad - thickness, tag = $rectangleSegmentA002rl) |> angledLine(angle = segAng(rectangleSegmentA002rl) - 90, length = railHeight * 1.75, tag = $rectangleSegmentB002rl) |> angledLine(angle = segAng(rectangleSegmentA002rl), length = -segLen(rectangleSegmentA002rl), tag = $rectangleSegmentC002rl) @@ -980,10 +908,7 @@ const extrude002rl = extrude(sketch002rl, length = thickness) // Bend const sketch003rl = startSketchOn(planeXYrl) - |> startProfileAt([ - bendRad + originStart[1] + thickness, - originStart[0] - ], %) + |> startProfile(at = [bendRad + originStart[1] + thickness, originStart[0]]) |> arc(angleStart = 90, angleEnd = 180, radius = bendRad) |> xLine(length = -thickness) |> arc(angleStart = 180, angleEnd = 90, radius = bendRad + thickness) @@ -993,10 +918,7 @@ const extrude003rl = extrude(sketch003rl, length = railHeight * 1.75) // define slots const sketch010rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + .81 - (.438 / 2) - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + .81 - (.438 / 2)]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1014,10 +936,7 @@ const extrude010rl = extrude(sketch010rl, length = -thickness) // define slots const sketch011rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + railHeight * 1.75 / 2 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + railHeight * 1.75 / 2 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1031,10 +950,7 @@ const extrude011rl = extrude(sketch011rl, length = -thickness) // define slots const sketch012rl = startSketchOn(extrude001rl, face = 'START') - |> startProfileAt([ - -1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, - originStart[2] + railHeight * 1.75 - .81 + .438 / 2 - ], %) + |> startProfile(at = [-1.12 + (.75 - .438) / 2 - originStart[0] - serverDepth + 1.5, originStart[2] + railHeight * 1.75 - .81 + .438 / 2]) |> xLine(length = 0.75 - .438) |> tangentialArc(endAbsolute = [ -0.66 - originStart[0] - serverDepth + 1.5, @@ -1073,7 +989,7 @@ fn streamServer = (serverPos) => { } const sketch001s = startSketchOn(planeXYs) - |> startProfileAt([1 + 1.2, 1], %) + |> startProfile(at = [1 + 1.2, 1]) |> angledLine(angle = 0, length = 17.2, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 29, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -1082,7 +998,7 @@ fn streamServer = (serverPos) => { const extrude001s = extrude(sketch001s, length = 7) const sketch002s = startSketchOn(planeXZs) - |> startProfileAt([-1, 4.114 + 1 + serverPos * 1.75], %) + |> startProfile(at = [-1, 4.114 + 1 + serverPos * 1.75]) |> yLine(length = 6.98) |> xLine(length = 0.2) |> yLine(length = -0.36) @@ -1106,7 +1022,7 @@ fn streamServer = (serverPos) => { const extrude002s = extrude(sketch002s, length = 1.8 / 2) const sketch003s = startSketchOn(planeXZs2) - |> startProfileAt([-1, 4.114 + 1 + serverPos * 1.75], %) + |> startProfile(at = [-1, 4.114 + 1 + serverPos * 1.75]) |> yLine(length = 6.98) |> xLine(length = 0.2) |> yLine(length = -0.36) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times-different-order.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times-different-order.kcl index bf353a9fc..59d3e62d9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times-different-order.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times-different-order.kcl @@ -1,5 +1,5 @@ const sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -15,14 +15,14 @@ const extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 50, tags = [seg02], tag = $seg04) const sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() const sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times.kcl index d9f031e1e..5e3dd3349 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch-on-chamfer-two-times.kcl @@ -1,5 +1,5 @@ const sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -15,14 +15,14 @@ const extrude001 = extrude(sketch001, length = 100) ) const sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() const sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl index 7035d701d..ae8324cda 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn(XY) - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) @@ -7,7 +7,7 @@ part001 = startSketchOn(XY) |> extrude(length = 5) part002 = startSketchOn(part001, face = here) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_after_fillets_referencing_face.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_after_fillets_referencing_face.kcl index cf6ced88d..894fc9c2e 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_after_fillets_referencing_face.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_after_fillets_referencing_face.kcl @@ -24,7 +24,7 @@ filletR = 0.25 // Sketch the bracket and extrude with fillets bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0], tag = $seg01) |> line(end = [0, -thickness]) @@ -46,7 +46,7 @@ bracket = startSketchOn(XY) ) sketch001 = startSketchOn(bracket, face = seg01) - |> startProfileAt([4.28, 3.83], %) + |> startProfile(at = [4.28, 3.83]) |> line(end = [2.17, -0.03]) |> line(end = [-0.07, -1.8]) |> line(end = [-2.07, 0.05]) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_circle_tagged.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_circle_tagged.kcl index bb84507cf..c88410fcb 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_circle_tagged.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_circle_tagged.kcl @@ -1,6 +1,6 @@ fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end.kcl index f5735b996..7cc419280 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end.kcl @@ -1,6 +1,6 @@ fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ const part001 = cube([0,0], 20) |> extrude(length = 20) const part002 = startSketchOn(part001, face = "END") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end_negative_extrude.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end_negative_extrude.kcl index 9c2a210da..18c57338a 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end_negative_extrude.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_end_negative_extrude.kcl @@ -1,6 +1,6 @@ fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ const part001 = cube([0,0], 20) |> extrude(length = 20) const part002 = startSketchOn(part001, face = "END") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_start.kcl b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_start.kcl index 915ab44fa..9b72d8c09 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_start.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face_start.kcl @@ -1,6 +1,6 @@ fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ const part001 = cube([0,0], 20) |> extrude(length = 20) const part002 = startSketchOn(part001, face = "start") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/e2e/executor/inputs/slow_lego.kcl.tmpl b/rust/kcl-lib/e2e/executor/inputs/slow_lego.kcl.tmpl index b9ffb2e31..d3f0578ce 100644 --- a/rust/kcl-lib/e2e/executor/inputs/slow_lego.kcl.tmpl +++ b/rust/kcl-lib/e2e/executor/inputs/slow_lego.kcl.tmpl @@ -27,7 +27,7 @@ const tubeFace = { } // Make the base const s = startSketchOn('XY') - |> startProfileAt([-totalWidth / 2, -totalLength / 2], %) + |> startProfile(at = [-totalWidth / 2, -totalLength / 2]) |> line([totalWidth, 0], %) |> line([0, totalLength], %) |> line([-totalWidth, 0], %) @@ -36,10 +36,10 @@ const s = startSketchOn('XY') // Sketch and extrude a rectangular shape to create the shell underneath the lego. This is a hack until we have a shell function. const shellExtrude = startSketchOn(s, "start") - |> startProfileAt([ + |> startProfile(at = [ -(totalWidth / 2 - t), -(totalLength / 2 - t) - ], %) + ]) |> line([totalWidth - (2 * t), 0], %) |> line([0, totalLength - (2 * t)], %) |> line([-(totalWidth - (2 * t)), 0], %) diff --git a/rust/kcl-lib/e2e/executor/inputs/tan_arc_x_line.kcl b/rust/kcl-lib/e2e/executor/inputs/tan_arc_x_line.kcl index 5da53aecd..e9af9582c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/tan_arc_x_line.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/tan_arc_x_line.kcl @@ -5,7 +5,7 @@ let r = 1 let angleStart = 110 startSketchOn(XY) - |> startProfileAt([startX, startY], %) + |> startProfile(at = [startX, startY]) |> angledLine( angle = angleStart, length = .000001, diff --git a/rust/kcl-lib/e2e/executor/inputs/tangential_arc.kcl b/rust/kcl-lib/e2e/executor/inputs/tangential_arc.kcl index 625c59e92..d65fc1f9a 100644 --- a/rust/kcl-lib/e2e/executor/inputs/tangential_arc.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/tangential_arc.kcl @@ -1,5 +1,5 @@ const boxSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> tangentialArc(radius = 5, angle = 90) |> line(end = [5, -15]) diff --git a/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl b/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl index 9a22c2cd8..9f5c6c6c0 100644 --- a/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl @@ -1,5 +1,5 @@ sketch002 = startSketchOn(XZ) - |> startProfileAt([-108.83, -57.48], %) + |> startProfile(at = [-108.83, -57.48]) |> angledLine(angle = 0, length = 105.13, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 77.9) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) diff --git a/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl b/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl index cc59d93e6..d4328996b 100644 --- a/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close() diff --git a/rust/kcl-lib/e2e/executor/main.rs b/rust/kcl-lib/e2e/executor/main.rs index dab58d075..bc78e1bc6 100644 --- a/rust/kcl-lib/e2e/executor/main.rs +++ b/rust/kcl-lib/e2e/executor/main.rs @@ -40,7 +40,7 @@ async fn kcl_test_fillet_duplicate_tags() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_execute_engine_error_return() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([5.5229, 5.25217], %) + |> startProfile(at = [5.5229, 5.25217]) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) |> line(end = [-1.02877, -6.76825]) @@ -157,7 +157,7 @@ async fn kcl_test_negative_args() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_basic_tangential_arc_with_point() { let code = r#"boxSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> tangentialArc(end = [-5, 5]) |> line(end = [5, -15]) @@ -171,7 +171,7 @@ async fn kcl_test_basic_tangential_arc_with_point() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_basic_tangential_arc_to() { let code = r#"boxSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> tangentialArc(endAbsolute = [-5, 15]) |> line(end = [5, -15]) @@ -190,7 +190,7 @@ length = 12 fn box = (sk1, sk2, scale, plane) => { boxsketch = startSketchOn(plane) - |> startProfileAt([sk1, sk2], %) + |> startProfile(at = [sk1, sk2]) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -222,7 +222,7 @@ shelfMountL = 9 wallMountL = 8 bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL]) |> tangentialArc(radius = filletR, angle = 90 ) |> line(end = [-shelfMountL, 0]) @@ -237,7 +237,7 @@ bracket = startSketchOn(XY) |> extrude(length = width) part001 = startSketchOn(XY) - |> startProfileAt([-15.53, -10.28], %) + |> startProfile(at = [-15.53, -10.28]) |> line(end = [10.49, -2.08]) |> line(end = [10.42, 8.47]) |> line(end = [-19.16, 5.1]) @@ -245,19 +245,19 @@ part001 = startSketchOn(XY) |> extrude(length = 4) part002 = startSketchOn('-XZ') - |> startProfileAt([-9.35, 19.18], %) + |> startProfile(at = [-9.35, 19.18]) |> line(end = [32.14, -2.47]) |> line(end = [8.39, -3.73]) |> close() part003 = startSketchOn('-XZ') - |> startProfileAt([13.82, 16.51], %) + |> startProfile(at = [13.82, 16.51]) |> line(end = [-6.24, -30.82]) |> line(end = [8.39, -3.73]) |> close() part004 = startSketchOn(YZ) - |> startProfileAt([19.04, 20.22], %) + |> startProfile(at = [19.04, 20.22]) |> line(end = [9.44, -30.16]) |> line(end = [8.39, -3.73]) |> close() @@ -270,7 +270,7 @@ part004 = startSketchOn(YZ) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_holes() { let code = r#"square = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -289,7 +289,7 @@ async fn optional_params() { let code = r#" fn other_circle = (pos, radius, tag?) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> arc(angleEnd = 360, angleStart = 0, radius = radius) |> close() |> extrude(length = 2) @@ -311,7 +311,7 @@ async fn kcl_test_rounded_with_holes() { fn roundedRectangle = (pos, w, l, cornerRadius) => { rr = startSketchOn(XY) - |> startProfileAt([pos[0] - w/2, 0], %) + |> startProfile(at = [pos[0] - w/2, 0]) |> line(endAbsolute = [pos[0] - w/2, pos[1] - l/2 + cornerRadius]) |> tarc([pos[0] - w/2 + cornerRadius, pos[1] - l/2], %, $arc0) |> line(endAbsolute = [pos[0] + w/2 - cornerRadius, pos[1] - l/2]) @@ -376,7 +376,7 @@ async fn kcl_test_patterns_linear_basic() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_linear_basic_3d() { let code = r#"part = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0,1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -420,7 +420,7 @@ async fn kcl_test_patterns_linear_basic_holes() { |> patternLinear2d(axis = [1,1], instances = 13, distance = 3) rectangle = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 50]) |> line(end = [50, 0]) |> line(end = [0, -50]) @@ -449,7 +449,7 @@ async fn kcl_test_patterns_circular_basic_2d() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_circular_basic_3d() { let code = r#"part = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0,1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -465,7 +465,7 @@ async fn kcl_test_patterns_circular_basic_3d() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_circular_3d_tilted_axis() { let code = r#"part = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0,1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -573,7 +573,7 @@ model = cube"#; async fn kcl_test_cube_mm() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -595,7 +595,7 @@ async fn kcl_test_cube_cm() { let code = r#"@settings(defaultLengthUnit = cm) fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -617,7 +617,7 @@ async fn kcl_test_cube_m() { let code = r#"@settings(defaultLengthUnit = m) fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -639,7 +639,7 @@ async fn kcl_test_cube_in() { let code = r#"@settings(defaultLengthUnit = in) fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -661,7 +661,7 @@ async fn kcl_test_cube_ft() { let code = r#"@settings(defaultLengthUnit = ft) fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -683,7 +683,7 @@ async fn kcl_test_cube_yd() { let code = r#"@settings(defaultLengthUnit = yd) fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -704,7 +704,7 @@ myCube = cube([0,0], 10) async fn kcl_test_error_sketch_on_arc_face() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> tangentialArc(end = [0, scale], tag = $here) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -716,7 +716,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = part001.sketch.tags.here) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 0]) |> line(end = [5, 5]) |> line(end = [0, 5]) @@ -740,7 +740,7 @@ part002 = startSketchOn(part001, face = part001.sketch.tags.here) async fn kcl_test_sketch_on_face_of_face() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -752,7 +752,7 @@ part001 = cube([0,0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -760,7 +760,7 @@ part002 = startSketchOn(part001, face = END) |> extrude(length = 5) part003 = startSketchOn(part002, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -775,7 +775,7 @@ part003 = startSketchOn(part002, face = END) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_stdlib_kcl_error_right_code_path() { let code = r#"square = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -800,7 +800,7 @@ async fn kcl_test_stdlib_kcl_error_right_code_path() { async fn kcl_test_sketch_on_face_circle() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -828,7 +828,7 @@ async fn kcl_test_stdlib_kcl_error_circle() { // Create a function that defines the body width and length of the mounting plate. Tag the corners so they can be passed through the fillet function. fn rectShape = (pos, w, l) => { rr = startSketchOn(XY) - |> startProfileAt([pos[0] - (w / 2), pos[1] - (l / 2)], %) + |> startProfile(at = [pos[0] - (w / 2), pos[1] - (l / 2)]) |> line(endAbsolute = [pos[0] + w / 2, pos[1] - (l / 2)], tag = $edge1) |> line(endAbsolute = [pos[0] + w / 2, pos[1] + l / 2], tag = $edge2) |> line(endAbsolute = [pos[0] - (w / 2), pos[1] + l / 2], tag = $edge3) @@ -872,7 +872,7 @@ part = rectShape([0, 0], 20, 20) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -892,7 +892,7 @@ async fn kcl_test_simple_revolve() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve_uppercase() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -912,7 +912,7 @@ async fn kcl_test_simple_revolve_uppercase() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve_negative() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -932,7 +932,7 @@ async fn kcl_test_simple_revolve_negative() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_bad_angle_low() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -958,7 +958,7 @@ async fn kcl_test_revolve_bad_angle_low() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_bad_angle_high() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -984,7 +984,7 @@ async fn kcl_test_revolve_bad_angle_high() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve_custom_angle() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -1004,7 +1004,7 @@ async fn kcl_test_simple_revolve_custom_angle() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve_custom_axis() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -1024,7 +1024,7 @@ async fn kcl_test_simple_revolve_custom_axis() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_edge() { let code = r#"box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $revolveAxis) @@ -1032,7 +1032,7 @@ async fn kcl_test_revolve_on_edge() { |> extrude(length = 10) sketch001 = startSketchOn(box, face = END) - |> startProfileAt([5, 10], %) + |> startProfile(at = [5, 10]) |> line(end = [0, -10]) |> line(end = [2, 0]) |> line(end = [0, 10]) @@ -1048,7 +1048,7 @@ sketch001 = startSketchOn(box, face = END) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_edge_get_edge() { let code = r#"box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $revolveAxis) @@ -1056,7 +1056,7 @@ async fn kcl_test_revolve_on_edge_get_edge() { |> extrude(length = 10) sketch001 = startSketchOn(box, face = revolveAxis) - |> startProfileAt([5, 10], %) + |> startProfile(at = [5, 10]) |> line(end = [0, -10]) |> line(end = [2, 0]) |> line(end = [0, 10]) @@ -1078,7 +1078,7 @@ sketch001 = startSketchOn(box, face = revolveAxis) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face_circle_edge() { let code = r#"box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $revolveAxis) @@ -1100,7 +1100,7 @@ sketch001 = startSketchOn(box, face = "END") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face_circle() { let code = r#"box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 20]) |> line(end = [20, 0], tag = $revolveAxis) |> line(end = [0, -20]) @@ -1122,7 +1122,7 @@ sketch001 = startSketchOn(box, face = "END") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face() { let code = r#"box = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -1130,7 +1130,7 @@ async fn kcl_test_revolve_on_face() { |> extrude(length = 10) sketch001 = startSketchOn(box, face = END) - |> startProfileAt([5, 10], %) + |> startProfile(at = [5, 10]) |> line(end = [0, -10]) |> line(end = [2, 0]) |> line(end = [0, 10]) @@ -1162,7 +1162,7 @@ async fn kcl_test_basic_revolve_circle() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve_sketch_on_edge() { let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) @@ -1174,7 +1174,7 @@ async fn kcl_test_simple_revolve_sketch_on_edge() { |> revolve(axis = Y, angle = 180) part002 = startSketchOn(part001, face = END) - |> startProfileAt([4.5, -5], %) + |> startProfile(at = [4.5, -5]) |> line(end = [0, 5]) |> line(end = [5, 0]) |> line(end = [0, -5]) @@ -1190,7 +1190,7 @@ part002 = startSketchOn(part001, face = END) async fn kcl_test_plumbus_fillets() { let code = r#"fn make_circle = (ext, face, pos, radius) => { sg = startSketchOn(ext, face = face) - |> startProfileAt([pos[0] + radius, pos[1]], %) + |> startProfile(at = [pos[0] + radius, pos[1]]) |> arc( angleEnd = 360, angleStart = 0, @@ -1204,7 +1204,7 @@ async fn kcl_test_plumbus_fillets() { fn pentagon = (len) => { sg = startSketchOn(XY) - |> startProfileAt([-len / 2, -len / 2], %) + |> startProfile(at = [-len / 2, -len / 2]) |> angledLine(angle = 0, length = len, tag = $a) |> angledLine( angle = segAng(a) + 180 - 108, @@ -1312,7 +1312,7 @@ filletR = 0.25 // Sketch the bracket and extrude with fillets bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0]) |> line(end = [0, -thickness]) @@ -1337,7 +1337,7 @@ bracket = startSketchOn(XY) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_error_empty_start_sketch_on_string() { let code = r#"part001 = startSketchOn('-XZ') - |> startProfileAt([75.75, 184.25], %) + |> startProfile(at = [75.75, 184.25]) |> line(end = [190.03, -118.13]) |> line(end = [-33.38, -202.86]) |> line(end = [-315.86, -64.2]) @@ -1368,7 +1368,7 @@ dia = 4 fn squareHole = (l, w) => { squareHoleSketch = startSketchOn(XY) - |> startProfileAt([-width / 2, -length / 2], %) + |> startProfile(at = [-width / 2, -length / 2]) |> line(endAbsolute = [width / 2, -length / 2]) |> line(endAbsolute = [width / 2, length / 2]) |> line(endAbsolute = [-width / 2, length / 2]) @@ -1395,7 +1395,7 @@ async fn kcl_test_array_of_sketches() { let code = r#"plane001 = startSketchOn(XZ) profile001 = plane001 - |> startProfileAt([40.82, 240.82], %) + |> startProfile(at = [40.82, 240.82]) |> line(end = [235.72, -8.16]) |> line(end = [13.27, -253.07]) |> line(end = [-247.97, -19.39]) @@ -1403,7 +1403,7 @@ profile001 = plane001 |> close() profile002 = plane001 - |> startProfileAt([47.17, -71.91], %) + |> startProfile(at = [47.17, -71.91]) |> line(end = [247.96, -4.03]) |> line(end = [-17.26, -116.79]) |> line(end = [-235.87, 12.66]) @@ -1424,7 +1424,7 @@ async fn kcl_test_circular_pattern3d_array_of_extrudes() { let code = r#"plane001 = startSketchOn(XZ) sketch001 = plane001 - |> startProfileAt([40.82, 240.82], %) + |> startProfile(at = [40.82, 240.82]) |> line(end = [235.72, -8.16]) |> line(end = [13.27, -253.07]) |> line(end = [-247.97, -19.39]) @@ -1433,7 +1433,7 @@ sketch001 = plane001 |> extrude(length = 10) sketch002 = plane001 - |> startProfileAt([47.17, -71.91], %) + |> startProfile(at = [47.17, -71.91]) |> line(end = [247.96, -4.03]) |> line(end = [-17.26, -116.79]) |> line(end = [-235.87, 12.66]) @@ -1475,7 +1475,7 @@ cornerFilletRad = 0.5 holeDia = 0.5 sketch001 = startSketchOn(XZ) - |> startProfileAt([-foot1Length, 0], %) + |> startProfile(at = [-foot1Length, 0]) |> line(end = [0, thickness], tag = $cornerFillet1) |> line(end = [foot1Length, 0]) |> line(end = [0, height], tag = $fillet1) @@ -1523,7 +1523,7 @@ cornerChamferRad = 0.5 holeDia = 0.5 sketch001 = startSketchOn(XZ) - |> startProfileAt([-foot1Length, 0], %) + |> startProfile(at = [-foot1Length, 0]) |> line(end = [0, thickness], tag = $cornerChamfer1) |> line(end = [foot1Length, 0]) |> line(end = [0, height], tag = $chamfer1) @@ -1555,7 +1555,7 @@ baseExtrusion = extrude(sketch001, length = width) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_shell_with_tag() { let code = r#"sketch001 = startSketchOn(XZ) - |> startProfileAt([61.74, 206.13], %) + |> startProfile(at = [61.74, 206.13]) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) |> xLine(length = -segLen(seg01)) @@ -1576,7 +1576,7 @@ async fn kcl_test_shell_with_tag() { async fn kcl_test_linear_pattern3d_filleted_sketch() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -1607,7 +1607,7 @@ pattn1 = patternLinear3d( async fn kcl_test_circular_pattern3d_filleted_sketch() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -1634,7 +1634,7 @@ pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], i async fn kcl_test_circular_pattern3d_chamfered_sketch() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -1660,7 +1660,7 @@ pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], i async fn kcl_test_tag_chamfer_with_more_than_one_edge_should_fail() { let code = r#"fn cube = (pos, scale) => { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -1694,7 +1694,7 @@ part001 = cube([0,0], 20) async fn kcl_test_duplicate_tags_should_error() { let code = r#"fn triangle = (len) => { return startSketchOn(XY) - |> startProfileAt([-len / 2, -len / 2], %) + |> startProfile(at = [-len / 2, -len / 2]) |> angledLine(angle = 0, length = len , tag = $a) |> angledLine( angle = segAng(a) + 120, @@ -1769,7 +1769,7 @@ async fn kcl_test_extrude_custom_plane() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_arc_error_same_start_end() { let code = r#"startSketchOn(XY) - |> startProfileAt([10, 0], %) + |> startProfile(at = [10, 0]) |> arc( angleStart = 180, angleEnd = 180, @@ -1793,7 +1793,7 @@ async fn kcl_test_arc_error_same_start_end() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_x_90() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 90, endAbsoluteX = 10) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -1813,7 +1813,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_x_270() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 270, endAbsoluteX = 10) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -1833,7 +1833,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_y_0() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 0, endAbsoluteY = 20) |> line(end = [-20, 0]) |> angledLine(angle = 70, endAbsoluteY = 10) @@ -1853,7 +1853,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_y_180() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 180, endAbsoluteY = 20) |> line(end = [-20, 0]) |> angledLine(angle = 70, endAbsoluteY = 10) @@ -1873,7 +1873,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_x_length_90() { let code = r#"sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 90, lengthX = 90, tag = $edge1) |> angledLine(angle = -15, lengthX = -15, tag = $edge2) |> line(end = [0, -5]) @@ -1893,7 +1893,7 @@ extrusion = extrude(sketch001, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_x_length_270() { let code = r#"sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 90, lengthX = 90, tag = $edge1) |> angledLine(angle = -15, lengthX = -15, tag = $edge2) |> line(end = [0, -5]) @@ -1913,7 +1913,7 @@ extrusion = extrude(sketch001, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_0() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = 0, lengthY = 10) |> line(end = [0, 10]) @@ -1935,7 +1935,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_180() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = 180, lengthY = 10) |> line(end = [0, 10]) @@ -1957,7 +1957,7 @@ example = extrude(exampleSketch, length = 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_negative_180() { let code = r#"exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> angledLine(angle = -180, lengthY = 10) |> line(end = [0, 10]) @@ -2017,7 +2017,7 @@ someFunction('INVALID') #[tokio::test(flavor = "multi_thread")] async fn kcl_test_error_no_auth_websocket() { let code = r#"const sketch001 = startSketchOn(XZ) - |> startProfileAt([61.74, 206.13], %) + |> startProfile(at = [61.74, 206.13]) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) |> xLine(length = -segLen(seg01)) @@ -2052,7 +2052,7 @@ length = 1 + 1 / 2 // create a sketch on the XY plane sketch000 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, innerDiameter / 2]) "#; diff --git a/rust/kcl-lib/src/execution/cache.rs b/rust/kcl-lib/src/execution/cache.rs index 5311b3a4d..25a6f2cab 100644 --- a/rust/kcl-lib/src/execution/cache.rs +++ b/rust/kcl-lib/src/execution/cache.rs @@ -249,7 +249,7 @@ mod tests { async fn test_get_changed_program_same_code() { let new = r#"// Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -280,7 +280,7 @@ shell(firstSketch, faces = [END], thickness = 0.25)"#; async fn test_get_changed_program_same_code_changed_whitespace() { let old = r#" // Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -292,7 +292,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) "#; let new = r#"// Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -325,7 +325,7 @@ shell(firstSketch, faces = [END], thickness = 0.25)"#; async fn test_get_changed_program_same_code_changed_code_comment_start_of_program() { let old = r#" // Removed the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -337,7 +337,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) "#; let new = r#"// Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -372,7 +372,7 @@ shell(firstSketch, faces = [END], thickness = 0.25)"#; @bar // Removed the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) // my thing @@ -386,7 +386,7 @@ shell(firstSketch, faces = [END], thickness = 0.25) "#; @baz // Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -420,7 +420,7 @@ shell(firstSketch, faces = [END], thickness = 0.25)"#; async fn test_get_changed_program_same_code_but_different_grid_setting() { let new = r#"// Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -457,7 +457,7 @@ shell(firstSketch, faces = [END], thickness = 0.25)"#; async fn test_get_changed_program_same_code_but_different_edge_visiblity_setting() { let new = r#"// Remove the end face for the extrusion. firstSketch = startSketchOn('XY') - |> startProfileAt([-12, 12], %) + |> startProfile(at = [-12, 12]) |> line(end = [24, 0]) |> line(end = [0, -24]) |> line(end = [-24, 0]) @@ -608,7 +608,7 @@ startSketchOn('XY') importedCube sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([-134.53, -56.17], sketch001) +profile001 = startProfile(sketch001, at = [-134.53, -56.17]) |> angledLine(angle = 0, length = 79.05, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 76.28) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $seg01) @@ -622,7 +622,7 @@ sketch002 = startSketchOn(extrude001, face = seg01) let other_file = ( std::path::PathBuf::from("toBeImported.kcl"), r#"sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([281.54, 305.81], sketch001) +profile001 = startProfile(sketch001, at = [281.54, 305.81]) |> angledLine(angle = 0, length = 123.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 85.99) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) diff --git a/rust/kcl-lib/src/execution/mod.rs b/rust/kcl-lib/src/execution/mod.rs index b46ccccb9..bf42c8d40 100644 --- a/rust/kcl-lib/src/execution/mod.rs +++ b/rust/kcl-lib/src/execution/mod.rs @@ -1295,7 +1295,7 @@ yo = 5 + 6 abc = 3 identifierGuy = 5 part001 = startSketchOn(XY) -|> startProfileAt([-1.2, 4.83], %) +|> startProfile(at = [-1.2, 4.83]) |> line(end = [2.8, 0]) |> angledLine(angle = 100 + 100, length = 3.01) |> angledLine(angle = abc, length = 3.02) @@ -1312,7 +1312,7 @@ yo2 = hmm([identifierGuy + 5])"#; async fn test_execute_with_pipe_substitutions_unary() { let ast = r#"const myVar = 3 const part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3, 4], tag = $seg01) |> line(end = [ min(segLen(seg01), myVar), @@ -1327,7 +1327,7 @@ const part001 = startSketchOn(XY) async fn test_execute_with_pipe_substitutions() { let ast = r#"const myVar = 3 const part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3, 4], tag = $seg01) |> line(end = [ min(segLen(seg01), myVar), @@ -1350,7 +1350,7 @@ const arrExpShouldNotBeIncluded = [1, 2, 3] const objExpShouldNotBeIncluded = { a: 1, b: 2, c: 3 } const part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(endAbsolute = 1) |> xLine(length = 3.84) // selection-range-7ish-before-this @@ -1371,7 +1371,7 @@ fn thing = () => { } const firstExtrude = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, thing()]) @@ -1392,7 +1392,7 @@ fn thing = (x) => { } const firstExtrude = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, thing(8)]) @@ -1413,7 +1413,7 @@ fn thing = (x) => { } const firstExtrude = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = thing(8)) @@ -1438,7 +1438,7 @@ fn thing = (x) => { } const firstExtrude = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, thing(8)]) @@ -1452,7 +1452,7 @@ const firstExtrude = startSketchOn(XY) async fn test_execute_with_function_sketch() { let ast = r#"fn box = (h, l, w) => { const myBox = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) @@ -1471,7 +1471,7 @@ const fnBox = box(3, 6, 10)"#; async fn test_get_member_of_object_with_function_period() { let ast = r#"fn box = (obj) => { let myBox = startSketchOn(XY) - |> startProfileAt(obj.start, %) + |> startProfile(at = obj.start) |> line(end = [0, obj.l]) |> line(end = [obj.w, 0]) |> line(end = [0, -obj.l]) @@ -1490,7 +1490,7 @@ const thisBox = box({start: [0,0], l: 6, w: 10, h: 3}) async fn test_get_member_of_object_with_function_brace() { let ast = r#"fn box = (obj) => { let myBox = startSketchOn(XY) - |> startProfileAt(obj["start"], %) + |> startProfile(at = obj["start"]) |> line(end = [0, obj["l"]]) |> line(end = [obj["w"], 0]) |> line(end = [0, -obj["l"]]) @@ -1509,7 +1509,7 @@ const thisBox = box({start: [0,0], l: 6, w: 10, h: 3}) async fn test_get_member_of_object_with_function_mix_period_brace() { let ast = r#"fn box = (obj) => { let myBox = startSketchOn(XY) - |> startProfileAt(obj["start"], %) + |> startProfile(at = obj["start"]) |> line(end = [0, obj["l"]]) |> line(end = [obj["w"], 0]) |> line(end = [10 - obj["w"], -obj.l]) @@ -1531,7 +1531,7 @@ const thisBox = box({start: [0,0], l: 6, w: 10, h: 3}) fn test2 = () => { return { thing: startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -1552,7 +1552,7 @@ x2.thing async fn test_execute_with_function_sketch_loop_objects() { let ast = r#"fn box = (obj) => { let myBox = startSketchOn(XY) - |> startProfileAt(obj.start, %) + |> startProfile(at = obj.start) |> line(end = [0, obj.l]) |> line(end = [obj.w, 0]) |> line(end = [0, -obj.l]) @@ -1574,7 +1574,7 @@ for var in [{start: [0,0], l: 6, w: 10, h: 3}, {start: [-10,-10], l: 3, w: 5, h: async fn test_execute_with_function_sketch_loop_array() { let ast = r#"fn box = (h, l, w, start) => { const myBox = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) @@ -1596,7 +1596,7 @@ for var in [[3, 6, 10, [0,0]], [1.5, 3, 5, [-10,-10]]] { async fn test_get_member_of_array_with_function() { let ast = r#"fn box = (arr) => { let myBox =startSketchOn(XY) - |> startProfileAt(arr[0], %) + |> startProfile(at = arr[0]) |> line(end = [0, arr[1]]) |> line(end = [arr[2], 0]) |> line(end = [0, -arr[1]]) @@ -1850,7 +1850,7 @@ const leg2 = 8 // inches fn thickness = () => { return 0.56 } const bracket = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness()]) @@ -2061,7 +2061,7 @@ const thickness_squared = distance * p * FOS * 6 / sigmaAllow const thickness = 0.56 // inches. App does not support square root function yet const bracket = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) @@ -2095,7 +2095,7 @@ const leg2 = 8 // inches const thickness_squared = (distance * p * FOS * 6 / (sigmaAllow - width)) const thickness = 0.32 // inches. App does not support square root function yet const bracket = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) @@ -2119,7 +2119,7 @@ const leg2 = 8 // inches const thickness_squared = distance * p * FOS * 6 / (sigmaAllow - width) const thickness = 0.32 // inches. App does not support square root function yet const bracket = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) @@ -2145,7 +2145,7 @@ let w = f() + f() #[tokio::test(flavor = "multi_thread")] async fn kcl_test_ids_stable_between_executions() { let code = r#"sketch001 = startSketchOn(XZ) -|> startProfileAt([61.74, 206.13], %) +|> startProfile(at = [61.74, 206.13]) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) |> xLine(length = -segLen(seg01)) @@ -2172,7 +2172,7 @@ let w = f() + f() let id_generator = cache::read_old_ast().await.unwrap().exec_state.mod_local.id_generator; let code = r#"sketch001 = startSketchOn(XZ) -|> startProfileAt([62.74, 206.13], %) +|> startProfile(at = [62.74, 206.13]) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) |> xLine(length = -segLen(seg01)) @@ -2198,7 +2198,7 @@ let w = f() + f() #[tokio::test(flavor = "multi_thread")] async fn kcl_test_changing_a_setting_updates_the_cached_state() { let code = r#"sketch001 = startSketchOn('XZ') -|> startProfileAt([61.74, 206.13], %) +|> startProfile(at = [61.74, 206.13]) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) |> xLine(length = -segLen(seg01)) @@ -2267,7 +2267,7 @@ let w = f() + f() async fn read_tag_version() { let ast = r#"fn bar(t) { return startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> angledLine( angle = -60, length = segLen(t), @@ -2277,7 +2277,7 @@ let w = f() + f() } sketch = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10]) |> line(end = [10, 0], tag = $tag0) |> line(end = [0, 0]) @@ -2290,7 +2290,7 @@ fn foo() { solid = sketch |> extrude(length = 10) // tag0 tags a face sketch2 = startSketchOn(solid, face = tag0) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, 0]) diff --git a/rust/kcl-lib/src/lint/checks/camel_case.rs b/rust/kcl-lib/src/lint/checks/camel_case.rs index 14f76856e..366da912a 100644 --- a/rust/kcl-lib/src/lint/checks/camel_case.rs +++ b/rust/kcl-lib/src/lint/checks/camel_case.rs @@ -101,7 +101,7 @@ const thickness = 0.5 // Create the sketch to be revolved around the y-axis. Use the small diameter, large diameter, length, and thickness to define the sketch. const Part001 = startSketchOn('XY') - |> startProfileAt([pipeLargeDia - (thickness / 2), 38], %) + |> startProfile(at = [pipeLargeDia - (thickness / 2), 38]) |> line([thickness, 0], %) |> line([0, -1], %) |> angledLine(angle = 60, endAbsoluteX = pipeSmallDia + thickness) @@ -131,7 +131,7 @@ const thickness = 0.5 // Create the sketch to be revolved around the y-axis. Use the small diameter, large diameter, length, and thickness to define the sketch. const part001 = startSketchOn('XY') - |> startProfileAt([pipeLargeDia - (thickness / 2), 38], %) + |> startProfile(at = [pipeLargeDia - (thickness / 2), 38]) |> line([thickness, 0], %) |> line([0, -1], %) |> angledLine(angle = 60, endAbsoluteX = pipeSmallDia + thickness) diff --git a/rust/kcl-lib/src/lint/checks/std_lib_args.rs b/rust/kcl-lib/src/lint/checks/std_lib_args.rs index a23c7ba17..c9cb5171e 100644 --- a/rust/kcl-lib/src/lint/checks/std_lib_args.rs +++ b/rust/kcl-lib/src/lint/checks/std_lib_args.rs @@ -101,7 +101,7 @@ const filletR = 0.25 // Sketch the bracket and extrude with fillets const bracket = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line([0, wallMountL], %, $outerEdge) |> line([-shelfMountL, 0], %) |> line([0, -thickness], %) @@ -148,7 +148,7 @@ const filletR = 0.25 // Sketch the bracket and extrude with fillets const bracket = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line([0, wallMountL], %, $outerEdge) |> line([-shelfMountL, 0], %) |> line([0, -thickness], %) diff --git a/rust/kcl-lib/src/lsp/copilot/mod.rs b/rust/kcl-lib/src/lsp/copilot/mod.rs index 781bda560..5ef8d380d 100644 --- a/rust/kcl-lib/src/lsp/copilot/mod.rs +++ b/rust/kcl-lib/src/lsp/copilot/mod.rs @@ -264,7 +264,7 @@ impl Backend { completion_list.push( r#"fn cube = (pos, scale) => { const sg = startSketchOn('XY') - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line([0, scale], %) |> line([scale, 0], %) |> line([0, -scale], %) diff --git a/rust/kcl-lib/src/lsp/tests.rs b/rust/kcl-lib/src/lsp/tests.rs index eb93cded8..5860c6ff6 100644 --- a/rust/kcl-lib/src/lsp/tests.rs +++ b/rust/kcl-lib/src/lsp/tests.rs @@ -727,7 +727,7 @@ async fn test_kcl_lsp_completions_tags() { language_id: "kcl".to_string(), version: 1, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) @@ -897,7 +897,7 @@ fn bar(x: string): string { bar("an arg") startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) "# @@ -1219,7 +1219,7 @@ async fn test_kcl_lsp_semantic_tokens_with_modifiers() { language_id: "kcl".to_string(), version: 1, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0]) @@ -1521,7 +1521,7 @@ async fn test_kcl_lsp_document_symbol_tag() { language_id: "kcl".to_string(), version: 1, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) @@ -1567,7 +1567,7 @@ async fn test_kcl_lsp_formatting() { language_id: "kcl".to_string(), version: 1, text: r#"startSketchOn(XY) - |> startProfileAt([0,0], %)"# + |> startProfile(at = [0,0])"# .to_string(), }, }) @@ -1598,7 +1598,7 @@ async fn test_kcl_lsp_formatting() { assert_eq!( formatting[0].new_text, r#"startSketchOn(XY) - |> startProfileAt([0, 0], %)"# + |> startProfile(at = [0, 0])"# ); } @@ -1624,7 +1624,7 @@ overHangLength = .4 // Sketch and revolve the inside bearing piece insideRevolve = startSketchOn(XZ) - |> startProfileAt([insideDia / 2, 0], %) + |> startProfile(at = [insideDia / 2, 0]) |> line(end = [0, thickness + sphereDia / 2]) |> line(end = [overHangLength, 0]) |> line(end = [0, -thickness]) @@ -1638,10 +1638,7 @@ insideRevolve = startSketchOn(XZ) // Sketch and revolve one of the balls and duplicate it using a circular pattern. (This is currently a workaround, we have a bug with rotating on a sketch that touches the rotation axis) sphere = startSketchOn(XZ) - |> startProfileAt([ - 0.05 + insideDia / 2 + thickness, - 0 - 0.05 - ], %) + |> startProfile(at = [0.05 + insideDia / 2 + thickness, 0 - 0.05]) |> line(end = [sphereDia - 0.1, 0]) |> arc(angle_start = 0, angle_end = -180, radius = sphereDia / 2 - 0.05) |> close() @@ -1656,10 +1653,7 @@ sphere = startSketchOn(XZ) // Sketch and revolve the outside bearing outsideRevolve = startSketchOn(XZ) - |> startProfileAt([ - insideDia / 2 + thickness + sphereDia, - 0 - ], %) + |> startProfile(at = [insideDia / 2 + thickness + sphereDia, 0]) |> line(end = [0, sphereDia / 2]) |> line(end = [-overHangLength + thickness, 0]) |> line(end = [0, thickness]) @@ -1702,7 +1696,7 @@ outsideRevolve = startSketchOn(XZ) tower_lsp::lsp_types::Range { start: tower_lsp::lsp_types::Position { line: 0, character: 0 }, end: tower_lsp::lsp_types::Position { - line: 56, + line: 50, character: 29 } } @@ -1720,7 +1714,7 @@ overHangLength = .4 // Sketch and revolve the inside bearing piece insideRevolve = startSketchOn(XZ) - |> startProfileAt([insideDia / 2, 0], %) + |> startProfile(at = [insideDia / 2, 0]) |> line(end = [0, thickness + sphereDia / 2]) |> line(end = [overHangLength, 0]) |> line(end = [0, -thickness]) @@ -1734,10 +1728,10 @@ insideRevolve = startSketchOn(XZ) // Sketch and revolve one of the balls and duplicate it using a circular pattern. (This is currently a workaround, we have a bug with rotating on a sketch that touches the rotation axis) sphere = startSketchOn(XZ) - |> startProfileAt([ + |> startProfile(at = [ 0.05 + insideDia / 2 + thickness, 0 - 0.05 - ], %) + ]) |> line(end = [sphereDia - 0.1, 0]) |> arc(angle_start = 0, angle_end = -180, radius = sphereDia / 2 - 0.05) |> close() @@ -1752,10 +1746,10 @@ sphere = startSketchOn(XZ) // Sketch and revolve the outside bearing outsideRevolve = startSketchOn(XZ) - |> startProfileAt([ + |> startProfile(at = [ insideDia / 2 + thickness + sphereDia, 0 - ], %) + ]) |> line(end = [0, sphereDia / 2]) |> line(end = [-overHangLength + thickness, 0]) |> line(end = [0, thickness]) @@ -2002,7 +1996,7 @@ async fn test_copilot_lsp_completions_raw() { .get_completions( "kcl".to_string(), r#"bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) "# .to_string(), r#" |> close() @@ -2021,7 +2015,7 @@ async fn test_copilot_lsp_completions_raw() { .get_completions( "kcl".to_string(), r#"bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) "# .to_string(), r#" |> close() @@ -2061,7 +2055,7 @@ async fn test_copilot_lsp_completions() { position: crate::lsp::copilot::types::CopilotPosition { line: 3, character: 3 }, relative_path: "test.copilot".to_string(), source: r#"bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> close() |> extrude(length = 10) @@ -2385,7 +2379,7 @@ async fn kcl_test_kcl_lsp_diagnostics_on_execution_error() { language_id: "kcl".to_string(), version: 1, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2406,7 +2400,7 @@ async fn kcl_test_kcl_lsp_diagnostics_on_execution_error() { // Update the text. let new_text = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2446,7 +2440,7 @@ async fn kcl_test_kcl_lsp_full_to_empty_file_updates_ast_and_memory() { language_id: "kcl".to_string(), version: 1, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2491,7 +2485,7 @@ async fn kcl_test_kcl_lsp_code_unchanged_but_has_diagnostics_reexecute() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2579,7 +2573,7 @@ async fn kcl_test_kcl_lsp_code_and_ast_unchanged_but_has_diagnostics_reexecute() let server = kcl_lsp_server(true).await.unwrap(); let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2656,7 +2650,7 @@ async fn kcl_test_kcl_lsp_cant_execute_set() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2737,7 +2731,7 @@ async fn test_kcl_lsp_folding() { language_id: "kcl".to_string(), version: 1, text: r#"startSketchOn(XY) - |> startProfileAt([0,0], %)"# + |> startProfile(at = [0,0])"# .to_string(), }, }) @@ -2776,7 +2770,7 @@ async fn kcl_test_kcl_lsp_code_with_parse_error_and_ast_unchanged_but_has_diagno let server = kcl_lsp_server(false).await.unwrap(); let code = r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2831,7 +2825,7 @@ async fn kcl_test_kcl_lsp_code_with_lint_and_ast_unchanged_but_has_diagnostics_r let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2885,7 +2879,7 @@ async fn kcl_test_kcl_lsp_code_with_lint_and_parse_error_and_ast_unchanged_but_h let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -2940,7 +2934,7 @@ async fn kcl_test_kcl_lsp_code_lint_and_ast_unchanged_but_has_diagnostics_reexec let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0], tag = $seg01) @@ -3001,7 +2995,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_new_lint() { let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0], tag = $seg01) @@ -3040,7 +3034,7 @@ part001 = startSketchOn(XY) range: None, range_length: None, text: r#"part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0], tag = $seg01) @@ -3070,7 +3064,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_new_ast_error() { let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0], tag = $seg01) @@ -3109,7 +3103,7 @@ part001 = startSketchOn(XY) range: None, range_length: None, text: r#"part001 = startSketchOn(XY) - |> ^^^^startProfileAt([-10, -10], %) + |> ^^^^startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0], tag = $seg01) @@ -3139,7 +3133,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_had_lint_new_parse_error() { let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -3186,7 +3180,7 @@ part001 = startSketchOn(XY) range: None, range_length: None, text: r#"part001 = startSketchOn(XY) - |> ^^^^startProfileAt([-10, -10], %) + |> ^^^^startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -3224,7 +3218,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_had_lint_new_execution_error() { let code = r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0]) |> line(end = [0, 20]) |> line(end = [-20, 0]) @@ -3276,7 +3270,7 @@ part001 = startSketchOn(XY) range_length: None, text: r#"LINT = 1 part001 = startSketchOn(XY) - |> startProfileAt([-10, -10], %) + |> startProfile(at = [-10, -10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, 20], tag = $seg01) |> line(end = [-20, 0]) @@ -3433,7 +3427,7 @@ fn bar(x: string): string { bar("an arg") startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) "# diff --git a/rust/kcl-lib/src/parsing/ast/digest.rs b/rust/kcl-lib/src/parsing/ast/digest.rs index 5c6a86f2d..91cd11a9f 100644 --- a/rust/kcl-lib/src/parsing/ast/digest.rs +++ b/rust/kcl-lib/src/parsing/ast/digest.rs @@ -528,13 +528,13 @@ mod test { #[tokio::test(flavor = "multi_thread")] async fn test_parse_digest() { let prog1_string = r#"startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line([5, 5], %) "#; let prog1_digest = crate::parsing::top_level_parse(prog1_string).unwrap().compute_digest(); let prog2_string = r#"startSketchOn('XY') - |> startProfileAt([0, 2], %) + |> startProfile(at = [0, 2]) |> line([5, 5], %) "#; let prog2_digest = crate::parsing::top_level_parse(prog2_string).unwrap().compute_digest(); @@ -542,7 +542,7 @@ mod test { assert!(prog1_digest != prog2_digest); let prog3_string = r#"startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line([5, 5], %) "#; let prog3_digest = crate::parsing::top_level_parse(prog3_string).unwrap().compute_digest(); diff --git a/rust/kcl-lib/src/parsing/ast/types/mod.rs b/rust/kcl-lib/src/parsing/ast/types/mod.rs index 70c090b58..dd070bc7f 100644 --- a/rust/kcl-lib/src/parsing/ast/types/mod.rs +++ b/rust/kcl-lib/src/parsing/ast/types/mod.rs @@ -3624,11 +3624,11 @@ mod tests { #[test] fn test_get_lsp_folding_ranges() { let code = r#"const part001 = startSketchOn(XY) - |> startProfileAt([0.0000000000, 5.0000000000], %) + |> startProfile(at = [0.0000000000, 5.0000000000]) |> line([0.4900857016, -0.0240763666], %) startSketchOn(XY) - |> startProfileAt([0.0000000000, 5.0000000000], %) + |> startProfile(at = [0.0000000000, 5.0000000000]) |> line([0.4900857016, -0.0240763666], %) const part002 = "part002" @@ -3663,7 +3663,7 @@ ghi("things") #[test] fn test_get_lsp_symbols() { let code = r#"const part001 = startSketchOn('XY') - |> startProfileAt([0.0000000000, 5.0000000000], %) + |> startProfile(at = [0.0000000000, 5.0000000000]) |> line([0.4900857016, -0.0240763666], %) const part002 = "part002" @@ -3688,7 +3688,7 @@ const h = 30 // st const cylinder = startSketchOn('-XZ') - |> startProfileAt([50, 0], %) + |> startProfile(at = [50, 0]) |> arc({ angle_end: 360, angle_start: 0, @@ -3708,7 +3708,7 @@ const h = 30 // st const cylinder = startSketchOn('-XZ') - |> startProfileAt([50, 0], %) + |> startProfile(at = [50, 0]) // comment |> arc({ angle_end: 360, @@ -3725,7 +3725,7 @@ const cylinder = startSketchOn('-XZ') #[test] fn test_ast_in_comment_inline() { let some_program_string = r#"const part001 = startSketchOn('XY') - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> xLine(length = 5) // lin "#; let program = crate::parsing::top_level_parse(some_program_string).unwrap(); diff --git a/rust/kcl-lib/src/parsing/parser.rs b/rust/kcl-lib/src/parsing/parser.rs index 2f11cb7e2..869a4d777 100644 --- a/rust/kcl-lib/src/parsing/parser.rs +++ b/rust/kcl-lib/src/parsing/parser.rs @@ -3340,7 +3340,7 @@ comment */ /* comment at start */ mySk1 = startSketchOn(XY) - |> startProfileAt([0, 0], %)"#; + |> startProfile(at = [0, 0])"#; let tokens = crate::parsing::token::lex(test_program, ModuleId::default()).unwrap(); let program = program.parse(tokens.as_slice()).unwrap(); let mut starting_comments = program.inner.non_code_meta.start_nodes; diff --git a/rust/kcl-lib/src/std/appearance.rs b/rust/kcl-lib/src/std/appearance.rs index 82f2621ab..641417e16 100644 --- a/rust/kcl-lib/src/std/appearance.rs +++ b/rust/kcl-lib/src/std/appearance.rs @@ -81,7 +81,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(endAbsolute = [10, 0]) /// |> line(endAbsolute = [0, 10]) /// |> line(endAbsolute = [-10, 0]) @@ -108,7 +108,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - 10, center[1] - 10], %) +/// |> startProfile(at = [center[0] - 10, center[1] - 10]) /// |> line(endAbsolute = [center[0] + 10, center[1] - 10]) /// |> line(endAbsolute = [center[0] + 10, center[1] + 10]) /// |> line(endAbsolute = [center[0] - 10, center[1] + 10]) @@ -128,7 +128,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -151,7 +151,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -174,7 +174,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 2]) /// |> line(end = [3, 1]) /// |> line(end = [0, -4]) @@ -197,7 +197,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 2]) /// |> line(end = [3, 1]) /// |> line(end = [0, -4]) @@ -219,7 +219,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([.5, 25], %) +/// |> startProfile(at = [.5, 25]) /// |> line(end = [0, 5]) /// |> line(end = [-1, 0]) /// |> line(end = [0, -5]) @@ -244,7 +244,7 @@ pub async fn appearance(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) diff --git a/rust/kcl-lib/src/std/args.rs b/rust/kcl-lib/src/std/args.rs index 516dfd7c2..3fac8aa16 100644 --- a/rust/kcl-lib/src/std/args.rs +++ b/rust/kcl-lib/src/std/args.rs @@ -659,10 +659,6 @@ impl Args { Ok((sketches, sketch)) } - pub(crate) fn get_data_and_sketch_surface(&self) -> Result<([TyF64; 2], SketchSurface, Option), KclError> { - FromArgs::from_args(self, 0) - } - pub(crate) async fn get_adjacent_face_to_tag( &self, exec_state: &mut ExecState, diff --git a/rust/kcl-lib/src/std/array.rs b/rust/kcl-lib/src/std/array.rs index 28f2b65a0..476b88783 100644 --- a/rust/kcl-lib/src/std/array.rs +++ b/rust/kcl-lib/src/std/array.rs @@ -138,7 +138,7 @@ pub async fn reduce(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([(cos(0)*radius), (sin(0) * radius)], %) +/// |> startProfile(at = [(cos(0)*radius), (sin(0) * radius)]) /// /// // Use a `reduce` to draw the remaining decagon sides. /// // For each number in the array 1..10, run the given function, @@ -159,7 +159,7 @@ pub async fn reduce(exec_state: &mut ExecState, args: Args) -> Result Result startProfileAt([-width/2, -length/2], %) +/// |> startProfile(at = [-width/2, -length/2]) /// |> line(endAbsolute = [width/2, -length/2], tag = $edge1) /// |> line(endAbsolute = [width/2, length/2], tag = $edge2) /// |> line(endAbsolute = [-width/2, length/2], tag = $edge3) @@ -68,7 +68,7 @@ pub async fn chamfer(exec_state: &mut ExecState, args: Args) -> Result startProfileAt(pos, %) +/// |> startProfile(at = pos) /// |> line(end = [0, scale]) /// |> line(end = [scale, 0]) /// |> line(end = [0, -scale]) @@ -87,7 +87,7 @@ pub async fn chamfer(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([10, 10], %) +/// |> startProfile(at = [10, 10]) /// |> line(end = [2, 0]) /// |> line(end = [0, 2]) /// |> line(end = [-2, 0]) diff --git a/rust/kcl-lib/src/std/clone.rs b/rust/kcl-lib/src/std/clone.rs index ba52ec386..5911cea99 100644 --- a/rust/kcl-lib/src/std/clone.rs +++ b/rust/kcl-lib/src/std/clone.rs @@ -54,7 +54,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -78,7 +78,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -95,7 +95,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-10, 10], %) +/// |> startProfile(at = [-10, 10]) /// |> xLine(length = 20) /// |> yLine(length = -20) /// |> xLine(length = -20) @@ -112,7 +112,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-10, 10], %) +/// |> startProfile(at = [-10, 10]) /// |> xLine(length = 20) /// |> yLine(length = -20) /// |> xLine(length = -20, tag = $filletTag) @@ -132,7 +132,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10], tag = $sketchingFace) /// |> line(end = [-10, 0]) @@ -143,7 +143,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result extrude(length = 5) /// /// startSketchOn(sketch002, face = sketchingFace) -/// |> startProfileAt([1, 1], %) +/// |> startProfile(at = [1, 1]) /// |> line(end = [8, 0]) /// |> line(end = [0, 8]) /// |> line(end = [-8, 0]) @@ -160,7 +160,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-width/2, -length/2], %) +/// |> startProfile(at = [-width/2, -length/2]) /// |> line(endAbsolute = [width/2, -length/2], tag = $edge1) /// |> line(endAbsolute = [width/2, length/2], tag = $edge2) /// |> line(endAbsolute = [-width/2, length/2], tag = $edge3) @@ -222,7 +222,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -239,7 +239,7 @@ pub async fn clone(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4.5, -5], %) +/// // |> startProfile(at = [4.5, -5]) /// // |> line(end = [0, 5]) /// // |> line(end = [5, 0]) /// // |> line(end = [0, -5]) @@ -520,7 +520,7 @@ mod tests { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_clone_sketch() { let code = r#"cube = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -568,7 +568,7 @@ clonedCube = clone(cube) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_clone_solid() { let code = r#"cube = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -627,7 +627,7 @@ clonedCube = clone(cube) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_clone_sketch_with_tags() { let code = r#"cube = startSketchOn(XY) - |> startProfileAt([0,0], %) // tag this one + |> startProfile(at = [0,0]) // tag this one |> line(end = [0, 10], tag = $tag02) |> line(end = [10, 0], tag = $tag03) |> line(end = [0, -10], tag = $tag04) @@ -682,7 +682,7 @@ clonedCube = clone(cube) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_clone_solid_with_tags() { let code = r#"cube = startSketchOn(XY) - |> startProfileAt([0,0], %) // tag this one + |> startProfile(at = [0,0]) // tag this one |> line(end = [0, 10], tag = $tag02) |> line(end = [10, 0], tag = $tag03) |> line(end = [0, -10], tag = $tag04) @@ -751,7 +751,7 @@ clonedCube = clone(cube) let code = r#"// Clone a basic solid and move it. exampleSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [10, 0]) |> line(end = [0, 10]) |> line(end = [-10, 0]) @@ -826,7 +826,7 @@ clonedCube = clone(cube) #[ignore = "this test is not working yet, need to fix the edge cut ids"] async fn kcl_test_clone_solid_with_edge_cuts() { let code = r#"cube = startSketchOn(XY) - |> startProfileAt([0,0], %) // tag this one + |> startProfile(at = [0,0]) // tag this one |> line(end = [0, 10], tag = $tag02) |> line(end = [10, 0], tag = $tag03) |> line(end = [0, -10], tag = $tag04) diff --git a/rust/kcl-lib/src/std/csg.rs b/rust/kcl-lib/src/std/csg.rs index 5a9445f79..45010e9f6 100644 --- a/rust/kcl-lib/src/std/csg.rs +++ b/rust/kcl-lib/src/std/csg.rs @@ -42,7 +42,7 @@ pub async fn union(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -64,7 +64,7 @@ pub async fn union(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -87,7 +87,7 @@ pub async fn union(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -192,7 +192,7 @@ pub async fn intersect(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -214,7 +214,7 @@ pub async fn intersect(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -325,7 +325,7 @@ pub async fn subtract(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) @@ -347,7 +347,7 @@ pub async fn subtract(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([center[0] - size, center[1] - size], %) +/// |> startProfile(at = [center[0] - size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] - size]) /// |> line(endAbsolute = [center[0] + size, center[1] + size]) /// |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/src/std/edge.rs b/rust/kcl-lib/src/std/edge.rs index 39b5e2093..eb6369a15 100644 --- a/rust/kcl-lib/src/std/edge.rs +++ b/rust/kcl-lib/src/std/edge.rs @@ -27,7 +27,7 @@ pub async fn get_opposite_edge(exec_state: &mut ExecState, args: Args) -> Result /// /// ```no_run /// exampleSketch = startSketchOn('XZ') -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> angledLine( /// angle = 60, @@ -110,7 +110,7 @@ pub async fn get_next_adjacent_edge(exec_state: &mut ExecState, args: Args) -> R /// /// ```no_run /// exampleSketch = startSketchOn('XZ') -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> angledLine( /// angle = 60, @@ -202,7 +202,7 @@ pub async fn get_previous_adjacent_edge(exec_state: &mut ExecState, args: Args) /// /// ```no_run /// exampleSketch = startSketchOn('XZ') -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> angledLine( /// angle = 60, @@ -296,7 +296,7 @@ pub async fn get_common_edge(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, scale]) /// |> line(end = [scale, 0]) /// |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/src/std/extrude.rs b/rust/kcl-lib/src/std/extrude.rs index 9e8c032aa..582ea9802 100644 --- a/rust/kcl-lib/src/std/extrude.rs +++ b/rust/kcl-lib/src/std/extrude.rs @@ -62,7 +62,7 @@ pub async fn extrude(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> arc( /// angleStart = 120, @@ -83,7 +83,7 @@ pub async fn extrude(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-10, 0], %) +/// |> startProfile(at = [-10, 0]) /// |> arc( /// angleStart = 120, /// angleEnd = -60, @@ -105,7 +105,7 @@ pub async fn extrude(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-10, 0], %) +/// |> startProfile(at = [-10, 0]) /// |> arc( /// angleStart = 120, /// angleEnd = -60, @@ -127,7 +127,7 @@ pub async fn extrude(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-10, 0], %) +/// |> startProfile(at = [-10, 0]) /// |> arc( /// angleStart = 120, /// angleEnd = -60, diff --git a/rust/kcl-lib/src/std/fillet.rs b/rust/kcl-lib/src/std/fillet.rs index 389a7855f..a2ba49665 100644 --- a/rust/kcl-lib/src/std/fillet.rs +++ b/rust/kcl-lib/src/std/fillet.rs @@ -88,7 +88,7 @@ pub async fn fillet(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-width/2, -length/2], %) +/// |> startProfile(at = [-width/2, -length/2]) /// |> line(endAbsolute = [width/2, -length/2], tag = $edge1) /// |> line(endAbsolute = [width/2, length/2], tag = $edge2) /// |> line(endAbsolute = [-width/2, length/2], tag = $edge3) @@ -113,7 +113,7 @@ pub async fn fillet(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-width/2, -length/2], %) +/// |> startProfile(at = [-width/2, -length/2]) /// |> line(endAbsolute = [width/2, -length/2], tag = $edge1) /// |> line(endAbsolute = [width/2, length/2], tag = $edge2) /// |> line(endAbsolute = [-width/2, length/2], tag = $edge3) diff --git a/rust/kcl-lib/src/std/loft.rs b/rust/kcl-lib/src/std/loft.rs index 6e42e3ebf..6a9f38780 100644 --- a/rust/kcl-lib/src/std/loft.rs +++ b/rust/kcl-lib/src/std/loft.rs @@ -59,7 +59,7 @@ pub async fn loft(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -67,7 +67,7 @@ pub async fn loft(exec_state: &mut ExecState, args: Args) -> Result close() /// /// triangleSketch = startSketchOn(offsetPlane('XY', offset = 75)) -/// |> startProfileAt([0, 125], %) +/// |> startProfile(at = [0, 125]) /// |> line(end = [-15, -30]) /// |> line(end = [30, 0]) /// |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -79,7 +79,7 @@ pub async fn loft(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -98,7 +98,7 @@ pub async fn loft(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) diff --git a/rust/kcl-lib/src/std/math.rs b/rust/kcl-lib/src/std/math.rs index 4e61571a3..16adde1f8 100644 --- a/rust/kcl-lib/src/std/math.rs +++ b/rust/kcl-lib/src/std/math.rs @@ -157,7 +157,7 @@ pub async fn sqrt(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = sqrt(2500), @@ -189,7 +189,7 @@ pub async fn abs(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [8, 0]) /// |> angledLine( /// angle = abs(myAngle), @@ -224,7 +224,7 @@ pub async fn round(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(endAbsolute = [12, 10]) /// |> line(end = [round(7.02986), 0]) /// |> yLine(endAbsolute = 0) @@ -252,7 +252,7 @@ pub async fn floor(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(endAbsolute = [12, 10]) /// |> line(end = [floor(7.02986), 0]) /// |> yLine(endAbsolute = 0) @@ -280,7 +280,7 @@ pub async fn ceil(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(endAbsolute = [12, 10]) /// |> line(end = [ceil(7.02986), 0]) /// |> yLine(endAbsolute = 0) @@ -315,7 +315,7 @@ pub async fn min(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 70, /// length = min(15, 31, 4, 13, 22) @@ -359,7 +359,7 @@ pub async fn max(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 70, /// length = max(15, 31, 4, 13, 22) @@ -410,7 +410,7 @@ pub async fn pow(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = pow(5, 2), @@ -452,7 +452,7 @@ pub async fn acos(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = toDegrees(acos(0.5)), /// length = 10, @@ -495,7 +495,7 @@ pub async fn asin(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = toDegrees(asin(0.5)), /// length = 20, @@ -537,7 +537,7 @@ pub async fn atan(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = toDegrees(atan(1.25)), /// length = 20, @@ -569,7 +569,7 @@ pub async fn atan2(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = toDegrees(atan2(y = 1.25, x = 2)), /// length = 20, @@ -626,7 +626,7 @@ pub async fn log(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [log(100, 5), 0]) /// |> line(end = [5, 8]) /// |> line(end = [-10, 0]) @@ -654,7 +654,7 @@ pub async fn log2(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [log2(100), 0]) /// |> line(end = [5, 8]) /// |> line(end = [-10, 0]) @@ -682,7 +682,7 @@ pub async fn log10(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [log10(100), 0]) /// |> line(end = [5, 8]) /// |> line(end = [-10, 0]) @@ -710,7 +710,7 @@ pub async fn ln(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [ln(100), 15]) /// |> line(end = [5, -6]) /// |> line(end = [-10, -10]) @@ -739,7 +739,7 @@ pub async fn e(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 30, /// length = 2 * e() ^ 2, @@ -771,7 +771,7 @@ pub async fn tau(_exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 10 * tau(), diff --git a/rust/kcl-lib/src/std/mod.rs b/rust/kcl-lib/src/std/mod.rs index 7a0c6018e..7b6e79449 100644 --- a/rust/kcl-lib/src/std/mod.rs +++ b/rust/kcl-lib/src/std/mod.rs @@ -81,7 +81,7 @@ lazy_static! { Box::new(crate::std::sketch::AngledLine), Box::new(crate::std::sketch::AngledLineThatIntersects), Box::new(crate::std::sketch::StartSketchOn), - Box::new(crate::std::sketch::StartProfileAt), + Box::new(crate::std::sketch::StartProfile), Box::new(crate::std::sketch::ProfileStartX), Box::new(crate::std::sketch::ProfileStartY), Box::new(crate::std::sketch::ProfileStart), diff --git a/rust/kcl-lib/src/std/patterns.rs b/rust/kcl-lib/src/std/patterns.rs index b90aa5868..45f39773a 100644 --- a/rust/kcl-lib/src/std/patterns.rs +++ b/rust/kcl-lib/src/std/patterns.rs @@ -147,7 +147,7 @@ pub async fn pattern_transform_2d(exec_state: &mut ExecState, args: Args) -> Res /// p3 = [ l + x, -l + y] /// /// return startSketchOn('XY') -/// |> startProfileAt(p0, %) +/// |> startProfile(at = p0) /// |> line(endAbsolute = p1) /// |> line(endAbsolute = p2) /// |> line(endAbsolute = p3) @@ -187,7 +187,7 @@ pub async fn pattern_transform_2d(exec_state: &mut ExecState, args: Args) -> Res /// p3 = [ l + x, -l + y] /// /// return startSketchOn('XY') -/// |> startProfileAt(p0, %) +/// |> startProfile(at = p0) /// |> line(endAbsolute = p1) /// |> line(endAbsolute = p2) /// |> line(endAbsolute = p3) @@ -244,7 +244,7 @@ pub async fn pattern_transform_2d(exec_state: &mut ExecState, args: Args) -> Res /// ] /// } /// startSketchOn('XY') -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> polygon( /// radius = 10, /// numSides = 4, @@ -812,7 +812,7 @@ pub async fn pattern_linear_3d(exec_state: &mut ExecState, args: Args) -> Result /// /// ```no_run /// exampleSketch = startSketchOn('XZ') -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 2]) /// |> line(end = [3, 1]) /// |> line(end = [0, -4]) @@ -831,7 +831,7 @@ pub async fn pattern_linear_3d(exec_state: &mut ExecState, args: Args) -> Result /// // Pattern a whole sketch on face. /// let size = 100 /// const case = startSketchOn('XY') -/// |> startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) @@ -859,7 +859,7 @@ pub async fn pattern_linear_3d(exec_state: &mut ExecState, args: Args) -> Result /// // Pattern an object on a face. /// let size = 100 /// const case = startSketchOn('XY') -/// |> startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) @@ -1063,7 +1063,7 @@ pub async fn pattern_circular_2d(exec_state: &mut ExecState, args: Args) -> Resu /// /// ```no_run /// exampleSketch = startSketchOn('XZ') -/// |> startProfileAt([.5, 25], %) +/// |> startProfile(at = [.5, 25]) /// |> line(end = [0, 5]) /// |> line(end = [-1, 0]) /// |> line(end = [0, -5]) diff --git a/rust/kcl-lib/src/std/segment.rs b/rust/kcl-lib/src/std/segment.rs index 1ff201275..ecc798a32 100644 --- a/rust/kcl-lib/src/std/segment.rs +++ b/rust/kcl-lib/src/std/segment.rs @@ -27,7 +27,7 @@ pub async fn segment_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [w, 0], tag = $line1) /// |> line(end = [0, w], tag = $line2) /// |> line(end = [-w, 0], tag = $line3) @@ -37,7 +37,7 @@ pub async fn segment_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> circle(radius = radius, center = segEnd(tag) ) /// |> extrude(length = radius) /// } @@ -79,7 +79,7 @@ pub async fn segment_end_x(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [20, 0], tag = $thing) /// |> line(end = [0, 5]) /// |> line(end = [segEndX(thing), 0]) @@ -120,7 +120,7 @@ pub async fn segment_end_y(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [20, 0]) /// |> line(end = [0, 3], tag = $thing) /// |> line(end = [-10, 0]) @@ -163,7 +163,7 @@ pub async fn segment_start(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [w, 0], tag = $line1) /// |> line(end = [0, w], tag = $line2) /// |> line(end = [-w, 0], tag = $line3) @@ -173,7 +173,7 @@ pub async fn segment_start(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> circle( radius = radius, center = segStart(tag) ) /// |> extrude(length = radius) /// } @@ -215,7 +215,7 @@ pub async fn segment_start_x(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [20, 0], tag = $thing) /// |> line(end = [0, 5]) /// |> line(end = [20 - segStartX(thing), 0]) @@ -256,7 +256,7 @@ pub async fn segment_start_y(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [20, 0]) /// |> line(end = [0, 3], tag = $thing) /// |> line(end = [-10, 0]) @@ -299,7 +299,7 @@ pub async fn last_segment_x(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [5, 0]) /// |> line(end = [20, 5]) /// |> line(end = [lastSegX(%), 0]) @@ -345,7 +345,7 @@ pub async fn last_segment_y(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [5, 0]) /// |> line(end = [20, 5]) /// |> line(end = [0, lastSegY(%)]) @@ -388,7 +388,7 @@ pub async fn segment_length(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 60, /// length = 10, @@ -435,7 +435,7 @@ pub async fn segment_angle(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [5, 10], tag = $seg01) /// |> line(end = [-10, 0]) @@ -481,7 +481,7 @@ pub async fn tangent_to_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [20, 0]) /// |> tangentialArc(end = [0, 10], tag = $arc1) /// |> angledLine( @@ -497,7 +497,7 @@ pub async fn tangent_to_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20]) /// |> tangentialArc(endAbsolute = [10, 20], tag = $arc1) /// |> angledLine( @@ -512,7 +512,7 @@ pub async fn tangent_to_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0], tag = $seg1) /// |> angledLine( /// angle = tangentToEnd(seg1), @@ -527,7 +527,7 @@ pub async fn tangent_to_end(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> arc( /// endAbsolute = [10, 10], /// interiorAbsolute = [5, 1], @@ -542,7 +542,7 @@ pub async fn tangent_to_end(exec_state: &mut ExecState, args: Args) -> Result circle( center= [0, 0], radius= 3 , tag= $circ) /// /// triangleSketch = startSketchOn("XY") -/// |> startProfileAt([-5, 0], %) +/// |> startProfile(at = [-5, 0]) /// |> angledLine(angle = tangentToEnd(circ), length = 10) /// |> line(end = [-15, 0]) /// |> close() diff --git a/rust/kcl-lib/src/std/shapes.rs b/rust/kcl-lib/src/std/shapes.rs index 654bfabff..6f3238ef8 100644 --- a/rust/kcl-lib/src/std/shapes.rs +++ b/rust/kcl-lib/src/std/shapes.rs @@ -72,7 +72,7 @@ async fn inner_circle( let from_t = [TyF64::new(from[0], ty.clone()), TyF64::new(from[1], ty)]; let sketch = - crate::std::sketch::inner_start_profile_at(from_t, sketch_surface, None, exec_state, args.clone()).await?; + crate::std::sketch::inner_start_profile(sketch_surface, from_t, None, exec_state, args.clone()).await?; let angle_start = Angle::zero(); let angle_end = Angle::turn(); @@ -189,8 +189,7 @@ async fn inner_circle_three_point( TyF64::new(center[1], ty.clone()), ]; let sketch = - crate::std::sketch::inner_start_profile_at(from.clone(), sketch_surface, None, exec_state, args.clone()) - .await?; + crate::std::sketch::inner_start_profile(sketch_surface, from.clone(), None, exec_state, args.clone()).await?; let angle_start = Angle::zero(); let angle_end = Angle::turn(); @@ -366,9 +365,9 @@ async fn inner_polygon( }) .collect(); - let mut sketch = crate::std::sketch::inner_start_profile_at( - point_to_typed(vertices[0], units), + let mut sketch = crate::std::sketch::inner_start_profile( sketch_surface, + point_to_typed(vertices[0], units), None, exec_state, args.clone(), diff --git a/rust/kcl-lib/src/std/shell.rs b/rust/kcl-lib/src/std/shell.rs index a09381863..8eb773285 100644 --- a/rust/kcl-lib/src/std/shell.rs +++ b/rust/kcl-lib/src/std/shell.rs @@ -30,7 +30,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -48,7 +48,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -66,7 +66,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0], tag = $myTag) @@ -84,7 +84,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0], tag = $myTag) @@ -103,7 +103,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) @@ -126,7 +126,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) @@ -151,7 +151,7 @@ pub async fn shell(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) @@ -262,7 +262,7 @@ pub async fn hollow(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -274,7 +274,7 @@ pub async fn hollow(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -287,7 +287,7 @@ pub async fn hollow(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-size, -size], %) +/// |> startProfile(at = [-size, -size]) /// |> line(end = [2 * size, 0]) /// |> line(end = [0, 2 * size]) /// |> tangentialArc(endAbsolute = [-size, size]) diff --git a/rust/kcl-lib/src/std/sketch.rs b/rust/kcl-lib/src/std/sketch.rs index 4e67a5a84..4f101e5f6 100644 --- a/rust/kcl-lib/src/std/sketch.rs +++ b/rust/kcl-lib/src/std/sketch.rs @@ -134,7 +134,7 @@ fn involute_curve(radius: f64, angle: f64) -> (f64, f64) { /// a = 10 /// b = 14 /// startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> involuteCircular(startRadius = a, endRadius = b, angle = 60) /// |> involuteCircular(startRadius = a, endRadius = b, angle = 60, reverse = true) /// ``` @@ -236,7 +236,7 @@ pub async fn line(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// // The END argument means it ends at exactly [10, 0]. /// // This is an absolute measurement, it is NOT relative to /// // the start of the sketch. @@ -247,7 +247,7 @@ pub async fn line(exec_state: &mut ExecState, args: Args) -> Result extrude(length = 5) /// /// box = startSketchOn(XZ) -/// |> startProfileAt([10, 10], %) +/// |> startProfile(at = [10, 10]) /// // The 'to' argument means move the pen this much. /// // So, [10, 0] is a relative distance away from the current point. /// |> line(end = [10, 0]) @@ -406,7 +406,7 @@ pub async fn x_line(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> xLine(length = 15) /// |> angledLine( /// angle = 80, @@ -475,7 +475,7 @@ pub async fn y_line(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> yLine(length = 15) /// |> angledLine( /// angle = 30, @@ -556,7 +556,7 @@ pub async fn angled_line(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> yLine(endAbsolute = 15) /// |> angledLine( /// angle = 30, @@ -854,7 +854,7 @@ pub async fn angled_line_that_intersects(exec_state: &mut ExecState, args: Args) /// /// ```no_run /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(endAbsolute = [5, 10]) /// |> line(endAbsolute = [-10, 10], tag = $lineToIntersect) /// |> line(endAbsolute = [0, 20]) @@ -1000,7 +1000,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -1009,7 +1009,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([1, 1], %) +/// |> startProfile(at = [1, 1]) /// |> line(end = [8, 0]) /// |> line(end = [0, 8]) /// |> line(end = [-8, 0]) @@ -1018,7 +1018,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([2, 2], %) +/// |> startProfile(at = [2, 2]) /// |> line(end = [6, 0]) /// |> line(end = [0, 6]) /// |> line(end = [-6, 0]) @@ -1031,7 +1031,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -1040,7 +1040,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([1, 1], %) +/// |> startProfile(at = [1, 1]) /// |> line(end = [8, 0]) /// |> line(end = [0, 8]) /// |> line(end = [-8, 0]) @@ -1049,7 +1049,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([2, 2], %) +/// |> startProfile(at = [2, 2]) /// |> line(end = [6, 0]) /// |> line(end = [0, 6]) /// |> line(end = [-6, 0]) @@ -1060,7 +1060,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10], tag = $sketchingFace) /// |> line(end = [-10, 0]) @@ -1069,7 +1069,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([1, 1], %) +/// |> startProfile(at = [1, 1]) /// |> line(end = [8, 0]) /// |> line(end = [0, 8]) /// |> line(end = [-8, 0]) @@ -1078,7 +1078,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-8, 12], %) +/// |> startProfile(at = [-8, 12]) /// |> line(end = [0, 6]) /// |> line(end = [6, 0]) /// |> line(end = [0, -6]) @@ -1089,7 +1089,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -1102,7 +1102,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4.5, -5], %) +/// |> startProfile(at = [4.5, -5]) /// |> line(end = [0, 5]) /// |> line(end = [5, 0]) /// |> line(end = [0, -5]) @@ -1115,7 +1115,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -1128,7 +1128,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([4.5, -5], %) +/// |> startProfile(at = [4.5, -5]) /// |> line(end = [0, 5]) /// |> line(end = [5, 0]) /// |> line(end = [0, -5]) @@ -1144,7 +1144,7 @@ pub async fn start_sketch_on(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [100.0, 0]) /// |> yLine(length = -100.0) /// |> xLine(length = -100.0) @@ -1260,10 +1260,13 @@ async fn make_sketch_plane_from_orientation( } /// Start a new profile at a given point. -pub async fn start_profile_at(exec_state: &mut ExecState, args: Args) -> Result { - let (start, sketch_surface, tag) = args.get_data_and_sketch_surface()?; +pub async fn start_profile(exec_state: &mut ExecState, args: Args) -> Result { + // let (start, sketch_surface, tag) = args.get_data_and_sketch_surface()?; + let sketch_surface = args.get_unlabeled_kw_arg("startProfileOn")?; + let start: [TyF64; 2] = args.get_kw_arg("at")?; + let tag = args.get_kw_arg_opt(NEW_TAG_KW)?; - let sketch = inner_start_profile_at(start, sketch_surface, tag, exec_state, args).await?; + let sketch = inner_start_profile(sketch_surface, start, tag, exec_state, args).await?; Ok(KclValue::Sketch { value: Box::new(sketch), }) @@ -1273,7 +1276,7 @@ pub async fn start_profile_at(exec_state: &mut ExecState, args: Args) -> Result< /// /// ```no_run /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -1284,7 +1287,7 @@ pub async fn start_profile_at(exec_state: &mut ExecState, args: Args) -> Result< /// /// ```no_run /// exampleSketch = startSketchOn(-XZ) -/// |> startProfileAt([10, 10], %) +/// |> startProfile(at = [10, 10]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -1295,7 +1298,7 @@ pub async fn start_profile_at(exec_state: &mut ExecState, args: Args) -> Result< /// /// ```no_run /// exampleSketch = startSketchOn(-XZ) -/// |> startProfileAt([-10, 23], %) +/// |> startProfile(at = [-10, 23]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> line(end = [-10, 0]) @@ -1304,11 +1307,18 @@ pub async fn start_profile_at(exec_state: &mut ExecState, args: Args) -> Result< /// example = extrude(exampleSketch, length = 5) /// ``` #[stdlib { - name = "startProfileAt", + name = "startProfile", + keywords = true, + unlabeled_first = true, + args = { + sketch_surface = { docs = "What to start the profile on" }, + at = { docs = "Where to start the profile. An absolute point." }, + tag = { docs = "Tag this first starting point" }, + } }] -pub(crate) async fn inner_start_profile_at( - to: [TyF64; 2], +pub(crate) async fn inner_start_profile( sketch_surface: SketchSurface, + at: [TyF64; 2], tag: Option, exec_state: &mut ExecState, args: Args, @@ -1364,7 +1374,7 @@ pub(crate) async fn inner_start_profile_at( ModelingCmdReq { cmd: ModelingCmd::from(mcmd::MovePathPen { path: path_id.into(), - to: KPoint2d::from(point_to_mm(to.clone())).with_z(0.0).map(LengthUnit), + to: KPoint2d::from(point_to_mm(at.clone())).with_z(0.0).map(LengthUnit), }), cmd_id: move_pen_id.into(), }, @@ -1375,7 +1385,7 @@ pub(crate) async fn inner_start_profile_at( ]) .await?; - let (to, ty) = untype_point(to); + let (to, ty) = untype_point(at); let current_path = BasePath { from: to, to, @@ -1431,7 +1441,7 @@ pub async fn profile_start_x(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([5, 2], %) +/// |> startProfile(at = [5, 2]) /// |> angledLine(angle = -26.6, length = 50) /// |> angledLine(angle = 90, length = 50) /// |> angledLine(angle = 30, endAbsoluteX = profileStartX(%)) @@ -1461,7 +1471,7 @@ pub async fn profile_start_y(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([5, 2], %) +/// |> startProfile(at = [5, 2]) /// |> angledLine(angle = -60, length = 14 ) /// |> angledLine(angle = 30, endAbsoluteY = profileStartY(%)) /// ``` @@ -1490,7 +1500,7 @@ pub async fn profile_start(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([5, 2], %) +/// |> startProfile(at = [5, 2]) /// |> angledLine(angle = 120, length = 50 , tag = $seg01) /// |> angledLine(angle = segAng(seg01) + 120, length = 50 ) /// |> line(end = profileStart(%)) @@ -1525,7 +1535,7 @@ pub async fn close(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 10]) /// |> line(end = [10, 0]) /// |> close() @@ -1534,7 +1544,7 @@ pub async fn close(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> close() @@ -1630,7 +1640,7 @@ pub async fn arc(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> arc( /// angleStart = 0, @@ -1642,7 +1652,7 @@ pub async fn arc(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> arc( /// endAbsolute = [10,0], /// interiorAbsolute = [5,5] @@ -1852,7 +1862,7 @@ pub async fn tangential_arc(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 45, /// length = 10, @@ -1866,7 +1876,7 @@ pub async fn tangential_arc(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 60, /// length = 10, @@ -1880,7 +1890,7 @@ pub async fn tangential_arc(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 60, /// length = 10, @@ -2161,7 +2171,7 @@ pub async fn bezier_curve(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 10]) /// |> bezierCurve( /// control1 = [5, 0], @@ -2256,7 +2266,7 @@ pub async fn hole(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 5]) /// |> line(end = [5, 0]) /// |> line(end = [0, -5]) @@ -2270,7 +2280,7 @@ pub async fn hole(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([-1, -1], %) +/// |> startProfile(at = [-1, -1]) /// |> line(end = [2, 0]) /// |> line(end = [0, 2]) /// |> line(end = [-2, 0]) diff --git a/rust/kcl-lib/src/std/sweep.rs b/rust/kcl-lib/src/std/sweep.rs index 874ce5075..97c6da89e 100644 --- a/rust/kcl-lib/src/std/sweep.rs +++ b/rust/kcl-lib/src/std/sweep.rs @@ -63,7 +63,7 @@ pub async fn sweep(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -110,7 +110,7 @@ pub async fn sweep(exec_state: &mut ExecState, args: Args) -> Result angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -126,7 +126,7 @@ pub async fn sweep(exec_state: &mut ExecState, args: Args) -> Result yLine(length = 231.81) /// |> tangentialArc(radius = 80, angle = -90) /// |> xLine(length = 384.93) @@ -140,7 +140,7 @@ pub async fn sweep(exec_state: &mut ExecState, args: Args) -> Result yLine(length = 231.81) /// |> tangentialArc(radius = 80, angle = -90) /// |> xLine(length = 384.93) diff --git a/rust/kcl-lib/src/std/transform.rs b/rust/kcl-lib/src/std/transform.rs index a84ec4e51..ca1ae8117 100644 --- a/rust/kcl-lib/src/std/transform.rs +++ b/rust/kcl-lib/src/std/transform.rs @@ -76,7 +76,7 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -117,7 +117,7 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -133,7 +133,7 @@ pub async fn scale(exec_state: &mut ExecState, args: Args) -> Result yLine(length = 231.81) /// |> tangentialArc(radius = 80, angle = -90) /// |> xLine(length = 384.93) @@ -242,7 +242,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -297,7 +297,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -313,7 +313,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result yLine(length = 231.81) /// |> tangentialArc(radius = 80, angle = -90) /// |> xLine(length = 384.93) @@ -335,7 +335,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result startProfileAt(p0, %) +/// |> startProfile(at = p0) /// |> line(endAbsolute = p1) /// |> line(endAbsolute = p2) /// |> line(endAbsolute = p3) @@ -357,7 +357,7 @@ pub async fn translate(exec_state: &mut ExecState, args: Args) -> Result xLine(length = 20) /// |> yLine(length = -20) /// |> xLine(length = -20) @@ -581,7 +581,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -614,7 +614,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -645,7 +645,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result startProfileAt([0.05, 0.05], %) +/// |> startProfile(at = [0.05, 0.05]) /// |> line(end = [0, 7]) /// |> tangentialArc(angle = 90, radius = 5) /// |> line(end = [-3, 0]) @@ -688,7 +688,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result angledLine(angle = 0, length = 73.47, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -704,7 +704,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result yLine(length = 231.81) /// |> tangentialArc(radius = 80, angle = -90) /// |> xLine(length = 384.93) @@ -720,7 +720,7 @@ pub async fn rotate(exec_state: &mut ExecState, args: Args) -> Result xLine(length = 20) /// |> yLine(length = -20) /// |> xLine(length = -20) @@ -832,7 +832,7 @@ mod tests { use crate::execution::parse_execute; const PIPE: &str = r#"sweepPath = startSketchOn('XZ') - |> startProfileAt([0.05, 0.05], %) + |> startProfile(at = [0.05, 0.05]) |> line(end = [0, 7]) |> tangentialArc(angle = 90, radius = 5) |> line(end = [-3, 0]) diff --git a/rust/kcl-lib/std/math.kcl b/rust/kcl-lib/std/math.kcl index 0db79024b..b56c0f3a6 100644 --- a/rust/kcl-lib/std/math.kcl +++ b/rust/kcl-lib/std/math.kcl @@ -19,7 +19,7 @@ export PI = 3.14159265358979323846264338327950288_ /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 30, /// length = 2 * E ^ 2, @@ -35,7 +35,7 @@ export E = 2.71828182845904523536028747135266250_ /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 10 * TAU, @@ -51,7 +51,7 @@ export TAU = 6.28318530717958647692528676655900577_ /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 30, /// length = 3 / cos(30deg), @@ -68,7 +68,7 @@ export fn cos(@num: number(Angle)): number(_) {} /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 15 / sin(135deg), @@ -85,7 +85,7 @@ export fn sin(@num: number(Angle)): number(_) {} /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 50 * tan((1/2): number(rad)), @@ -103,7 +103,7 @@ export fn tan(@num: number(Angle)): number(_) {} /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = polar(angle = 30, length = 5), tag = $thing) /// |> line(end = [0, 5]) /// |> line(end = [segEndX(thing), 0]) diff --git a/rust/kcl-lib/std/prelude.kcl b/rust/kcl-lib/std/prelude.kcl index 20688ffb0..aeeb0e089 100644 --- a/rust/kcl-lib/std/prelude.kcl +++ b/rust/kcl-lib/std/prelude.kcl @@ -69,7 +69,7 @@ export END = 'end' /// ``` /// // Create a helix around an edge. /// helper001 = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 10], tag = $edge001) /// /// helixPath = helix( @@ -157,7 +157,7 @@ export fn helix( /// /// ``` /// part001 = startSketchOn(XY) -/// |> startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -181,7 +181,7 @@ export fn helix( /// /// ``` /// part001 = startSketchOn(XY) -/// |> startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -195,7 +195,7 @@ export fn helix( /// /// ``` /// part001 = startSketchOn(XY) -/// |> startProfileAt([4, 12], %) +/// |> startProfile(at = [4, 12]) /// |> line(end = [2, 0]) /// |> line(end = [0, -6]) /// |> line(end = [4, -6]) @@ -207,7 +207,7 @@ export fn helix( /// |> revolve(axis = Y, angle = 180) /// /// part002 = startSketchOn(part001, face = END) -/// |> startProfileAt([4.5, -5], %) +/// |> startProfile(at = [4.5, -5]) /// |> line(end = [0, 5]) /// |> line(end = [5, 0]) /// |> line(end = [0, -5]) @@ -217,7 +217,7 @@ export fn helix( /// /// ``` /// box = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20]) /// |> line(end = [20, 0]) /// |> line(end = [0, -20]) @@ -234,7 +234,7 @@ export fn helix( /// /// ``` /// box = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20]) /// |> line(end = [20, 0]) /// |> line(end = [0, -20], tag = $revolveAxis) @@ -251,7 +251,7 @@ export fn helix( /// /// ``` /// box = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20]) /// |> line(end = [20, 0]) /// |> line(end = [0, -20], tag = $revolveAxis) @@ -269,7 +269,7 @@ export fn helix( /// /// ``` /// sketch001 = startSketchOn(XY) -/// |> startProfileAt([10, 0], %) +/// |> startProfile(at = [10, 0]) /// |> line(end = [5, -5]) /// |> line(end = [5, 5]) /// |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -288,14 +288,14 @@ export fn helix( /// // Revolve two sketches around the same axis. /// /// sketch001 = startSketchOn(XY) -/// profile001 = startProfileAt([4, 8], sketch001) +/// profile001 = startProfile(sketch001, at = [4, 8]) /// |> xLine(length = 3) /// |> yLine(length = -3) /// |> xLine(length = -3) /// |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) /// |> close() /// -/// profile002 = startProfileAt([-5, 8], sketch001) +/// profile002 = startProfile(sketch001, at = [-5, 8]) /// |> xLine(length = 3) /// |> yLine(length = -3) /// |> xLine(length = -3) @@ -312,7 +312,7 @@ export fn helix( /// // Revolve around a path that has not been extruded. /// /// profile001 = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20], tag = $revolveAxis) /// |> line(end = [20, 0]) /// |> line(end = [0, -20]) @@ -327,7 +327,7 @@ export fn helix( /// // Revolve around a path that has not been extruded or closed. /// /// profile001 = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20], tag = $revolveAxis) /// |> line(end = [20, 0]) /// @@ -340,7 +340,7 @@ export fn helix( /// // Symmetrically revolve around a path. /// /// profile001 = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20], tag = $revolveAxis) /// |> line(end = [20, 0]) /// @@ -353,7 +353,7 @@ export fn helix( /// // Bidirectional revolve around a path. /// /// profile001 = startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 20], tag = $revolveAxis) /// |> line(end = [20, 0]) /// @@ -415,7 +415,7 @@ export fn toYards(@num: number(yd)): number(yd) { /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 70 * cos(toRadians(45)), @@ -433,7 +433,7 @@ export fn toRadians(@num: number(rad)): number(rad) { /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> angledLine( /// angle = 50, /// length = 70 * cos(toDegrees((PI/4): number(rad))), @@ -455,7 +455,7 @@ export fn toDegrees(@num: number(deg)): number(deg) { /// ``` /// // Loft a square and a circle on the `XY` plane using offset. /// squareSketch = startSketchOn(XY) -/// |> startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -471,7 +471,7 @@ export fn toDegrees(@num: number(deg)): number(deg) { /// ``` /// // Loft a square and a circle on the `XZ` plane using offset. /// squareSketch = startSketchOn(XZ) -/// |> startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -487,7 +487,7 @@ export fn toDegrees(@num: number(deg)): number(deg) { /// ``` /// // Loft a square and a circle on the `YZ` plane using offset. /// squareSketch = startSketchOn(YZ) -/// |> startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -503,7 +503,7 @@ export fn toDegrees(@num: number(deg)): number(deg) { /// ``` /// // Loft a square and a circle on the `-XZ` plane using offset. /// squareSketch = startSketchOn(-XZ) -/// |> startProfileAt([-100, 200], %) +/// |> startProfile(at = [-100, 200]) /// |> line(end = [200, 0]) /// |> line(end = [0, -200]) /// |> line(end = [-200, 0]) @@ -519,12 +519,12 @@ export fn toDegrees(@num: number(deg)): number(deg) { /// ``` /// // A circle on the XY plane /// startSketchOn(XY) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> circle( radius = 10, center = [0, 0] ) /// /// // Triangle on the plane 4 units above /// startSketchOn(offsetPlane(XY, offset = 4)) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [10, 0]) /// |> line(end = [0, 10]) /// |> close() diff --git a/rust/kcl-lib/std/sketch.kcl b/rust/kcl-lib/std/sketch.kcl index a393049ef..f0bf2f72d 100644 --- a/rust/kcl-lib/std/sketch.kcl +++ b/rust/kcl-lib/std/sketch.kcl @@ -13,7 +13,7 @@ /// /// ``` /// exampleSketch = startSketchOn(XZ) -/// |> startProfileAt([-15, 0], %) +/// |> startProfile(at = [-15, 0]) /// |> line(end = [30, 0]) /// |> line(end = [0, 30]) /// |> line(end = [-30, 0]) @@ -43,7 +43,7 @@ export fn circle( /// ``` /// // Mirror an un-closed sketch across the Y axis. /// sketch001 = startSketchOn(XZ) -/// |> startProfileAt([0, 10], %) +/// |> startProfile(at = [0, 10]) /// |> line(end = [15, 0]) /// |> line(end = [-7, -3]) /// |> line(end = [9, -1]) @@ -60,7 +60,7 @@ export fn circle( /// ``` /// // Mirror a un-closed sketch across the Y axis. /// sketch001 = startSketchOn(XZ) -/// |> startProfileAt([0, 8.5], %) +/// |> startProfile(at = [0, 8.5]) /// |> line(end = [20, -8.5]) /// |> line(end = [-20, -8.5]) /// |> mirror2d(axis = Y) @@ -71,11 +71,11 @@ export fn circle( /// ``` /// // Mirror a un-closed sketch across an edge. /// helper001 = startSketchOn(XZ) -/// |> startProfileAt([0, 0], %) +/// |> startProfile(at = [0, 0]) /// |> line(end = [0, 10], tag = $edge001) /// /// sketch001 = startSketchOn(XZ) -/// |> startProfileAt([0, 8.5], %) +/// |> startProfile(at = [0, 8.5]) /// |> line(end = [20, -8.5]) /// |> line(end = [-20, -8.5]) /// |> mirror2d(axis = edge001) @@ -86,7 +86,7 @@ export fn circle( /// ``` /// // Mirror an un-closed sketch across a custom axis. /// sketch001 = startSketchOn(XZ) -/// |> startProfileAt([0, 8.5], %) +/// |> startProfile(at = [0, 8.5]) /// |> line(end = [20, -8.5]) /// |> line(end = [-20, -8.5]) /// |> mirror2d( @@ -101,7 +101,7 @@ export fn circle( /// ``` /// // Sketch on the face of a mirrored sketch, that has been extruded. /// sketch0011 = startSketchOn(XY) -/// |> startProfileAt([6.77, 0], %) +/// |> startProfile(at = [6.77, 0]) /// |> yLine(length = 1.27) /// |> tangentialArc(endAbsolute = [5.96, 2.37]) /// |> tangentialArc(endAbsolute = [-6.2, 2.44]) diff --git a/rust/kcl-lib/std/types.kcl b/rust/kcl-lib/std/types.kcl index 69c51ba0c..51f3f2660 100644 --- a/rust/kcl-lib/std/types.kcl +++ b/rust/kcl-lib/std/types.kcl @@ -35,7 +35,7 @@ export type string /// /// ```norun,inline /// startSketchOn(XZ) -/// |> startProfileAt(origin, %) +/// |> startProfile(at = origin) /// |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -69,7 +69,7 @@ export type string /// ```norun,inline /// fn rect(origin) { /// return startSketchOn(XZ) -/// |> startProfileAt(origin, %) +/// |> startProfile(at = origin) /// |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -98,7 +98,7 @@ export type string /// ```norun,inline /// fn rect(origin) { /// return startSketchOn(XZ) -/// |> startProfileAt(origin, %) +/// |> startProfile(at = origin) /// |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) /// |> angledLine( /// angle = segAng(rectangleSegmentA001) - 90, @@ -136,7 +136,7 @@ export type Plane /// /// ```kcl,inline /// mySketch = startSketchOn(XY) -/// |> startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -154,7 +154,7 @@ export type Plane /// ```kcl,inline /// fn createSketch() { /// return startSketchOn(XY) -/// |> startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -180,7 +180,7 @@ export type Sketch /// /// ```kcl,inline /// myPart = startSketchOn('XY') -/// |> startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) @@ -199,7 +199,7 @@ export type Sketch /// ```kcl,inline /// fn createPart() { /// return startSketchOn('XY') -/// |> startProfileAt([-12, 12], %) +/// |> startProfile(at = [-12, 12]) /// |> line(end = [24, 0]) /// |> line(end = [0, -24]) /// |> line(end = [-24, 0]) diff --git a/rust/kcl-lib/tests/angled_line/ast.snap b/rust/kcl-lib/tests/angled_line/ast.snap index c6a37fae6..86f2bb04b 100644 --- a/rust/kcl-lib/tests/angled_line/ast.snap +++ b/rust/kcl-lib/tests/angled_line/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing angled_line.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "4.83", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.83, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "4.83", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.83, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "12.56", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 12.56, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "12.56", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 12.56, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing angled_line.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing angled_line.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/angled_line/input.kcl b/rust/kcl-lib/tests/angled_line/input.kcl index 3d78556eb..b3f5e3ba7 100644 --- a/rust/kcl-lib/tests/angled_line/input.kcl +++ b/rust/kcl-lib/tests/angled_line/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([4.83, 12.56], %) + |> startProfile(at = [4.83, 12.56]) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) diff --git a/rust/kcl-lib/tests/angled_line/unparsed.snap b/rust/kcl-lib/tests/angled_line/unparsed.snap index 4f4924ebf..10b4e6d55 100644 --- a/rust/kcl-lib/tests/angled_line/unparsed.snap +++ b/rust/kcl-lib/tests/angled_line/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing angled_line.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([4.83, 12.56], %) + |> startProfile(at = [4.83, 12.56]) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) |> line(end = [-15.17, -4.1]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code1/ast.snap b/rust/kcl-lib/tests/artifact_graph_example_code1/ast.snap index 1b038356c..26f377976 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code1/ast.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code1/ast.snap @@ -55,60 +55,63 @@ description: Result of parsing artifact_graph_example_code1.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "5", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.0, - "suffix": "None" - } + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "5", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.0, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -118,7 +121,7 @@ description: Result of parsing artifact_graph_example_code1.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -129,8 +132,9 @@ description: Result of parsing artifact_graph_example_code1.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -790,60 +794,63 @@ description: Result of parsing artifact_graph_example_code1.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "2", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "6", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 6.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "6", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 6.0, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -853,7 +860,7 @@ description: Result of parsing artifact_graph_example_code1.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -864,8 +871,9 @@ description: Result of parsing artifact_graph_example_code1.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/artifact_graph_example_code1/input.kcl b/rust/kcl-lib/tests/artifact_graph_example_code1/input.kcl index b50d3b4d9..1c0abc54d 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code1/input.kcl +++ b/rust/kcl-lib/tests/artifact_graph_example_code1/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn('XY') - |> startProfileAt([-5, -5], %) + |> startProfile(at = [-5, -5]) |> line(end = [0, 10]) |> line(end = [10.55, 0], tag = $seg01) |> line(end = [0, -10], tag = $seg02) @@ -8,7 +8,7 @@ sketch001 = startSketchOn('XY') extrude001 = extrude(sketch001, length = -10) |> fillet(radius = 5, tags = [seg01]) sketch002 = startSketchOn(extrude001, face = seg02) - |> startProfileAt([-2, -6], %) + |> startProfile(at = [-2, -6]) |> line(end = [2, 3]) |> line(end = [2, -3]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap b/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap index b1066870c..b6c1db457 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_example_code1.kcl --- sketch001 = startSketchOn(XY) - |> startProfileAt([-5, -5], %) + |> startProfile(at = [-5, -5]) |> line(end = [0, 10]) |> line(end = [10.55, 0], tag = $seg01) |> line(end = [0, -10], tag = $seg02) @@ -12,7 +12,7 @@ sketch001 = startSketchOn(XY) extrude001 = extrude(sketch001, length = -10) |> fillet(radius = 5, tags = [seg01]) sketch002 = startSketchOn(extrude001, face = seg02) - |> startProfileAt([-2, -6], %) + |> startProfile(at = [-2, -6]) |> line(end = [2, 3]) |> line(end = [2, -3]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/ast.snap b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/ast.snap index 6e7ef93bf..c69262d16 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/ast.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "5.82", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.82, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "5.82", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.82, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -684,44 +688,47 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "14.36", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 14.36, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "14.36", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 14.36, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -731,7 +738,7 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -742,8 +749,9 @@ description: Result of parsing artifact_graph_example_code_no_3d.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/input.kcl b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/input.kcl index e2f8b35c0..e31ce5c23 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/input.kcl +++ b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/input.kcl @@ -1,12 +1,12 @@ sketch003 = startSketchOn('YZ') - |> startProfileAt([5.82, 0], %) + |> startProfile(at = [5.82, 0]) |> angledLine(angle = 180, length = 11.54, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 8.21, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch004 = startSketchOn('-XZ') - |> startProfileAt([0, 14.36], %) + |> startProfile(at = [0, 14.36]) |> line(end = [15.49, 0.05]) |> tangentialArc(endAbsolute = [0, 0]) |> tangentialArc(endAbsolute = [-6.8, 8.17]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/unparsed.snap b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/unparsed.snap index 882091554..5c630909a 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/unparsed.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code_no_3d/unparsed.snap @@ -3,14 +3,14 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_example_code_no_3d.kcl --- sketch003 = startSketchOn(YZ) - |> startProfileAt([5.82, 0], %) + |> startProfile(at = [5.82, 0]) |> angledLine(angle = 180, length = 11.54, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 8.21, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch004 = startSketchOn(-XZ) - |> startProfileAt([0, 14.36], %) + |> startProfile(at = [0, 14.36]) |> line(end = [15.49, 0.05]) |> tangentialArc(endAbsolute = [0, 0]) |> tangentialArc(endAbsolute = [-6.8, 8.17]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/ast.snap b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/ast.snap index a0154d812..30c68633b 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/ast.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/ast.snap @@ -298,44 +298,47 @@ description: Result of parsing artifact_graph_example_code_offset_planes.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -345,7 +348,7 @@ description: Result of parsing artifact_graph_example_code_offset_planes.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -356,8 +359,9 @@ description: Result of parsing artifact_graph_example_code_offset_planes.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/input.kcl b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/input.kcl index dace451b0..dbdd05607 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/input.kcl +++ b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/input.kcl @@ -3,5 +3,5 @@ offsetPlane002 = offsetPlane("XZ", offset = -50) offsetPlane003 = offsetPlane("YZ", offset = 10) sketch002 = startSketchOn(offsetPlane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [6.78, 15.01]) diff --git a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/unparsed.snap b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/unparsed.snap index 7601bafda..4a25c7a85 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/unparsed.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code_offset_planes/unparsed.snap @@ -7,5 +7,5 @@ offsetPlane002 = offsetPlane(XZ, offset = -50) offsetPlane003 = offsetPlane(YZ, offset = 10) sketch002 = startSketchOn(offsetPlane001) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [6.78, 15.01]) diff --git a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/ast.snap b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/ast.snap index 0e38b7f1a..51904aa69 100644 --- a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/ast.snap +++ b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/ast.snap @@ -62,44 +62,47 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -109,7 +112,7 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -120,8 +123,9 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -596,10 +600,38 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "0.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.5, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { "commentStart": 0, "end": 0, "raw": "0.5", @@ -610,38 +642,13 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "value": 0.5, "suffix": "None" } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.5, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -651,7 +658,7 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -662,8 +669,9 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1113,44 +1121,47 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "1.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.5, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "1.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.5, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1160,7 +1171,7 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1171,8 +1182,9 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1647,52 +1659,55 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "3", + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "raw": "14", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 3.0, + "value": 14.0, "suffix": "None" } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "14", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 14.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1702,7 +1717,7 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1713,8 +1728,9 @@ description: Result of parsing artifact_graph_sketch_on_face_etc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/input.kcl b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/input.kcl index e77dd7be0..2b2f6edcd 100644 --- a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/input.kcl +++ b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/input.kcl @@ -1,26 +1,26 @@ sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [4, 8]) |> line(end = [5, -8], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(sketch001, length = 6) sketch002 = startSketchOn(extrude001, face = seg01) - |> startProfileAt([-0.5, 0.5], %) + |> startProfile(at = [-0.5, 0.5]) |> line(end = [2, 5]) |> line(end = [2, -5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude002 = extrude(sketch002, length = 5) sketch003 = startSketchOn(extrude002, face = 'END') - |> startProfileAt([1, 1.5], %) + |> startProfile(at = [1, 1.5]) |> line(end = [0.5, 2], tag = $seg02) |> line(end = [1, -2]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude003 = extrude(sketch003, length = 4) sketch004 = startSketchOn(extrude003, face = seg02) - |> startProfileAt([-3, 14], %) + |> startProfile(at = [-3, 14]) |> line(end = [0.5, 1]) |> line(end = [0.5, -2]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/unparsed.snap b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/unparsed.snap index 92ab4a55c..ded4ed1d2 100644 --- a/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/unparsed.snap +++ b/rust/kcl-lib/tests/artifact_graph_sketch_on_face_etc/unparsed.snap @@ -3,28 +3,28 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_sketch_on_face_etc.kcl --- sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [4, 8]) |> line(end = [5, -8], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(sketch001, length = 6) sketch002 = startSketchOn(extrude001, face = seg01) - |> startProfileAt([-0.5, 0.5], %) + |> startProfile(at = [-0.5, 0.5]) |> line(end = [2, 5]) |> line(end = [2, -5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude002 = extrude(sketch002, length = 5) sketch003 = startSketchOn(extrude002, face = END) - |> startProfileAt([1, 1.5], %) + |> startProfile(at = [1, 1.5]) |> line(end = [0.5, 2], tag = $seg02) |> line(end = [1, -2]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude003 = extrude(sketch003, length = 4) sketch004 = startSketchOn(extrude003, face = seg02) - |> startProfileAt([-3, 14], %) + |> startProfile(at = [-3, 14]) |> line(end = [0.5, 1]) |> line(end = [0.5, -2]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/assembly_mixed_units_cubes/artifact_graph_flowchart.snap.md index 7ff79822a..76ffd60c7 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/artifact_graph_flowchart.snap.md @@ -1,25 +1,25 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[76, 113, 6]"] - 3["Segment
[119, 136, 6]"] - 4["Segment
[142, 160, 6]"] - 5["Segment
[166, 184, 6]"] - 6["Segment
[190, 246, 6]"] - 7["Segment
[252, 259, 6]"] + 2["Path
[76, 116, 6]"] + 3["Segment
[122, 139, 6]"] + 4["Segment
[145, 163, 6]"] + 5["Segment
[169, 187, 6]"] + 6["Segment
[193, 249, 6]"] + 7["Segment
[255, 262, 6]"] 8[Solid2d] end subgraph path25 [Path] - 25["Path
[76, 111, 7]"] - 26["Segment
[117, 134, 7]"] - 27["Segment
[140, 158, 7]"] - 28["Segment
[164, 182, 7]"] - 29["Segment
[188, 244, 7]"] - 30["Segment
[250, 257, 7]"] + 25["Path
[76, 114, 7]"] + 26["Segment
[120, 137, 7]"] + 27["Segment
[143, 161, 7]"] + 28["Segment
[167, 185, 7]"] + 29["Segment
[191, 247, 7]"] + 30["Segment
[253, 260, 7]"] 31[Solid2d] end 1["Plane
[47, 66, 6]"] - 9["Sweep Extrusion
[265, 287, 6]"] + 9["Sweep Extrusion
[268, 290, 6]"] 10[Wall] 11[Wall] 12[Wall] @@ -35,7 +35,7 @@ flowchart LR 22["SweepEdge Opposite"] 23["SweepEdge Adjacent"] 24["Plane
[47, 66, 7]"] - 32["Sweep Extrusion
[263, 285, 7]"] + 32["Sweep Extrusion
[266, 288, 7]"] 33[Wall] 34[Wall] 35[Wall] diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-inches.kcl b/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-inches.kcl index dbd2d6a10..88463c03d 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-inches.kcl +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-inches.kcl @@ -1,7 +1,7 @@ @settings(defaultLengthUnit = in) sketch001 = startSketchOn('XY') -cubeIn = startProfileAt([-10, -10], sketch001) +cubeIn = startProfile(sketch001, at = [-10, -10]) |> xLine(length = 5) |> yLine(length = -5) |> xLine(length = -5) diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-mm.kcl b/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-mm.kcl index 893cfcf4a..1fa0012b2 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-mm.kcl +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/cube-mm.kcl @@ -1,7 +1,7 @@ @settings(defaultLengthUnit = mm) sketch001 = startSketchOn('XY') -cubeMm = startProfileAt([10, 10], sketch001) +cubeMm = startProfile(sketch001, at = [10, 10]) |> xLine(length = 5) |> yLine(length = -5) |> xLine(length = -5) diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-inches.kcl.snap b/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-inches.kcl.snap index 3e5740699..023dc5a50 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-inches.kcl.snap +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-inches.kcl.snap @@ -5,7 +5,7 @@ description: Result of unparsing tests/assembly_mixed_units_cubes/cube-inches.kc @settings(defaultLengthUnit = in) sketch001 = startSketchOn(XY) -cubeIn = startProfileAt([-10, -10], sketch001) +cubeIn = startProfile(sketch001, at = [-10, -10]) |> xLine(length = 5) |> yLine(length = -5) |> xLine(length = -5) diff --git a/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-mm.kcl.snap b/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-mm.kcl.snap index d576d0b69..b4a648208 100644 --- a/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-mm.kcl.snap +++ b/rust/kcl-lib/tests/assembly_mixed_units_cubes/unparsed@cube-mm.kcl.snap @@ -5,7 +5,7 @@ description: Result of unparsing tests/assembly_mixed_units_cubes/cube-mm.kcl @settings(defaultLengthUnit = mm) sketch001 = startSketchOn(XY) -cubeMm = startProfileAt([10, 10], sketch001) +cubeMm = startProfile(sketch001, at = [10, 10]) |> xLine(length = 5) |> yLine(length = -5) |> xLine(length = -5) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/ast.snap b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/ast.snap index 77b1f06e8..8bfc96bae 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/ast.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing basic_fillet_cube_close_opposite.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing basic_fillet_cube_close_opposite.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing basic_fillet_cube_close_opposite.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/input.kcl b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/input.kcl index 5283257f9..32cde14fc 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/input.kcl +++ b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/unparsed.snap b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/unparsed.snap index 837d8eabb..6d9118f32 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_close_opposite/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_close_opposite.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_end/ast.snap b/rust/kcl-lib/tests/basic_fillet_cube_end/ast.snap index df3f4aaa2..82ae02b84 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_end/ast.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_end/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing basic_fillet_cube_end.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing basic_fillet_cube_end.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing basic_fillet_cube_end.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/basic_fillet_cube_end/input.kcl b/rust/kcl-lib/tests/basic_fillet_cube_end/input.kcl index 1c2a68b35..60d28dbbc 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_end/input.kcl +++ b/rust/kcl-lib/tests/basic_fillet_cube_end/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap b/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap index 7ccce9cf2..d189376df 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_end.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/ast.snap b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/ast.snap index d519bb631..f52b62f6e 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/ast.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing basic_fillet_cube_next_adjacent.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing basic_fillet_cube_next_adjacent.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing basic_fillet_cube_next_adjacent.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/input.kcl b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/input.kcl index ec7e60f82..beb7c70d5 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/input.kcl +++ b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/unparsed.snap b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/unparsed.snap index 9ff053f6b..7239e0e47 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_next_adjacent/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_next_adjacent.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/ast.snap b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/ast.snap index d2adda442..3acfa2d05 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/ast.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing basic_fillet_cube_previous_adjacent.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing basic_fillet_cube_previous_adjacent.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing basic_fillet_cube_previous_adjacent.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/input.kcl b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/input.kcl index e22ff5a54..100d29f3a 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/input.kcl +++ b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/unparsed.snap b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/unparsed.snap index 46eb82f52..10b47069e 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_previous_adjacent/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_previous_adjacent.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_start/ast.snap b/rust/kcl-lib/tests/basic_fillet_cube_start/ast.snap index 898910108..bc160fbdb 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_start/ast.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_start/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing basic_fillet_cube_start.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing basic_fillet_cube_start.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing basic_fillet_cube_start.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/basic_fillet_cube_start/input.kcl b/rust/kcl-lib/tests/basic_fillet_cube_start/input.kcl index 024d3c8ca..619e34c9a 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_start/input.kcl +++ b/rust/kcl-lib/tests/basic_fillet_cube_start/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap b/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap index 761d820db..6f1f29eb1 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_start.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) |> line(end = [0, -10], tag = $thing2) diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_x/ast.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/ast.snap new file mode 100644 index 000000000..25991a9ad --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/ast.snap @@ -0,0 +1,432 @@ +--- +source: kcl-lib/src/simulation_tests.rs +description: Result of parsing big_number_angle_to_match_length_x.kcl +--- +{ + "Ok": { + "body": [ + { + "commentStart": 0, + "declaration": { + "commentStart": 0, + "end": 0, + "id": { + "commentStart": 0, + "end": 0, + "name": "part001", + "start": 0, + "type": "Identifier" + }, + "init": { + "body": [ + { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "raw": "'XY'", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "XY" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startSketchOn", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startProfile", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "end", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "3.82", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.82, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "tag", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "TagDeclarator", + "type": "TagDeclarator", + "value": "seg01" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "line", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "angle", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "seg01", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "angleToMatchLengthX", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "endAbsoluteX", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "angledLine", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "close", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "10", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 10.0, + "suffix": "None" + } + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "extrude", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + } + ], + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeExpression", + "type": "PipeExpression" + }, + "start": 0, + "type": "VariableDeclarator" + }, + "end": 0, + "kind": "const", + "start": 0, + "type": "VariableDeclaration", + "type": "VariableDeclaration" + } + ], + "commentStart": 0, + "end": 0, + "start": 0 + } +} diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_x/input.kcl b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/input.kcl new file mode 100644 index 000000000..2f6ea6184 --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/input.kcl @@ -0,0 +1,6 @@ +part001 = startSketchOn('XY') + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angledLine(angle = -angleToMatchLengthX(seg01, 3, %), endAbsoluteX = 3) + |> close(%) + |> extrude(length = 10) diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_x/unparsed.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/unparsed.snap new file mode 100644 index 000000000..ad2b23c7c --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_x/unparsed.snap @@ -0,0 +1,10 @@ +--- +source: kcl-lib/src/simulation_tests.rs +description: Result of unparsing big_number_angle_to_match_length_x.kcl +--- +part001 = startSketchOn(XY) + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angledLine(angle = -angleToMatchLengthX(seg01, 3, %), endAbsoluteX = 3) + |> close(%) + |> extrude(length = 10) diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_y/ast.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/ast.snap new file mode 100644 index 000000000..54e0a3d41 --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/ast.snap @@ -0,0 +1,432 @@ +--- +source: kcl-lib/src/simulation_tests.rs +description: Result of parsing big_number_angle_to_match_length_y.kcl +--- +{ + "Ok": { + "body": [ + { + "commentStart": 0, + "declaration": { + "commentStart": 0, + "end": 0, + "id": { + "commentStart": 0, + "end": 0, + "name": "part001", + "start": 0, + "type": "Identifier" + }, + "init": { + "body": [ + { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "raw": "'XY'", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "XY" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startSketchOn", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startProfile", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "end", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "3.82", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.82, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "tag", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "TagDeclarator", + "type": "TagDeclarator", + "value": "seg01" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "line", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "angle", + "start": 0, + "type": "Identifier" + }, + "arg": { + "argument": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "seg01", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "angleToMatchLengthY", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + }, + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "endAbsoluteX", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "angledLine", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + }, + { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeSubstitution", + "type": "PipeSubstitution" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "close", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + { + "arguments": [ + { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "10", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 10.0, + "suffix": "None" + } + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "extrude", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null + } + ], + "commentStart": 0, + "end": 0, + "start": 0, + "type": "PipeExpression", + "type": "PipeExpression" + }, + "start": 0, + "type": "VariableDeclarator" + }, + "end": 0, + "kind": "const", + "start": 0, + "type": "VariableDeclaration", + "type": "VariableDeclaration" + } + ], + "commentStart": 0, + "end": 0, + "start": 0 + } +} diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_y/input.kcl b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/input.kcl new file mode 100644 index 000000000..1b1fda2da --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/input.kcl @@ -0,0 +1,6 @@ +part001 = startSketchOn('XY') + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angledLine(angle = -angleToMatchLengthY(seg01, 3, %), endAbsoluteX = 3) + |> close(%) + |> extrude(length = 10) diff --git a/rust/kcl-lib/tests/big_number_angle_to_match_length_y/unparsed.snap b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/unparsed.snap new file mode 100644 index 000000000..62b8c69a4 --- /dev/null +++ b/rust/kcl-lib/tests/big_number_angle_to_match_length_y/unparsed.snap @@ -0,0 +1,10 @@ +--- +source: kcl-lib/src/simulation_tests.rs +description: Result of unparsing big_number_angle_to_match_length_y.kcl +--- +part001 = startSketchOn(XY) + |> startProfile(at = [0, 0]) + |> line(end = [1, 3.82], tag = $seg01) + |> angledLine(angle = -angleToMatchLengthY(seg01, 3, %), endAbsoluteX = 3) + |> close(%) + |> extrude(length = 10) diff --git a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/ast.snap b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/ast.snap index a60fe1249..a28af4f58 100644 --- a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/ast.snap +++ b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing circular_pattern3d_a_pattern.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing circular_pattern3d_a_pattern.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing circular_pattern3d_a_pattern.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/input.kcl b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/input.kcl index cece9fa3f..4beb79e41 100644 --- a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/input.kcl +++ b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/input.kcl @@ -1,5 +1,5 @@ exampleSketch = startSketchOn('XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap index 025ac304f..153789daa 100644 --- a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing circular_pattern3d_a_pattern.kcl --- exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/tests/crazy_multi_profile/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/crazy_multi_profile/artifact_graph_flowchart.snap.md index 2d22763f9..d2ffc6953 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/crazy_multi_profile/artifact_graph_flowchart.snap.md @@ -1,85 +1,85 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[43, 83, 0]"] - 3["Segment
[89, 127, 0]"] - 4["Segment
[133, 172, 0]"] - 5["Segment
[178, 234, 0]"] - 6["Segment
[240, 247, 0]"] + 2["Path
[43, 86, 0]"] + 3["Segment
[92, 130, 0]"] + 4["Segment
[136, 175, 0]"] + 5["Segment
[181, 237, 0]"] + 6["Segment
[243, 250, 0]"] 7[Solid2d] end subgraph path20 [Path] - 20["Path
[359, 399, 0]"] - 21["Segment
[405, 429, 0]"] - 22["Segment
[435, 460, 0]"] + 20["Path
[362, 405, 0]"] + 21["Segment
[411, 435, 0]"] + 22["Segment
[441, 466, 0]"] end subgraph path23 [Path] - 23["Path
[474, 513, 0]"] - 24["Segment
[519, 584, 0]"] - 25["Segment
[590, 658, 0]"] - 26["Segment
[664, 752, 0]"] - 27["Segment
[758, 814, 0]"] - 28["Segment
[820, 827, 0]"] + 23["Path
[480, 522, 0]"] + 24["Segment
[528, 593, 0]"] + 25["Segment
[599, 667, 0]"] + 26["Segment
[673, 761, 0]"] + 27["Segment
[767, 823, 0]"] + 28["Segment
[829, 836, 0]"] 29[Solid2d] end subgraph path30 [Path] - 30["Path
[841, 880, 0]"] - 31["Segment
[886, 906, 0]"] - 32["Segment
[912, 938, 0]"] - 33["Segment
[944, 1000, 0]"] - 34["Segment
[1006, 1013, 0]"] + 30["Path
[850, 892, 0]"] + 31["Segment
[898, 918, 0]"] + 32["Segment
[924, 950, 0]"] + 33["Segment
[956, 1012, 0]"] + 34["Segment
[1018, 1025, 0]"] 35[Solid2d] end subgraph path36 [Path] - 36["Path
[1027, 1082, 0]"] - 37["Segment
[1027, 1082, 0]"] + 36["Path
[1039, 1094, 0]"] + 37["Segment
[1039, 1094, 0]"] 38[Solid2d] end subgraph path39 [Path] - 39["Path
[1096, 1135, 0]"] - 40["Segment
[1141, 1165, 0]"] - 41["Segment
[1171, 1196, 0]"] - 42["Segment
[1202, 1258, 0]"] - 43["Segment
[1264, 1271, 0]"] + 39["Path
[1108, 1150, 0]"] + 40["Segment
[1156, 1180, 0]"] + 41["Segment
[1186, 1211, 0]"] + 42["Segment
[1217, 1273, 0]"] + 43["Segment
[1279, 1286, 0]"] 44[Solid2d] end subgraph path59 [Path] - 59["Path
[1441, 1479, 0]"] - 60["Segment
[1485, 1509, 0]"] - 61["Segment
[1515, 1540, 0]"] + 59["Path
[1456, 1497, 0]"] + 60["Segment
[1503, 1527, 0]"] + 61["Segment
[1533, 1558, 0]"] end subgraph path62 [Path] - 62["Path
[1554, 1593, 0]"] - 63["Segment
[1599, 1623, 0]"] - 64["Segment
[1629, 1654, 0]"] - 65["Segment
[1660, 1716, 0]"] - 66["Segment
[1722, 1729, 0]"] + 62["Path
[1572, 1614, 0]"] + 63["Segment
[1620, 1644, 0]"] + 64["Segment
[1650, 1675, 0]"] + 65["Segment
[1681, 1737, 0]"] + 66["Segment
[1743, 1750, 0]"] 67[Solid2d] end subgraph path68 [Path] - 68["Path
[1743, 1782, 0]"] - 69["Segment
[1788, 1811, 0]"] - 70["Segment
[1817, 1842, 0]"] - 71["Segment
[1848, 1904, 0]"] - 72["Segment
[1910, 1917, 0]"] + 68["Path
[1764, 1806, 0]"] + 69["Segment
[1812, 1835, 0]"] + 70["Segment
[1841, 1866, 0]"] + 71["Segment
[1872, 1928, 0]"] + 72["Segment
[1934, 1941, 0]"] 73[Solid2d] end subgraph path74 [Path] - 74["Path
[1931, 1987, 0]"] - 75["Segment
[1931, 1987, 0]"] + 74["Path
[1955, 2011, 0]"] + 75["Segment
[1955, 2011, 0]"] 76[Solid2d] end subgraph path77 [Path] - 77["Path
[2001, 2041, 0]"] - 78["Segment
[2047, 2112, 0]"] - 79["Segment
[2118, 2186, 0]"] - 80["Segment
[2192, 2280, 0]"] - 81["Segment
[2286, 2342, 0]"] - 82["Segment
[2348, 2355, 0]"] + 77["Path
[2025, 2068, 0]"] + 78["Segment
[2074, 2139, 0]"] + 79["Segment
[2145, 2213, 0]"] + 80["Segment
[2219, 2307, 0]"] + 81["Segment
[2313, 2369, 0]"] + 82["Segment
[2375, 2382, 0]"] 83[Solid2d] end 1["Plane
[12, 29, 0]"] - 8["Sweep Extrusion
[261, 293, 0]"] + 8["Sweep Extrusion
[264, 296, 0]"] 9[Wall] 10[Wall] 11[Wall] @@ -91,8 +91,8 @@ flowchart LR 17["SweepEdge Adjacent"] 18["SweepEdge Opposite"] 19["SweepEdge Adjacent"] - 45["Sweep RevolveAboutEdge
[1285, 1351, 0]"] - 46["Sweep Extrusion
[1365, 1396, 0]"] + 45["Sweep RevolveAboutEdge
[1300, 1366, 0]"] + 46["Sweep Extrusion
[1380, 1411, 0]"] 47[Wall] 48[Wall] 49[Wall] @@ -104,8 +104,8 @@ flowchart LR 55["SweepEdge Adjacent"] 56["SweepEdge Opposite"] 57["SweepEdge Adjacent"] - 58["Plane
[1409, 1427, 0]"] - 84["Sweep Extrusion
[2369, 2402, 0]"] + 58["Plane
[1424, 1442, 0]"] + 84["Sweep Extrusion
[2396, 2429, 0]"] 85[Wall] 86[Wall] 87[Wall] @@ -120,7 +120,7 @@ flowchart LR 96["SweepEdge Adjacent"] 97["SweepEdge Opposite"] 98["SweepEdge Adjacent"] - 99["Sweep RevolveAboutEdge
[2416, 2461, 0]"] + 99["Sweep RevolveAboutEdge
[2443, 2488, 0]"] 100[Wall] 101[Wall] 102[Wall] @@ -132,7 +132,7 @@ flowchart LR 108["SweepEdge Adjacent"] 109["SweepEdge Opposite"] 110["SweepEdge Adjacent"] - 111["StartSketchOnFace
[306, 345, 0]"] + 111["StartSketchOnFace
[309, 348, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/crazy_multi_profile/ast.snap b/rust/kcl-lib/tests/crazy_multi_profile/ast.snap index 0f359917c..66d3fda65 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/ast.snap +++ b/rust/kcl-lib/tests/crazy_multi_profile/ast.snap @@ -83,61 +83,55 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "6.71", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 6.71, - "suffix": "None" - } - }, - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "raw": "3.66", + "raw": "6.71", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 3.66, + "value": 6.71, "suffix": "None" } }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "3.66", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.66, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], "end": 0, - "name": "sketch001", "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -147,7 +141,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -158,8 +152,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch001", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -673,53 +683,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.75", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.75, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "13.46", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 13.46, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch002", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.75", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.75, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "13.46", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 13.46, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -729,7 +733,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -740,8 +744,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -920,53 +940,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "3.19", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.19, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "13.3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 13.3, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch002", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "3.19", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.19, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "13.3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 13.3, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -976,7 +990,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -987,8 +1001,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -1489,53 +1519,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "3.15", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.15, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "9.39", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 9.39, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch002", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "3.15", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.15, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "9.39", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 9.39, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1545,7 +1569,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1556,8 +1580,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -1978,53 +2018,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "9.65", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 9.65, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "3.82", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.82, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch002", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "9.65", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 9.65, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "3.82", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.82, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2034,7 +2068,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2045,8 +2079,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -2639,53 +2689,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "4.8", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.8, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "7.55", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 7.55, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch003", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "4.8", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.8, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "7.55", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 7.55, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2695,7 +2739,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2706,8 +2750,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch003", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -2886,53 +2946,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "5.54", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.54, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "5.49", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.49, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch003", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "5.54", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.54, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "5.49", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.49, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2942,7 +2996,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2953,8 +3007,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch003", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -3262,53 +3332,47 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "5.23", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.23, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "1.95", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.95, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch003", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "5.23", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.23, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "1.95", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.95, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3318,7 +3382,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3329,8 +3393,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch003", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -3772,61 +3852,55 @@ description: Result of parsing crazy_multi_profile.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "5.07", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.07, - "suffix": "None" - } - }, - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "raw": "6.39", + "raw": "5.07", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 6.39, + "value": 5.07, "suffix": "None" } }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "6.39", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 6.39, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], "end": 0, - "name": "sketch003", "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3836,7 +3910,7 @@ description: Result of parsing crazy_multi_profile.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3847,8 +3921,24 @@ description: Result of parsing crazy_multi_profile.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch003", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ diff --git a/rust/kcl-lib/tests/crazy_multi_profile/input.kcl b/rust/kcl-lib/tests/crazy_multi_profile/input.kcl index fbc87b9ac..00710bd37 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/input.kcl +++ b/rust/kcl-lib/tests/crazy_multi_profile/input.kcl @@ -1,27 +1,27 @@ sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([6.71, -3.66], sketch001) +profile001 = startProfile(sketch001, at = [6.71, -3.66]) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 20) sketch002 = startSketchOn(extrude001, face = seg01) -profile002 = startProfileAt([0.75, 13.46], sketch002) +profile002 = startProfile(sketch002, at = [0.75, 13.46]) |> line(end = [4.52, 3.79]) |> line(end = [5.98, -2.81]) -profile003 = startProfileAt([3.19, 13.3], sketch002) +profile003 = startProfile(sketch002, at = [3.19, 13.3]) |> angledLine(angle = 0, length = 6.64, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 2.81) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile004 = startProfileAt([3.15, 9.39], sketch002) +profile004 = startProfile(sketch002, at = [3.15, 9.39]) |> xLine(length = 6.92) |> line(end = [-7.41, -2.85]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() profile005 = circle(sketch002, center = [5.15, 4.34], radius = 1.66) -profile006 = startProfileAt([9.65, 3.82], sketch002) +profile006 = startProfile(sketch002, at = [9.65, 3.82]) |> line(end = [2.38, 5.62]) |> line(end = [2.13, -5.57]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -29,21 +29,21 @@ profile006 = startProfileAt([9.65, 3.82], sketch002) revolve001 = revolve(profile004, angle = 45, axis = getNextAdjacentEdge(seg01)) extrude002 = extrude(profile006, length = 4) sketch003 = startSketchOn(-XZ) -profile007 = startProfileAt([4.8, 7.55], sketch003) +profile007 = startProfile(sketch003, at = [4.8, 7.55]) |> line(end = [7.39, 2.58]) |> line(end = [7.02, -2.85]) -profile008 = startProfileAt([5.54, 5.49], sketch003) +profile008 = startProfile(sketch003, at = [5.54, 5.49]) |> line(end = [6.34, 2.64]) |> line(end = [6.33, -2.96]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile009 = startProfileAt([5.23, 1.95], sketch003) +profile009 = startProfile(sketch003, at = [5.23, 1.95]) |> line(end = [6.8, 2.17]) |> line(end = [7.34, -2.75]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() profile010 = circle(sketch003, center = [7.18, -2.11], radius = 2.67) -profile011 = startProfileAt([5.07, -6.39], sketch003) +profile011 = startProfile(sketch003, at = [5.07, -6.39]) |> angledLine(angle = 0, length = 4.54, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 4.17) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) diff --git a/rust/kcl-lib/tests/crazy_multi_profile/program_memory.snap b/rust/kcl-lib/tests/crazy_multi_profile/program_memory.snap index a22eab2c2..056982ed7 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/program_memory.snap +++ b/rust/kcl-lib/tests/crazy_multi_profile/program_memory.snap @@ -15,9 +15,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -28,9 +28,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -58,9 +58,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -83,9 +83,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -351,9 +351,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -364,9 +364,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -394,9 +394,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -419,9 +419,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -594,9 +594,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2090, - "end": 2111, - "start": 2090, + "commentStart": 2117, + "end": 2138, + "start": 2117, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -638,9 +638,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -6.39 ], "tag": { - "commentStart": 2090, - "end": 2111, - "start": 2090, + "commentStart": 2117, + "end": 2138, + "start": 2117, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -815,9 +815,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -840,9 +840,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1035,9 +1035,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1048,9 +1048,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1078,9 +1078,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1103,9 +1103,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1274,9 +1274,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 13.3 ], "tag": { - "commentStart": 562, - "end": 583, - "start": 562, + "commentStart": 571, + "end": 592, + "start": 571, "type": "TagDeclarator", "value": "rectangleSegmentA001" }, @@ -1397,9 +1397,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1410,9 +1410,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1440,9 +1440,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1465,9 +1465,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1740,9 +1740,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1753,9 +1753,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -1783,9 +1783,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -1808,9 +1808,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -2026,9 +2026,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -2039,9 +2039,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -2069,9 +2069,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -2094,9 +2094,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -2363,9 +2363,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -2376,9 +2376,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -2406,9 +2406,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -2431,9 +2431,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -3065,9 +3065,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -6.39 ], "tag": { - "commentStart": 2090, - "end": 2111, - "start": 2090, + "commentStart": 2117, + "end": 2138, + "start": 2117, "type": "TagDeclarator", "value": "rectangleSegmentA002" }, @@ -3347,9 +3347,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -3360,9 +3360,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -3390,9 +3390,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -3415,9 +3415,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -3825,9 +3825,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -3838,9 +3838,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, @@ -3868,9 +3868,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl -3.66 ], "tag": { - "commentStart": 120, - "end": 126, - "start": 120, + "commentStart": 123, + "end": 129, + "start": 123, "type": "TagDeclarator", "value": "seg02" }, @@ -3893,9 +3893,9 @@ description: Variables in memory after executing crazy_multi_profile.kcl 5.36 ], "tag": { - "commentStart": 165, - "end": 171, - "start": 165, + "commentStart": 168, + "end": 174, + "start": 168, "type": "TagDeclarator", "value": "seg01" }, diff --git a/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap b/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap index 6a6f69307..bf27cae58 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap +++ b/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap @@ -3,29 +3,29 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing crazy_multi_profile.kcl --- sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([6.71, -3.66], sketch001) +profile001 = startProfile(sketch001, at = [6.71, -3.66]) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 20) sketch002 = startSketchOn(extrude001, face = seg01) -profile002 = startProfileAt([0.75, 13.46], sketch002) +profile002 = startProfile(sketch002, at = [0.75, 13.46]) |> line(end = [4.52, 3.79]) |> line(end = [5.98, -2.81]) -profile003 = startProfileAt([3.19, 13.3], sketch002) +profile003 = startProfile(sketch002, at = [3.19, 13.3]) |> angledLine(angle = 0, length = 6.64, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 2.81) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile004 = startProfileAt([3.15, 9.39], sketch002) +profile004 = startProfile(sketch002, at = [3.15, 9.39]) |> xLine(length = 6.92) |> line(end = [-7.41, -2.85]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() profile005 = circle(sketch002, center = [5.15, 4.34], radius = 1.66) -profile006 = startProfileAt([9.65, 3.82], sketch002) +profile006 = startProfile(sketch002, at = [9.65, 3.82]) |> line(end = [2.38, 5.62]) |> line(end = [2.13, -5.57]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -33,21 +33,21 @@ profile006 = startProfileAt([9.65, 3.82], sketch002) revolve001 = revolve(profile004, angle = 45, axis = getNextAdjacentEdge(seg01)) extrude002 = extrude(profile006, length = 4) sketch003 = startSketchOn(-XZ) -profile007 = startProfileAt([4.8, 7.55], sketch003) +profile007 = startProfile(sketch003, at = [4.8, 7.55]) |> line(end = [7.39, 2.58]) |> line(end = [7.02, -2.85]) -profile008 = startProfileAt([5.54, 5.49], sketch003) +profile008 = startProfile(sketch003, at = [5.54, 5.49]) |> line(end = [6.34, 2.64]) |> line(end = [6.33, -2.96]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -profile009 = startProfileAt([5.23, 1.95], sketch003) +profile009 = startProfile(sketch003, at = [5.23, 1.95]) |> line(end = [6.8, 2.17]) |> line(end = [7.34, -2.75]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() profile010 = circle(sketch003, center = [7.18, -2.11], radius = 2.67) -profile011 = startProfileAt([5.07, -6.39], sketch003) +profile011 = startProfile(sketch003, at = [5.07, -6.39]) |> angledLine(angle = 0, length = 4.54, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 4.17) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002)) diff --git a/rust/kcl-lib/tests/cube/ast.snap b/rust/kcl-lib/tests/cube/ast.snap index f6c8a8113..7a171d947 100644 --- a/rust/kcl-lib/tests/cube/ast.snap +++ b/rust/kcl-lib/tests/cube/ast.snap @@ -693,27 +693,30 @@ description: Result of parsing cube.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "p0", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "p0", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -723,7 +726,7 @@ description: Result of parsing cube.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -734,8 +737,9 @@ description: Result of parsing cube.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/cube/input.kcl b/rust/kcl-lib/tests/cube/input.kcl index f93984842..f751cb9c9 100644 --- a/rust/kcl-lib/tests/cube/input.kcl +++ b/rust/kcl-lib/tests/cube/input.kcl @@ -8,7 +8,7 @@ fn cube(sideLength, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/cube/unparsed.snap b/rust/kcl-lib/tests/cube/unparsed.snap index 166c0e2a0..816a04c65 100644 --- a/rust/kcl-lib/tests/cube/unparsed.snap +++ b/rust/kcl-lib/tests/cube/unparsed.snap @@ -12,7 +12,7 @@ fn cube(sideLength, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/cube_with_error/ast.snap b/rust/kcl-lib/tests/cube_with_error/ast.snap index 0209a8d5a..bbdd37fea 100644 --- a/rust/kcl-lib/tests/cube_with_error/ast.snap +++ b/rust/kcl-lib/tests/cube_with_error/ast.snap @@ -693,27 +693,30 @@ description: Result of parsing cube_with_error.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "p0", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "p0", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -723,7 +726,7 @@ description: Result of parsing cube_with_error.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -734,8 +737,9 @@ description: Result of parsing cube_with_error.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/cube_with_error/input.kcl b/rust/kcl-lib/tests/cube_with_error/input.kcl index cdb69c74e..0331a1285 100644 --- a/rust/kcl-lib/tests/cube_with_error/input.kcl +++ b/rust/kcl-lib/tests/cube_with_error/input.kcl @@ -8,7 +8,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/cube_with_error/unparsed.snap b/rust/kcl-lib/tests/cube_with_error/unparsed.snap index 53423cd8f..4ff3a9e1b 100644 --- a/rust/kcl-lib/tests/cube_with_error/unparsed.snap +++ b/rust/kcl-lib/tests/cube_with_error/unparsed.snap @@ -12,7 +12,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/fillet-and-shell/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/fillet-and-shell/artifact_graph_flowchart.snap.md index c2f08c244..03596a87a 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/fillet-and-shell/artifact_graph_flowchart.snap.md @@ -1,76 +1,76 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[396, 488, 0]"] - 3["Segment
[494, 585, 0]"] - 4["Segment
[591, 682, 0]"] - 5["Segment
[688, 781, 0]"] - 6["Segment
[787, 795, 0]"] + 2["Path
[396, 467, 0]"] + 3["Segment
[473, 564, 0]"] + 4["Segment
[570, 661, 0]"] + 5["Segment
[667, 760, 0]"] + 6["Segment
[766, 774, 0]"] 7[Solid2d] end subgraph path9 [Path] - 9["Path
[829, 854, 0]"] - 10["Segment
[860, 908, 0]"] - 11["Segment
[914, 971, 0]"] - 12["Segment
[977, 1026, 0]"] - 13["Segment
[1032, 1051, 0]"] + 9["Path
[808, 833, 0]"] + 10["Segment
[839, 887, 0]"] + 11["Segment
[893, 950, 0]"] + 12["Segment
[956, 1005, 0]"] + 13["Segment
[1011, 1030, 0]"] 14[Solid2d] end subgraph path31 [Path] - 31["Path
[1364, 1389, 0]"] + 31["Path
[1343, 1368, 0]"] end subgraph path32 [Path] - 32["Path
[1397, 1434, 0]"] - 33["Segment
[1397, 1434, 0]"] + 32["Path
[1376, 1413, 0]"] + 33["Segment
[1376, 1413, 0]"] 34[Solid2d] end subgraph path35 [Path] - 35["Path
[1447, 1485, 0]"] - 36["Segment
[1447, 1485, 0]"] + 35["Path
[1426, 1464, 0]"] + 36["Segment
[1426, 1464, 0]"] 37[Solid2d] end subgraph path45 [Path] - 45["Path
[1364, 1389, 0]"] + 45["Path
[1343, 1368, 0]"] end subgraph path46 [Path] - 46["Path
[1397, 1434, 0]"] - 47["Segment
[1397, 1434, 0]"] + 46["Path
[1376, 1413, 0]"] + 47["Segment
[1376, 1413, 0]"] 48[Solid2d] end subgraph path49 [Path] - 49["Path
[1447, 1485, 0]"] - 50["Segment
[1447, 1485, 0]"] + 49["Path
[1426, 1464, 0]"] + 50["Segment
[1426, 1464, 0]"] 51[Solid2d] end subgraph path59 [Path] - 59["Path
[1364, 1389, 0]"] + 59["Path
[1343, 1368, 0]"] end subgraph path60 [Path] - 60["Path
[1397, 1434, 0]"] - 61["Segment
[1397, 1434, 0]"] + 60["Path
[1376, 1413, 0]"] + 61["Segment
[1376, 1413, 0]"] 62[Solid2d] end subgraph path63 [Path] - 63["Path
[1447, 1485, 0]"] - 64["Segment
[1447, 1485, 0]"] + 63["Path
[1426, 1464, 0]"] + 64["Segment
[1426, 1464, 0]"] 65[Solid2d] end subgraph path73 [Path] - 73["Path
[1364, 1389, 0]"] + 73["Path
[1343, 1368, 0]"] end subgraph path74 [Path] - 74["Path
[1397, 1434, 0]"] - 75["Segment
[1397, 1434, 0]"] + 74["Path
[1376, 1413, 0]"] + 75["Segment
[1376, 1413, 0]"] 76[Solid2d] end subgraph path77 [Path] - 77["Path
[1447, 1485, 0]"] - 78["Segment
[1447, 1485, 0]"] + 77["Path
[1426, 1464, 0]"] + 78["Segment
[1426, 1464, 0]"] 79[Solid2d] end 1["Plane
[373, 390, 0]"] - 8["Plane
[804, 823, 0]"] - 15["Sweep Extrusion
[1057, 1085, 0]"] + 8["Plane
[783, 802, 0]"] + 15["Sweep Extrusion
[1036, 1064, 0]"] 16[Wall] 17[Wall] 18[Wall] @@ -85,38 +85,38 @@ flowchart LR 27["SweepEdge Adjacent"] 28["SweepEdge Opposite"] 29["SweepEdge Adjacent"] - 30["Plane
[1337, 1356, 0]"] - 38["Sweep Extrusion
[1497, 1521, 0]"] + 30["Plane
[1316, 1335, 0]"] + 38["Sweep Extrusion
[1476, 1500, 0]"] 39[Wall] 40["Cap Start"] 41["Cap End"] 42["SweepEdge Opposite"] 43["SweepEdge Adjacent"] - 44["Plane
[1337, 1356, 0]"] - 52["Sweep Extrusion
[1497, 1521, 0]"] + 44["Plane
[1316, 1335, 0]"] + 52["Sweep Extrusion
[1476, 1500, 0]"] 53[Wall] 54["Cap Start"] 55["Cap End"] 56["SweepEdge Opposite"] 57["SweepEdge Adjacent"] - 58["Plane
[1337, 1356, 0]"] - 66["Sweep Extrusion
[1497, 1521, 0]"] + 58["Plane
[1316, 1335, 0]"] + 66["Sweep Extrusion
[1476, 1500, 0]"] 67[Wall] 68["Cap Start"] 69["Cap End"] 70["SweepEdge Opposite"] 71["SweepEdge Adjacent"] - 72["Plane
[1337, 1356, 0]"] - 80["Sweep Extrusion
[1497, 1521, 0]"] + 72["Plane
[1316, 1335, 0]"] + 80["Sweep Extrusion
[1476, 1500, 0]"] 81[Wall] 82["Cap Start"] 83["Cap End"] 84["SweepEdge Opposite"] 85["SweepEdge Adjacent"] - 86["EdgeCut Fillet
[1091, 1297, 0]"] - 87["EdgeCut Fillet
[1091, 1297, 0]"] - 88["EdgeCut Fillet
[1091, 1297, 0]"] - 89["EdgeCut Fillet
[1091, 1297, 0]"] + 86["EdgeCut Fillet
[1070, 1276, 0]"] + 87["EdgeCut Fillet
[1070, 1276, 0]"] + 88["EdgeCut Fillet
[1070, 1276, 0]"] + 89["EdgeCut Fillet
[1070, 1276, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/fillet-and-shell/ast.snap b/rust/kcl-lib/tests/fillet-and-shell/ast.snap index e9b972173..275eb2056 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/ast.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/ast.snap @@ -706,116 +706,119 @@ description: Result of parsing fillet-and-shell.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "border", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "miniHdmiDistance", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "-", + "right": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "miniHdmiWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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" } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "border", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "miniHdmiDistance", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "-", - "right": { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "miniHdmiWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "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" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -825,7 +828,7 @@ description: Result of parsing fillet-and-shell.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -836,8 +839,9 @@ description: Result of parsing fillet-and-shell.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1356,44 +1360,47 @@ description: Result of parsing fillet-and-shell.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1403,7 +1410,7 @@ description: Result of parsing fillet-and-shell.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1414,8 +1421,9 @@ description: Result of parsing fillet-and-shell.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2092,44 +2100,47 @@ description: Result of parsing fillet-and-shell.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2139,7 +2150,7 @@ description: Result of parsing fillet-and-shell.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2150,8 +2161,9 @@ description: Result of parsing fillet-and-shell.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/fillet-and-shell/input.kcl b/rust/kcl-lib/tests/fillet-and-shell/input.kcl index db78fb19a..6368d5bd6 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/input.kcl +++ b/rust/kcl-lib/tests/fillet-and-shell/input.kcl @@ -23,10 +23,7 @@ microUsbWidth = 7.4 connectorPadding = 4 miniHdmiHole = startSketchOn(XY) - |> startProfileAt([ - 0, - border + miniHdmiDistance - (miniHdmiWidth / 2) - ], %) + |> startProfile(at = [0, border + miniHdmiDistance - (miniHdmiWidth / 2)]) |> line(endAbsolute = [ 0, border + miniHdmiDistance + miniHdmiWidth / 2 @@ -42,7 +39,7 @@ miniHdmiHole = startSketchOn(XY) |> close(%) case = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [caseWidth, 0], tag = $edge1) |> line(endAbsolute = [caseWidth, caseLength], tag = $edge2) |> line(endAbsolute = [0, caseLength], tag = $edge3) @@ -60,7 +57,7 @@ case = startSketchOn('XY') fn m25Screw(x, y, height) { screw = startSketchOn("XY") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle(center = [x, y], radius = 2.5) |> hole(circle(center = [x, y], radius = 1.25), %) |> extrude(length = height) diff --git a/rust/kcl-lib/tests/fillet-and-shell/ops.snap b/rust/kcl-lib/tests/fillet-and-shell/ops.snap index 98ed83ff8..5fa401692 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/ops.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/ops.snap @@ -127,8 +127,8 @@ description: Operations executed fillet-and-shell.kcl "type": "FunctionCall", "name": "m25Screw", "functionSourceRange": [ - 1310, - 1538, + 1289, + 1517, 0 ], "unlabeledArg": null, @@ -218,8 +218,8 @@ description: Operations executed fillet-and-shell.kcl "type": "FunctionCall", "name": "m25Screw", "functionSourceRange": [ - 1310, - 1538, + 1289, + 1517, 0 ], "unlabeledArg": null, @@ -309,8 +309,8 @@ description: Operations executed fillet-and-shell.kcl "type": "FunctionCall", "name": "m25Screw", "functionSourceRange": [ - 1310, - 1538, + 1289, + 1517, 0 ], "unlabeledArg": null, @@ -400,8 +400,8 @@ description: Operations executed fillet-and-shell.kcl "type": "FunctionCall", "name": "m25Screw", "functionSourceRange": [ - 1310, - 1538, + 1289, + 1517, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/fillet-and-shell/program_memory.snap b/rust/kcl-lib/tests/fillet-and-shell/program_memory.snap index 1beef5260..d7841e09b 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/program_memory.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/program_memory.snap @@ -28,9 +28,9 @@ description: Variables in memory after executing fillet-and-shell.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 901, - "end": 907, - "start": 901, + "commentStart": 880, + "end": 886, + "start": 880, "type": "TagDeclarator", "value": "edge1" }, @@ -41,9 +41,9 @@ description: Variables in memory after executing fillet-and-shell.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 964, - "end": 970, - "start": 964, + "commentStart": 943, + "end": 949, + "start": 943, "type": "TagDeclarator", "value": "edge2" }, @@ -54,9 +54,9 @@ description: Variables in memory after executing fillet-and-shell.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1019, - "end": 1025, - "start": 1019, + "commentStart": 998, + "end": 1004, + "start": 998, "type": "TagDeclarator", "value": "edge3" }, @@ -67,9 +67,9 @@ description: Variables in memory after executing fillet-and-shell.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1044, - "end": 1050, - "start": 1044, + "commentStart": 1023, + "end": 1029, + "start": 1023, "type": "TagDeclarator", "value": "edge4" }, @@ -90,9 +90,9 @@ description: Variables in memory after executing fillet-and-shell.kcl 0.0 ], "tag": { - "commentStart": 901, - "end": 907, - "start": 901, + "commentStart": 880, + "end": 886, + "start": 880, "type": "TagDeclarator", "value": "edge1" }, @@ -115,9 +115,9 @@ description: Variables in memory after executing fillet-and-shell.kcl 0.0 ], "tag": { - "commentStart": 964, - "end": 970, - "start": 964, + "commentStart": 943, + "end": 949, + "start": 943, "type": "TagDeclarator", "value": "edge2" }, @@ -140,9 +140,9 @@ description: Variables in memory after executing fillet-and-shell.kcl 73.0 ], "tag": { - "commentStart": 1019, - "end": 1025, - "start": 1019, + "commentStart": 998, + "end": 1004, + "start": 998, "type": "TagDeclarator", "value": "edge3" }, @@ -165,9 +165,9 @@ description: Variables in memory after executing fillet-and-shell.kcl 73.0 ], "tag": { - "commentStart": 1044, - "end": 1050, - "start": 1044, + "commentStart": 1023, + "end": 1029, + "start": 1023, "type": "TagDeclarator", "value": "edge4" }, diff --git a/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap b/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap index 2e913b79f..526654168 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap @@ -27,10 +27,10 @@ microUsbWidth = 7.4 connectorPadding = 4 miniHdmiHole = startSketchOn(XY) - |> startProfileAt([ + |> startProfile(at = [ 0, border + miniHdmiDistance - (miniHdmiWidth / 2) - ], %) + ]) |> line(endAbsolute = [ 0, border + miniHdmiDistance + miniHdmiWidth / 2 @@ -46,7 +46,7 @@ miniHdmiHole = startSketchOn(XY) |> close(%) case = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [caseWidth, 0], tag = $edge1) |> line(endAbsolute = [caseWidth, caseLength], tag = $edge2) |> line(endAbsolute = [0, caseLength], tag = $edge3) @@ -64,7 +64,7 @@ case = startSketchOn(XY) fn m25Screw(x, y, height) { screw = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> circle(center = [x, y], radius = 2.5) |> hole(circle(center = [x, y], radius = 1.25), %) |> extrude(length = height) diff --git a/rust/kcl-lib/tests/function_sketch/ast.snap b/rust/kcl-lib/tests/function_sketch/ast.snap index 0564a1502..9543c1460 100644 --- a/rust/kcl-lib/tests/function_sketch/ast.snap +++ b/rust/kcl-lib/tests/function_sketch/ast.snap @@ -70,44 +70,47 @@ description: Result of parsing function_sketch.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -117,7 +120,7 @@ description: Result of parsing function_sketch.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -128,8 +131,9 @@ description: Result of parsing function_sketch.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/function_sketch/input.kcl b/rust/kcl-lib/tests/function_sketch/input.kcl index 36c62b50b..3f409324e 100644 --- a/rust/kcl-lib/tests/function_sketch/input.kcl +++ b/rust/kcl-lib/tests/function_sketch/input.kcl @@ -1,6 +1,6 @@ fn box(h, l, w) { myBox = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/tests/function_sketch/unparsed.snap b/rust/kcl-lib/tests/function_sketch/unparsed.snap index 772c58ea0..ad3e8ad12 100644 --- a/rust/kcl-lib/tests/function_sketch/unparsed.snap +++ b/rust/kcl-lib/tests/function_sketch/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing function_sketch.kcl --- fn box(h, l, w) { myBox = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/tests/function_sketch_with_position/ast.snap b/rust/kcl-lib/tests/function_sketch_with_position/ast.snap index 71a643b96..1bedb6bb0 100644 --- a/rust/kcl-lib/tests/function_sketch_with_position/ast.snap +++ b/rust/kcl-lib/tests/function_sketch_with_position/ast.snap @@ -70,27 +70,30 @@ description: Result of parsing function_sketch_with_position.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "p", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "p", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -100,7 +103,7 @@ description: Result of parsing function_sketch_with_position.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -111,8 +114,9 @@ description: Result of parsing function_sketch_with_position.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/function_sketch_with_position/input.kcl b/rust/kcl-lib/tests/function_sketch_with_position/input.kcl index 7a4f0a570..6ee443316 100644 --- a/rust/kcl-lib/tests/function_sketch_with_position/input.kcl +++ b/rust/kcl-lib/tests/function_sketch_with_position/input.kcl @@ -1,6 +1,6 @@ fn box(p, h, l, w) { myBox = startSketchOn('XY') - |> startProfileAt(p, %) + |> startProfile(at = p) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap b/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap index 7642a5451..ffa71009e 100644 --- a/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap +++ b/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing function_sketch_with_position.kcl --- fn box(p, h, l, w) { myBox = startSketchOn(XY) - |> startProfileAt(p, %) + |> startProfile(at = p) |> line(end = [0, l]) |> line(end = [w, 0]) |> line(end = [0, -l]) diff --git a/rust/kcl-lib/tests/helix_simple/ast.snap b/rust/kcl-lib/tests/helix_simple/ast.snap index a118e0dc2..8c5344527 100644 --- a/rust/kcl-lib/tests/helix_simple/ast.snap +++ b/rust/kcl-lib/tests/helix_simple/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing helix_simple.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing helix_simple.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing helix_simple.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/helix_simple/input.kcl b/rust/kcl-lib/tests/helix_simple/input.kcl index b0c9b9c67..d67a35af5 100644 --- a/rust/kcl-lib/tests/helix_simple/input.kcl +++ b/rust/kcl-lib/tests/helix_simple/input.kcl @@ -1,6 +1,6 @@ // Create a helix around an edge. helper001 = startSketchOn('XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $edge001) helixPath = helix( diff --git a/rust/kcl-lib/tests/helix_simple/unparsed.snap b/rust/kcl-lib/tests/helix_simple/unparsed.snap index 4a86b68ff..376d17580 100644 --- a/rust/kcl-lib/tests/helix_simple/unparsed.snap +++ b/rust/kcl-lib/tests/helix_simple/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing helix_simple.kcl --- // Create a helix around an edge. helper001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10], tag = $edge001) helixPath = helix( diff --git a/rust/kcl-lib/tests/i_shape/ast.snap b/rust/kcl-lib/tests/i_shape/ast.snap index eb9a2389d..ab243b990 100644 --- a/rust/kcl-lib/tests/i_shape/ast.snap +++ b/rust/kcl-lib/tests/i_shape/ast.snap @@ -396,48 +396,51 @@ description: Result of parsing i_shape.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "corner_radius", + "name": { + "commentStart": 0, + "end": 0, + "name": "corner_radius", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -447,7 +450,7 @@ description: Result of parsing i_shape.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -458,8 +461,9 @@ description: Result of parsing i_shape.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2885,44 +2889,47 @@ description: Result of parsing i_shape.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2932,7 +2939,7 @@ description: Result of parsing i_shape.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2943,8 +2950,9 @@ description: Result of parsing i_shape.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/i_shape/input.kcl b/rust/kcl-lib/tests/i_shape/input.kcl index 3e76da0c0..717f8c091 100644 --- a/rust/kcl-lib/tests/i_shape/input.kcl +++ b/rust/kcl-lib/tests/i_shape/input.kcl @@ -8,7 +8,7 @@ corner_radius = 5.0 // but I measured intentionally to not be symmetric, // because your wrist isn't a perfect cylindrical surface brace_base = startSketchOn(XY) - |> startProfileAt([corner_radius, 0], %) + |> startProfile(at = [corner_radius, 0]) |> line(end = [width - corner_radius, 0.0]) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - corner_radius) @@ -36,7 +36,7 @@ brace_base = startSketchOn(XY) |> close(%) inner = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 1.0) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - (corner_radius * 2)) diff --git a/rust/kcl-lib/tests/i_shape/unparsed.snap b/rust/kcl-lib/tests/i_shape/unparsed.snap index 0e47c18ac..f560ca860 100644 --- a/rust/kcl-lib/tests/i_shape/unparsed.snap +++ b/rust/kcl-lib/tests/i_shape/unparsed.snap @@ -12,7 +12,7 @@ corner_radius = 5.0 // but I measured intentionally to not be symmetric, // because your wrist isn't a perfect cylindrical surface brace_base = startSketchOn(XY) - |> startProfileAt([corner_radius, 0], %) + |> startProfile(at = [corner_radius, 0]) |> line(end = [width - corner_radius, 0.0]) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - corner_radius) @@ -40,7 +40,7 @@ brace_base = startSketchOn(XY) |> close(%) inner = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = 1.0) |> tangentialArc(end = [corner_radius, corner_radius]) |> yLine(length = 25.0 - (corner_radius * 2)) diff --git a/rust/kcl-lib/tests/import_async/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/import_async/artifact_graph_flowchart.snap.md index 3ff559dcc..63249d940 100644 --- a/rust/kcl-lib/tests/import_async/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/import_async/artifact_graph_flowchart.snap.md @@ -214,13 +214,13 @@ flowchart LR 218[Solid2d] end subgraph path220 [Path] - 220["Path
[2309, 2409, 0]"] - 221["Segment
[2415, 2442, 0]"] - 222["Segment
[2448, 2476, 0]"] - 223["Segment
[2482, 2510, 0]"] - 224["Segment
[2516, 2632, 0]"] - 225["Segment
[2638, 2743, 0]"] - 226["Segment
[2749, 2756, 0]"] + 220["Path
[2309, 2388, 0]"] + 221["Segment
[2394, 2421, 0]"] + 222["Segment
[2427, 2455, 0]"] + 223["Segment
[2461, 2489, 0]"] + 224["Segment
[2495, 2611, 0]"] + 225["Segment
[2617, 2722, 0]"] + 226["Segment
[2728, 2735, 0]"] 227[Solid2d] end 1["Plane
[168, 185, 0]"] @@ -233,7 +233,7 @@ flowchart LR 11["SweepEdge Adjacent"] 12["Plane
[1565, 1582, 0]"] 219["Sweep Extrusion
[1834, 1862, 0]"] - 228["Sweep Extrusion
[2762, 2791, 0]"] + 228["Sweep Extrusion
[2741, 2770, 0]"] 229[Wall] 230[Wall] 231[Wall] diff --git a/rust/kcl-lib/tests/import_async/ast.snap b/rust/kcl-lib/tests/import_async/ast.snap index fc85446fa..3ac430a51 100644 --- a/rust/kcl-lib/tests/import_async/ast.snap +++ b/rust/kcl-lib/tests/import_async/ast.snap @@ -3053,76 +3053,79 @@ description: Result of parsing import_async.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, + "computed": false, "end": 0, - "name": "xs", + "object": { + "commentStart": 0, + "end": 0, + "name": "xs", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "101", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 101.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier", - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "property": { + { "commentStart": 0, + "computed": false, "end": 0, - "raw": "101", + "object": { + "commentStart": 0, + "end": 0, + "name": "ys", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "101", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 101.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 101.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "ys", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "101", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 101.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "MemberExpression", + "type": "MemberExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3132,7 +3135,7 @@ description: Result of parsing import_async.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3143,8 +3146,9 @@ description: Result of parsing import_async.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null } ], "commentStart": 0, @@ -4121,148 +4125,151 @@ description: Result of parsing import_async.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "holeRadius", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "startAngle", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "callee": { + "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "cos", + "name": "holeRadius", "start": 0, "type": "Identifier" }, "path": [], "start": 0, + "type": "Name", "type": "Name" }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "holeRadius", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { + "operator": "*", + "right": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startAngle", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "callee": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "startAngle", + "name": "cos", "start": 0, "type": "Identifier" }, "path": [], "start": 0, - "type": "Name", "type": "Name" - } - ], - "callee": { + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "sin", + "name": "holeRadius", "start": 0, "type": "Identifier" }, "path": [], "start": 0, + "type": "Name", "type": "Name" }, - "commentStart": 0, - "end": 0, + "operator": "*", + "right": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startAngle", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sin", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4272,7 +4279,7 @@ description: Result of parsing import_async.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4283,8 +4290,9 @@ description: Result of parsing import_async.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/import_async/input.kcl b/rust/kcl-lib/tests/import_async/input.kcl index 7802ae6de..34b29812b 100644 --- a/rust/kcl-lib/tests/import_async/input.kcl +++ b/rust/kcl-lib/tests/import_async/input.kcl @@ -66,7 +66,7 @@ fn rightInvolute(i, sg) { // Draw gear teeth start = startSketchOn(XY) - |> startProfileAt([xs[101], ys[101]], %) + |> startProfile(at = [xs[101], ys[101]]) teeth = reduce([0..100], start, leftInvolute) |> arc( angleStart = 0, @@ -93,10 +93,7 @@ startAngle = asin(keywayWidth / 2 / holeRadius) // Sketch the keyway and center hole and extrude keyWay = startSketchOn(body, face = END) - |> startProfileAt([ - holeRadius * cos(startAngle), - holeRadius * sin(startAngle) - ], %) + |> startProfile(at = [holeRadius * cos(startAngle), holeRadius * sin(startAngle)]) |> xLine(length = keywayDepth) |> yLine(length = -keywayWidth) |> xLine(length = -keywayDepth) diff --git a/rust/kcl-lib/tests/import_async/ops.snap b/rust/kcl-lib/tests/import_async/ops.snap index c359fa6bd..cd0c15421 100644 --- a/rust/kcl-lib/tests/import_async/ops.snap +++ b/rust/kcl-lib/tests/import_async/ops.snap @@ -36,8 +36,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -72,8 +72,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -90,8 +90,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -108,8 +108,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -126,8 +126,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -144,8 +144,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -162,8 +162,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -180,8 +180,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -198,8 +198,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -216,8 +216,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -234,8 +234,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -252,8 +252,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -270,8 +270,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -288,8 +288,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -306,8 +306,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -324,8 +324,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -342,8 +342,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -360,8 +360,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -378,8 +378,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -396,8 +396,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -414,8 +414,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -432,8 +432,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -450,8 +450,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -468,8 +468,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -486,8 +486,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -504,8 +504,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -522,8 +522,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -540,8 +540,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -558,8 +558,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -576,8 +576,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -594,8 +594,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -612,8 +612,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -630,8 +630,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -648,8 +648,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -666,8 +666,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -684,8 +684,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -702,8 +702,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -720,8 +720,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -738,8 +738,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -756,8 +756,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -774,8 +774,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -792,8 +792,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -810,8 +810,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -828,8 +828,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -846,8 +846,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -864,8 +864,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -882,8 +882,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -900,8 +900,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -918,8 +918,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -936,8 +936,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -954,8 +954,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -972,8 +972,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -990,8 +990,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1008,8 +1008,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1026,8 +1026,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1044,8 +1044,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1062,8 +1062,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1080,8 +1080,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1098,8 +1098,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1116,8 +1116,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1134,8 +1134,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1152,8 +1152,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1170,8 +1170,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1188,8 +1188,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1206,8 +1206,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1224,8 +1224,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1242,8 +1242,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1260,8 +1260,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1278,8 +1278,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1296,8 +1296,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1314,8 +1314,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1332,8 +1332,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1350,8 +1350,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1368,8 +1368,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1386,8 +1386,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1404,8 +1404,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1422,8 +1422,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1440,8 +1440,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1458,8 +1458,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1476,8 +1476,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1494,8 +1494,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1512,8 +1512,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1530,8 +1530,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1548,8 +1548,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1566,8 +1566,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1584,8 +1584,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1602,8 +1602,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1620,8 +1620,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1638,8 +1638,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1656,8 +1656,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1674,8 +1674,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1692,8 +1692,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1710,8 +1710,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1728,8 +1728,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1746,8 +1746,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1764,8 +1764,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1782,8 +1782,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1800,8 +1800,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1818,8 +1818,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1836,8 +1836,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1854,8 +1854,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1872,8 +1872,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1890,8 +1890,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1908,8 +1908,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1944,8 +1944,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1962,8 +1962,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1998,8 +1998,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2016,8 +2016,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2052,8 +2052,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2070,8 +2070,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2106,8 +2106,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2124,8 +2124,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2160,8 +2160,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2178,8 +2178,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2214,8 +2214,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2232,8 +2232,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2268,8 +2268,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2286,8 +2286,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2322,8 +2322,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2340,8 +2340,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2376,8 +2376,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2394,8 +2394,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2430,8 +2430,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2448,8 +2448,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2484,8 +2484,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2502,8 +2502,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2538,8 +2538,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2556,8 +2556,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2592,8 +2592,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2610,8 +2610,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2646,8 +2646,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2664,8 +2664,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2700,8 +2700,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2718,8 +2718,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2754,8 +2754,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2772,8 +2772,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2808,8 +2808,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2826,8 +2826,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2862,8 +2862,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2880,8 +2880,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2916,8 +2916,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2934,8 +2934,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2970,8 +2970,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2988,8 +2988,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3024,8 +3024,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3042,8 +3042,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3078,8 +3078,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3096,8 +3096,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3132,8 +3132,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3150,8 +3150,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3186,8 +3186,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3204,8 +3204,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3240,8 +3240,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3258,8 +3258,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3294,8 +3294,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3312,8 +3312,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3348,8 +3348,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3366,8 +3366,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3402,8 +3402,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3420,8 +3420,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3456,8 +3456,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3474,8 +3474,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3510,8 +3510,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3528,8 +3528,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3564,8 +3564,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3582,8 +3582,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3618,8 +3618,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3636,8 +3636,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3672,8 +3672,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3690,8 +3690,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3726,8 +3726,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3744,8 +3744,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3780,8 +3780,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3798,8 +3798,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3834,8 +3834,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3852,8 +3852,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3888,8 +3888,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3906,8 +3906,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3942,8 +3942,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3960,8 +3960,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3996,8 +3996,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4014,8 +4014,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4050,8 +4050,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4068,8 +4068,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4104,8 +4104,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4122,8 +4122,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4158,8 +4158,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4176,8 +4176,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4212,8 +4212,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4230,8 +4230,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4266,8 +4266,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4284,8 +4284,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4320,8 +4320,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4338,8 +4338,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4374,8 +4374,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4392,8 +4392,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4428,8 +4428,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4446,8 +4446,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4482,8 +4482,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4500,8 +4500,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4536,8 +4536,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4554,8 +4554,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4590,8 +4590,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4608,8 +4608,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4644,8 +4644,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4662,8 +4662,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4698,8 +4698,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4716,8 +4716,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4752,8 +4752,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4770,8 +4770,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4806,8 +4806,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4824,8 +4824,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4860,8 +4860,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4878,8 +4878,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4914,8 +4914,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4932,8 +4932,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4968,8 +4968,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4986,8 +4986,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5022,8 +5022,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5040,8 +5040,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5076,8 +5076,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5094,8 +5094,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5130,8 +5130,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5148,8 +5148,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5184,8 +5184,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5202,8 +5202,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5238,8 +5238,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5256,8 +5256,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5292,8 +5292,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5310,8 +5310,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5346,8 +5346,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5364,8 +5364,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5400,8 +5400,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5418,8 +5418,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5454,8 +5454,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5472,8 +5472,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5508,8 +5508,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5526,8 +5526,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5562,8 +5562,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5580,8 +5580,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5616,8 +5616,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5634,8 +5634,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5670,8 +5670,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5688,8 +5688,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5724,8 +5724,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5742,8 +5742,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5778,8 +5778,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5796,8 +5796,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5832,8 +5832,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5850,8 +5850,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5886,8 +5886,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5904,8 +5904,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5940,8 +5940,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5958,8 +5958,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5994,8 +5994,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6012,8 +6012,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6048,8 +6048,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6066,8 +6066,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6102,8 +6102,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6120,8 +6120,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6156,8 +6156,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6174,8 +6174,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6210,8 +6210,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6228,8 +6228,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6264,8 +6264,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6282,8 +6282,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6318,8 +6318,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6336,8 +6336,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6372,8 +6372,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6390,8 +6390,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6426,8 +6426,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6444,8 +6444,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6480,8 +6480,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6498,8 +6498,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6534,8 +6534,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6552,8 +6552,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6588,8 +6588,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6606,8 +6606,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6642,8 +6642,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6660,8 +6660,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6696,8 +6696,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6714,8 +6714,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6750,8 +6750,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6768,8 +6768,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6804,8 +6804,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6822,8 +6822,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6858,8 +6858,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6876,8 +6876,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6912,8 +6912,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6930,8 +6930,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6966,8 +6966,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6984,8 +6984,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7020,8 +7020,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7038,8 +7038,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7074,8 +7074,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7092,8 +7092,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7128,8 +7128,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7146,8 +7146,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7182,8 +7182,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7200,8 +7200,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7236,8 +7236,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7254,8 +7254,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7290,8 +7290,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7308,8 +7308,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7344,8 +7344,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7362,8 +7362,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7398,8 +7398,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11150,8 +11150,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11168,8 +11168,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11204,8 +11204,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11222,8 +11222,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11258,8 +11258,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11276,8 +11276,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11312,8 +11312,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11330,8 +11330,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11366,8 +11366,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11384,8 +11384,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11420,8 +11420,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11438,8 +11438,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11474,8 +11474,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11492,8 +11492,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11528,8 +11528,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11546,8 +11546,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11582,8 +11582,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11600,8 +11600,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11636,8 +11636,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11654,8 +11654,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11690,8 +11690,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11708,8 +11708,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11744,8 +11744,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11762,8 +11762,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11798,8 +11798,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11816,8 +11816,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11852,8 +11852,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11870,8 +11870,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11906,8 +11906,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11924,8 +11924,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11960,8 +11960,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11978,8 +11978,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12014,8 +12014,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12032,8 +12032,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12068,8 +12068,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12086,8 +12086,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12122,8 +12122,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12140,8 +12140,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12176,8 +12176,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12194,8 +12194,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12230,8 +12230,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12248,8 +12248,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12284,8 +12284,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12302,8 +12302,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12338,8 +12338,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12356,8 +12356,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12392,8 +12392,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12410,8 +12410,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12446,8 +12446,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12464,8 +12464,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12500,8 +12500,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12518,8 +12518,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12554,8 +12554,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12572,8 +12572,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12608,8 +12608,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12626,8 +12626,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12662,8 +12662,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12680,8 +12680,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12716,8 +12716,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12734,8 +12734,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12770,8 +12770,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12788,8 +12788,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12824,8 +12824,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12842,8 +12842,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12878,8 +12878,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12896,8 +12896,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12932,8 +12932,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12950,8 +12950,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12986,8 +12986,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13004,8 +13004,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13040,8 +13040,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13058,8 +13058,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13094,8 +13094,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13112,8 +13112,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13148,8 +13148,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13166,8 +13166,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13202,8 +13202,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13220,8 +13220,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13256,8 +13256,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13274,8 +13274,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13310,8 +13310,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13328,8 +13328,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13364,8 +13364,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13382,8 +13382,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13418,8 +13418,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13436,8 +13436,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13472,8 +13472,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13490,8 +13490,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13526,8 +13526,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13544,8 +13544,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13580,8 +13580,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13598,8 +13598,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13634,8 +13634,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13652,8 +13652,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13688,8 +13688,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13706,8 +13706,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13742,8 +13742,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13760,8 +13760,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13796,8 +13796,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13814,8 +13814,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13850,8 +13850,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13868,8 +13868,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13904,8 +13904,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13922,8 +13922,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13958,8 +13958,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13976,8 +13976,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14012,8 +14012,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14030,8 +14030,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14066,8 +14066,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14084,8 +14084,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14120,8 +14120,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14138,8 +14138,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14174,8 +14174,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14192,8 +14192,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14228,8 +14228,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14246,8 +14246,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14282,8 +14282,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14300,8 +14300,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14336,8 +14336,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14354,8 +14354,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14390,8 +14390,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14408,8 +14408,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14444,8 +14444,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14462,8 +14462,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14498,8 +14498,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14516,8 +14516,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14552,8 +14552,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14570,8 +14570,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14606,8 +14606,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14624,8 +14624,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14660,8 +14660,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14678,8 +14678,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14714,8 +14714,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14732,8 +14732,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14768,8 +14768,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14786,8 +14786,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14822,8 +14822,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14840,8 +14840,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14876,8 +14876,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14894,8 +14894,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14930,8 +14930,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14948,8 +14948,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14984,8 +14984,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15002,8 +15002,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15038,8 +15038,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15056,8 +15056,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15092,8 +15092,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15110,8 +15110,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15146,8 +15146,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15164,8 +15164,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15200,8 +15200,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15218,8 +15218,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15254,8 +15254,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15272,8 +15272,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15308,8 +15308,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15326,8 +15326,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15362,8 +15362,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15380,8 +15380,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15416,8 +15416,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15434,8 +15434,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15470,8 +15470,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15488,8 +15488,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15524,8 +15524,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15542,8 +15542,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15578,8 +15578,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15596,8 +15596,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15632,8 +15632,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15650,8 +15650,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15686,8 +15686,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15704,8 +15704,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15740,8 +15740,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15758,8 +15758,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15794,8 +15794,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15812,8 +15812,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15848,8 +15848,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15866,8 +15866,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15902,8 +15902,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15920,8 +15920,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15956,8 +15956,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15974,8 +15974,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16010,8 +16010,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16028,8 +16028,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16064,8 +16064,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16082,8 +16082,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16118,8 +16118,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16136,8 +16136,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16172,8 +16172,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16190,8 +16190,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16226,8 +16226,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16244,8 +16244,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16280,8 +16280,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16298,8 +16298,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16334,8 +16334,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16352,8 +16352,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16388,8 +16388,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16406,8 +16406,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16442,8 +16442,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16460,8 +16460,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16496,8 +16496,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16514,8 +16514,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16550,8 +16550,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16568,8 +16568,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16604,8 +16604,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16622,8 +16622,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16658,8 +16658,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16676,8 +16676,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16712,8 +16712,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16730,8 +16730,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16766,8 +16766,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16784,8 +16784,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16820,8 +16820,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16838,8 +16838,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16874,8 +16874,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16892,8 +16892,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16928,8 +16928,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16946,8 +16946,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16982,8 +16982,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17000,8 +17000,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17036,8 +17036,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17054,8 +17054,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17090,8 +17090,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17108,8 +17108,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17144,8 +17144,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17162,8 +17162,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17198,8 +17198,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17216,8 +17216,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17252,8 +17252,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17270,8 +17270,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17306,8 +17306,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17324,8 +17324,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17360,8 +17360,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17378,8 +17378,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17414,8 +17414,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17432,8 +17432,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17468,8 +17468,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17486,8 +17486,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17522,8 +17522,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17540,8 +17540,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17576,8 +17576,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17594,8 +17594,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17630,8 +17630,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17648,8 +17648,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17684,8 +17684,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17702,8 +17702,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17738,8 +17738,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17756,8 +17756,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17792,8 +17792,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17810,8 +17810,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17846,8 +17846,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17864,8 +17864,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17900,8 +17900,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17918,8 +17918,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17954,8 +17954,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17972,8 +17972,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18008,8 +18008,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18026,8 +18026,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18062,8 +18062,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18080,8 +18080,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18116,8 +18116,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18134,8 +18134,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18170,8 +18170,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18188,8 +18188,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18224,8 +18224,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18242,8 +18242,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18278,8 +18278,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18296,8 +18296,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18332,8 +18332,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18350,8 +18350,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18386,8 +18386,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18404,8 +18404,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18440,8 +18440,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18458,8 +18458,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18494,8 +18494,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18512,8 +18512,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18548,8 +18548,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18566,8 +18566,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18602,8 +18602,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18620,8 +18620,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18656,8 +18656,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18674,8 +18674,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18710,8 +18710,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18728,8 +18728,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18764,8 +18764,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18782,8 +18782,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18818,8 +18818,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18836,8 +18836,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18872,8 +18872,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18890,8 +18890,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18926,8 +18926,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18944,8 +18944,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18980,8 +18980,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18998,8 +18998,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19034,8 +19034,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19052,8 +19052,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19088,8 +19088,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19106,8 +19106,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19142,8 +19142,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19160,8 +19160,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19196,8 +19196,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19214,8 +19214,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19250,8 +19250,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19268,8 +19268,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19304,8 +19304,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19322,8 +19322,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19358,8 +19358,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19376,8 +19376,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19412,8 +19412,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19430,8 +19430,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19466,8 +19466,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19484,8 +19484,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19520,8 +19520,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19538,8 +19538,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19574,8 +19574,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19592,8 +19592,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19628,8 +19628,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19646,8 +19646,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19682,8 +19682,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19700,8 +19700,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19736,8 +19736,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19754,8 +19754,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19790,8 +19790,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19808,8 +19808,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19844,8 +19844,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19862,8 +19862,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19898,8 +19898,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19916,8 +19916,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19952,8 +19952,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19970,8 +19970,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20006,8 +20006,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20024,8 +20024,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20060,8 +20060,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20078,8 +20078,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20114,8 +20114,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20132,8 +20132,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20168,8 +20168,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20186,8 +20186,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20222,8 +20222,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20240,8 +20240,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20276,8 +20276,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20294,8 +20294,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20330,8 +20330,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20348,8 +20348,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20384,8 +20384,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20402,8 +20402,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20438,8 +20438,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20456,8 +20456,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20492,8 +20492,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20510,8 +20510,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20546,8 +20546,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20564,8 +20564,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20600,8 +20600,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20618,8 +20618,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20654,8 +20654,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20672,8 +20672,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20708,8 +20708,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20726,8 +20726,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20762,8 +20762,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20780,8 +20780,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20816,8 +20816,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20834,8 +20834,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20870,8 +20870,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20888,8 +20888,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20924,8 +20924,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20942,8 +20942,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20978,8 +20978,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20996,8 +20996,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21032,8 +21032,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21050,8 +21050,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21086,8 +21086,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21104,8 +21104,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21140,8 +21140,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21158,8 +21158,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21194,8 +21194,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21212,8 +21212,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21248,8 +21248,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21266,8 +21266,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21302,8 +21302,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21320,8 +21320,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21356,8 +21356,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21374,8 +21374,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21410,8 +21410,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21428,8 +21428,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21464,8 +21464,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21482,8 +21482,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21518,8 +21518,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21536,8 +21536,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21572,8 +21572,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21590,8 +21590,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21626,8 +21626,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21644,8 +21644,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21680,8 +21680,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21698,8 +21698,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21734,8 +21734,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21752,8 +21752,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21788,8 +21788,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21806,8 +21806,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21842,8 +21842,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21860,8 +21860,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21896,8 +21896,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21914,8 +21914,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21950,8 +21950,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21968,8 +21968,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -22004,8 +22004,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -22022,8 +22022,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -22298,8 +22298,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -22316,8 +22316,8 @@ description: Operations executed import_async.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/import_async/unparsed.snap b/rust/kcl-lib/tests/import_async/unparsed.snap index 34dd7d2f6..8c49b5aa3 100644 --- a/rust/kcl-lib/tests/import_async/unparsed.snap +++ b/rust/kcl-lib/tests/import_async/unparsed.snap @@ -69,7 +69,7 @@ fn rightInvolute(i, sg) { // Draw gear teeth start = startSketchOn(XY) - |> startProfileAt([xs[101], ys[101]], %) + |> startProfile(at = [xs[101], ys[101]]) teeth = reduce([0..100], start, leftInvolute) |> arc(angleStart = 0, angleEnd = toothAngle, radius = baseDiameter / 2) |> reduce([1..101], %, rightInvolute) @@ -92,10 +92,10 @@ startAngle = asin(keywayWidth / 2 / holeRadius) // Sketch the keyway and center hole and extrude keyWay = startSketchOn(body, face = END) - |> startProfileAt([ + |> startProfile(at = [ holeRadius * cos(startAngle), holeRadius * sin(startAngle) - ], %) + ]) |> xLine(length = keywayDepth) |> yLine(length = -keywayWidth) |> xLine(length = -keywayDepth) diff --git a/rust/kcl-lib/tests/import_function_not_sketch/my_functions.kcl b/rust/kcl-lib/tests/import_function_not_sketch/my_functions.kcl index 038219dce..5d8f1915e 100644 --- a/rust/kcl-lib/tests/import_function_not_sketch/my_functions.kcl +++ b/rust/kcl-lib/tests/import_function_not_sketch/my_functions.kcl @@ -1,7 +1,7 @@ @settings(defaultLengthUnit = mm) export part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) diff --git a/rust/kcl-lib/tests/import_function_not_sketch/unparsed@my_functions.kcl.snap b/rust/kcl-lib/tests/import_function_not_sketch/unparsed@my_functions.kcl.snap index 97ec203b7..132f03f6b 100644 --- a/rust/kcl-lib/tests/import_function_not_sketch/unparsed@my_functions.kcl.snap +++ b/rust/kcl-lib/tests/import_function_not_sketch/unparsed@my_functions.kcl.snap @@ -5,7 +5,7 @@ description: Result of unparsing tests/import_function_not_sketch/my_functions.k @settings(defaultLengthUnit = mm) export part001 = startSketchOn(XY) - |> startProfileAt([4, 12], %) + |> startProfile(at = [4, 12]) |> line(end = [2, 0]) |> line(end = [0, -6]) |> line(end = [4, -6]) diff --git a/rust/kcl-lib/tests/intersect_cubes/ast.snap b/rust/kcl-lib/tests/intersect_cubes/ast.snap index d60d26aee..0920666c6 100644 --- a/rust/kcl-lib/tests/intersect_cubes/ast.snap +++ b/rust/kcl-lib/tests/intersect_cubes/ast.snap @@ -66,124 +66,127 @@ description: Result of parsing intersect_cubes.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "center", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { "commentStart": 0, + "computed": false, "end": 0, - "name": "size", + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "center", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "size", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -193,7 +196,7 @@ description: Result of parsing intersect_cubes.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -204,8 +207,9 @@ description: Result of parsing intersect_cubes.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/intersect_cubes/input.kcl b/rust/kcl-lib/tests/intersect_cubes/input.kcl index 221421088..ec430fd43 100644 --- a/rust/kcl-lib/tests/intersect_cubes/input.kcl +++ b/rust/kcl-lib/tests/intersect_cubes/input.kcl @@ -1,6 +1,6 @@ fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/intersect_cubes/unparsed.snap b/rust/kcl-lib/tests/intersect_cubes/unparsed.snap index bb50b83f2..cdb0aadae 100644 --- a/rust/kcl-lib/tests/intersect_cubes/unparsed.snap +++ b/rust/kcl-lib/tests/intersect_cubes/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing intersect_cubes.kcl --- fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/kcl_samples/80-20-rail/ast.snap b/rust/kcl-lib/tests/kcl_samples/80-20-rail/ast.snap index af7b9403d..479785b2a 100644 --- a/rust/kcl-lib/tests/kcl_samples/80-20-rail/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/80-20-rail/ast.snap @@ -85,77 +85,18 @@ description: Result of parsing 80-20-rail.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "originStart", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "raw": "0.1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.1, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "railHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "+", - "right": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "computed": false, "end": 0, @@ -170,12 +111,12 @@ description: Result of parsing 80-20-rail.kcl "property": { "commentStart": 0, "end": 0, - "raw": "1", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 1.0, + "value": 0.0, "suffix": "None" } }, @@ -183,22 +124,84 @@ description: Result of parsing 80-20-rail.kcl "type": "MemberExpression", "type": "MemberExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "raw": "0.1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.1, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "railHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "originStart", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -208,7 +211,7 @@ description: Result of parsing 80-20-rail.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -219,8 +222,9 @@ description: Result of parsing 80-20-rail.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md index c8ac79043..2e5c42fb7 100644 --- a/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md @@ -64,47 +64,47 @@ flowchart LR 115[Solid2d] end subgraph path120 [Path] - 120["Path
[3470, 3529, 6]"] - 121["Segment
[3535, 3603, 6]"] - 122["Segment
[3609, 3709, 6]"] - 123["Segment
[3715, 3832, 6]"] - 124["Segment
[3838, 3923, 6]"] - 125["Segment
[3929, 3936, 6]"] + 120["Path
[3470, 3532, 6]"] + 121["Segment
[3538, 3606, 6]"] + 122["Segment
[3612, 3712, 6]"] + 123["Segment
[3718, 3835, 6]"] + 124["Segment
[3841, 3926, 6]"] + 125["Segment
[3932, 3939, 6]"] 126[Solid2d] end subgraph path127 [Path] - 127["Path
[3947, 3998, 6]"] - 128["Segment
[3947, 3998, 6]"] + 127["Path
[3950, 4001, 6]"] + 128["Segment
[3950, 4001, 6]"] 129[Solid2d] end subgraph path130 [Path] - 130["Path
[4013, 4160, 6]"] - 131["Segment
[4013, 4160, 6]"] + 130["Path
[4016, 4163, 6]"] + 131["Segment
[4016, 4163, 6]"] 132[Solid2d] end subgraph path133 [Path] - 133["Path
[4175, 4323, 6]"] - 134["Segment
[4175, 4323, 6]"] + 133["Path
[4178, 4326, 6]"] + 134["Segment
[4178, 4326, 6]"] 135[Solid2d] end subgraph path136 [Path] - 136["Path
[4338, 4486, 6]"] - 137["Segment
[4338, 4486, 6]"] + 136["Path
[4341, 4489, 6]"] + 137["Segment
[4341, 4489, 6]"] 138[Solid2d] end subgraph path139 [Path] - 139["Path
[4501, 4650, 6]"] - 140["Segment
[4501, 4650, 6]"] + 139["Path
[4504, 4653, 6]"] + 140["Segment
[4504, 4653, 6]"] 141[Solid2d] end subgraph path157 [Path] - 157["Path
[4795, 4833, 6]"] - 158["Segment
[4795, 4833, 6]"] + 157["Path
[4798, 4836, 6]"] + 158["Segment
[4798, 4836, 6]"] 159[Solid2d] end subgraph path165 [Path] - 165["Path
[4906, 4942, 6]"] - 166["Segment
[4906, 4942, 6]"] + 165["Path
[4909, 4945, 6]"] + 166["Segment
[4909, 4945, 6]"] 167[Solid2d] end subgraph path181 [Path] @@ -231,7 +231,7 @@ flowchart LR 117[Wall] 118["SweepEdge Opposite"] 119["SweepEdge Adjacent"] - 142["Sweep Extrusion
[4660, 4679, 6]"] + 142["Sweep Extrusion
[4663, 4682, 6]"] 143[Wall] 144[Wall] 145[Wall] @@ -246,23 +246,23 @@ flowchart LR 154["SweepEdge Adjacent"] 155["SweepEdge Opposite"] 156["SweepEdge Adjacent"] - 160["Sweep Extrusion
[4839, 4859, 6]"] + 160["Sweep Extrusion
[4842, 4862, 6]"] 161[Wall] 162["Cap End"] 163["SweepEdge Opposite"] 164["SweepEdge Adjacent"] - 168["Sweep Extrusion
[4948, 4969, 6]"] + 168["Sweep Extrusion
[4951, 4972, 6]"] 169[Wall] 170["SweepEdge Opposite"] 171["SweepEdge Adjacent"] - 172["EdgeCut Fillet
[5010, 5521, 6]"] - 173["EdgeCut Fillet
[5010, 5521, 6]"] - 174["EdgeCut Fillet
[5010, 5521, 6]"] - 175["EdgeCut Fillet
[5010, 5521, 6]"] - 176["EdgeCut Fillet
[5010, 5521, 6]"] - 177["EdgeCut Fillet
[5010, 5521, 6]"] - 178["EdgeCut Fillet
[5010, 5521, 6]"] - 179["EdgeCut Fillet
[5010, 5521, 6]"] + 172["EdgeCut Fillet
[5013, 5524, 6]"] + 173["EdgeCut Fillet
[5013, 5524, 6]"] + 174["EdgeCut Fillet
[5013, 5524, 6]"] + 175["EdgeCut Fillet
[5013, 5524, 6]"] + 176["EdgeCut Fillet
[5013, 5524, 6]"] + 177["EdgeCut Fillet
[5013, 5524, 6]"] + 178["EdgeCut Fillet
[5013, 5524, 6]"] + 179["EdgeCut Fillet
[5013, 5524, 6]"] 180["Plane
[204, 231, 7]"] 184["Sweep Extrusion
[333, 353, 7]"] 185[Wall] @@ -326,8 +326,8 @@ flowchart LR 278["StartSketchOnFace
[2498, 2541, 6]"] 279["StartSketchOnFace
[3197, 3234, 6]"] 280["StartSketchOnFace
[3421, 3458, 6]"] - 281["StartSketchOnFace
[4746, 4789, 6]"] - 282["StartSketchOnFace
[4861, 4900, 6]"] + 281["StartSketchOnFace
[4749, 4792, 6]"] + 282["StartSketchOnFace
[4864, 4903, 6]"] 283["StartSketchOnPlane
[244, 271, 7]"] 284["StartSketchOnPlane
[453, 496, 7]"] 285["StartSketchOnPlane
[1039, 1092, 8]"] diff --git a/rust/kcl-lib/tests/kcl_samples/axial-fan/ops.snap b/rust/kcl-lib/tests/kcl_samples/axial-fan/ops.snap index 4768bceba..3e75ba245 100644 --- a/rust/kcl-lib/tests/kcl_samples/axial-fan/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/axial-fan/ops.snap @@ -1138,8 +1138,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1174,8 +1174,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1210,8 +1210,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1246,8 +1246,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1282,8 +1282,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1318,8 +1318,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1354,8 +1354,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1390,8 +1390,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1426,8 +1426,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1462,8 +1462,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1498,8 +1498,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1534,8 +1534,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1633,8 +1633,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1669,8 +1669,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1705,8 +1705,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1741,8 +1741,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1777,8 +1777,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1813,8 +1813,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1849,8 +1849,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1885,8 +1885,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1921,8 +1921,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1957,8 +1957,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1993,8 +1993,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2029,8 +2029,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2128,8 +2128,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2164,8 +2164,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2200,8 +2200,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2236,8 +2236,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2272,8 +2272,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2308,8 +2308,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2344,8 +2344,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2380,8 +2380,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2416,8 +2416,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2452,8 +2452,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2488,8 +2488,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2524,8 +2524,8 @@ description: Operations executed axial-fan.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/ball-bearing/ast.snap b/rust/kcl-lib/tests/kcl_samples/ball-bearing/ast.snap index 949c6e0dc..0d0681c92 100644 --- a/rust/kcl-lib/tests/kcl_samples/ball-bearing/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/ball-bearing/ast.snap @@ -1008,22 +1008,65 @@ description: Result of parsing ball-bearing.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "shaftDia", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "shaftDia", + "name": "wallThickness", "start": 0, "type": "Identifier" }, @@ -1032,68 +1075,28 @@ description: Result of parsing ball-bearing.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "wallThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0.001", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0.001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.001, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.001, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1103,7 +1106,7 @@ description: Result of parsing ball-bearing.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1114,8 +1117,9 @@ description: Result of parsing ball-bearing.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1667,12 +1671,18 @@ description: Result of parsing ball-bearing.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { @@ -1682,13 +1692,74 @@ description: Result of parsing ball-bearing.kcl "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "shaftDia", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "shaftDia", + "name": "wallThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sphereDia", "start": 0, "type": "Identifier" }, @@ -1714,28 +1785,11 @@ description: Result of parsing ball-bearing.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "wallThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", + "operator": "-", "right": { "commentStart": 0, "end": 0, @@ -1746,7 +1800,7 @@ description: Result of parsing ball-bearing.kcl "name": { "commentStart": 0, "end": 0, - "name": "sphereDia", + "name": "chainWidth", "start": 0, "type": "Identifier" }, @@ -1776,139 +1830,92 @@ description: Result of parsing ball-bearing.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "-", - "right": { + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "chainWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", + "raw": "0.125", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.125, "suffix": "None" } }, + "operator": "*", + "right": { + "arguments": [ + { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "raw": "60", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 60.0, + "suffix": "None" + } + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "toRadians", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sin", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "raw": "0.125", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.125, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "arguments": [ - { - "arguments": [ - { - "commentStart": 0, - "end": 0, - "raw": "60", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 60.0, - "suffix": "None" - } - } - ], - "callee": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "toRadians", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - } - ], - "callee": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sin", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1918,7 +1925,7 @@ description: Result of parsing ball-bearing.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1929,8 +1936,9 @@ description: Result of parsing ball-bearing.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/ball-bearing/ops.snap b/rust/kcl-lib/tests/kcl_samples/ball-bearing/ops.snap index 21514f9c2..9a4755a5c 100644 --- a/rust/kcl-lib/tests/kcl_samples/ball-bearing/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/ball-bearing/ops.snap @@ -382,8 +382,8 @@ description: Operations executed ball-bearing.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/bottle/ast.snap b/rust/kcl-lib/tests/kcl_samples/bottle/ast.snap index 0ec056728..95b7a58d8 100644 --- a/rust/kcl-lib/tests/kcl_samples/bottle/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/bottle/ast.snap @@ -263,76 +263,79 @@ description: Result of parsing bottle.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "bottleLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "bottleLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -342,7 +345,7 @@ description: Result of parsing bottle.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -353,8 +356,9 @@ description: Result of parsing bottle.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap b/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap index 310029bcb..b46de9e8d 100644 --- a/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap @@ -1275,44 +1275,47 @@ description: Result of parsing bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1322,7 +1325,7 @@ description: Result of parsing bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1333,8 +1336,9 @@ description: Result of parsing bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/color-cube/ast.snap b/rust/kcl-lib/tests/kcl_samples/color-cube/ast.snap index 2a971e13b..fe4e47391 100644 --- a/rust/kcl-lib/tests/kcl_samples/color-cube/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/color-cube/ast.snap @@ -825,10 +825,42 @@ description: Result of parsing color-cube.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "halfSize", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { "abs_path": false, "commentStart": 0, "end": 0, @@ -843,42 +875,13 @@ description: Result of parsing color-cube.kcl "start": 0, "type": "Name", "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "halfSize", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -888,7 +891,7 @@ description: Result of parsing color-cube.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -899,8 +902,9 @@ description: Result of parsing color-cube.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ast.snap b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ast.snap index f093fd39d..5c8e782e9 100644 --- a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ast.snap @@ -227,15 +227,130 @@ description: Result of parsing cycloidal-gear.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "gearPitch", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "1.55", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.55, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "*", + "right": { + "arguments": [ + { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "helixAngleP", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "toRadians", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "cos", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { "commentStart": 0, "end": 0, "left": { @@ -256,117 +371,133 @@ description: Result of parsing cycloidal-gear.kcl }, "operator": "*", "right": { - "commentStart": 0, - "end": 0, - "raw": "1.55", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.55, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "*", - "right": { - "arguments": [ - { - "arguments": [ - { + "arguments": [ + { + "arguments": [ + { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "helixAngleP", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "callee": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "helixAngleP", + "name": "toRadians", "start": 0, "type": "Identifier" }, "path": [], "start": 0, - "type": "Name", "type": "Name" - } - ], - "callee": { - "abs_path": false, + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "toRadians", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" - }, + "type": "CallExpression", + "type": "CallExpression" + } + ], + "callee": { + "abs_path": false, "commentStart": 0, "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sin", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "CallExpression", - "type": "CallExpression" - } - ], - "callee": { - "abs_path": false, + "type": "Name" + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "cos", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" + "type": "CallExpression", + "type": "CallExpression" }, - "commentStart": 0, - "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "gearPitch", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "gearPitch", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "1.55", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.55, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { - "arguments": [ - { - "argument": { + "operator": "*", + "right": { + "arguments": [ + { + "arguments": [ + { "abs_path": false, "commentStart": 0, "end": 0, @@ -381,73 +512,57 @@ description: Result of parsing cycloidal-gear.kcl "start": 0, "type": "Name", "type": "Name" - }, + } + ], + "callee": { + "abs_path": false, "commentStart": 0, "end": 0, - "operator": "-", + "name": { + "commentStart": 0, + "end": 0, + "name": "toRadians", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "callee": { - "abs_path": false, + "type": "Name" + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "toRadians", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" - }, + "type": "CallExpression", + "type": "CallExpression" + } + ], + "callee": { + "abs_path": false, "commentStart": 0, "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sin", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "CallExpression", - "type": "CallExpression" - } - ], - "callee": { - "abs_path": false, + "type": "Name" + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sin", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" + "type": "CallExpression", + "type": "CallExpression" }, - "commentStart": 0, - "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { + "operator": "+", + "right": { "commentStart": 0, "end": 0, "left": { @@ -468,203 +583,91 @@ description: Result of parsing cycloidal-gear.kcl }, "operator": "*", "right": { - "commentStart": 0, - "end": 0, - "raw": "1.55", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.55, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "operator": "*", - "right": { - "arguments": [ - { - "arguments": [ - { + "arguments": [ + { + "arguments": [ + { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "helixAngleP", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "callee": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "helixAngleP", + "name": "toRadians", "start": 0, "type": "Identifier" }, "path": [], "start": 0, - "type": "Name", "type": "Name" - } - ], - "callee": { - "abs_path": false, + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "toRadians", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" - }, + "type": "CallExpression", + "type": "CallExpression" + } + ], + "callee": { + "abs_path": false, "commentStart": 0, "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "cos", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "CallExpression", - "type": "CallExpression" - } - ], - "callee": { - "abs_path": false, + "type": "Name" + }, "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sin", - "start": 0, - "type": "Identifier" - }, - "path": [], "start": 0, - "type": "Name" + "type": "CallExpression", + "type": "CallExpression" }, - "commentStart": 0, - "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "gearPitch", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { - "arguments": [ - { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "helixAngleP", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "callee": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "toRadians", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - } - ], - "callee": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "cos", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -674,7 +677,7 @@ description: Result of parsing cycloidal-gear.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -685,8 +688,9 @@ description: Result of parsing cycloidal-gear.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ops.snap b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ops.snap index f9232cd99..ca12f1b27 100644 --- a/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/cycloidal-gear/ops.snap @@ -84,8 +84,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -120,8 +120,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -156,8 +156,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -192,8 +192,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -317,8 +317,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -353,8 +353,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -389,8 +389,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -425,8 +425,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -550,8 +550,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -586,8 +586,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -622,8 +622,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -658,8 +658,8 @@ description: Operations executed cycloidal-gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/dodecahedron/ast.snap b/rust/kcl-lib/tests/kcl_samples/dodecahedron/ast.snap index 40d9e1c95..fe7db03ee 100644 --- a/rust/kcl-lib/tests/kcl_samples/dodecahedron/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/dodecahedron/ast.snap @@ -113,108 +113,111 @@ description: Result of parsing dodecahedron.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "1000", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1000.0, - "suffix": "None" - } - }, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, + "left": { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "1000", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1000.0, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "dither", + "name": { + "commentStart": 0, + "end": 0, + "name": "dither", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "1000", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1000.0, - "suffix": "None" - } - }, + { "commentStart": 0, "end": 0, + "left": { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "1000", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1000.0, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "dither", + "name": { + "commentStart": 0, + "end": 0, + "name": "dither", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -224,7 +227,7 @@ description: Result of parsing dodecahedron.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -235,8 +238,9 @@ description: Result of parsing dodecahedron.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 6cc347a8e..726bd677a 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
[672, 706, 0]"] - 3["Segment
[712, 744, 0]"] - 4["Segment
[750, 782, 0]"] - 5["Segment
[788, 821, 0]"] - 6["Segment
[827, 883, 0]"] - 7["Segment
[889, 896, 0]"] + 2["Path
[672, 709, 0]"] + 3["Segment
[715, 747, 0]"] + 4["Segment
[753, 785, 0]"] + 5["Segment
[791, 824, 0]"] + 6["Segment
[830, 886, 0]"] + 7["Segment
[892, 899, 0]"] 8[Solid2d] end subgraph path32 [Path] - 32["Path
[1289, 1342, 0]"] - 33["Segment
[1348, 1380, 0]"] - 34["Segment
[1386, 1418, 0]"] - 35["Segment
[1424, 1457, 0]"] - 36["Segment
[1463, 1519, 0]"] - 37["Segment
[1525, 1532, 0]"] + 32["Path
[1292, 1348, 0]"] + 33["Segment
[1354, 1386, 0]"] + 34["Segment
[1392, 1424, 0]"] + 35["Segment
[1430, 1463, 0]"] + 36["Segment
[1469, 1525, 0]"] + 37["Segment
[1531, 1538, 0]"] 38[Solid2d] end subgraph path59 [Path] - 59["Path
[1797, 1850, 0]"] - 60["Segment
[1856, 1888, 0]"] - 61["Segment
[1894, 1926, 0]"] - 62["Segment
[1932, 1965, 0]"] - 63["Segment
[1971, 2027, 0]"] - 64["Segment
[2033, 2040, 0]"] + 59["Path
[1803, 1859, 0]"] + 60["Segment
[1865, 1897, 0]"] + 61["Segment
[1903, 1935, 0]"] + 62["Segment
[1941, 1974, 0]"] + 63["Segment
[1980, 2036, 0]"] + 64["Segment
[2042, 2049, 0]"] 65[Solid2d] end subgraph path83 [Path] - 83["Path
[2436, 2491, 0]"] - 84["Segment
[2497, 2529, 0]"] - 85["Segment
[2535, 2567, 0]"] - 86["Segment
[2573, 2606, 0]"] - 87["Segment
[2612, 2668, 0]"] - 88["Segment
[2674, 2681, 0]"] + 83["Path
[2445, 2503, 0]"] + 84["Segment
[2509, 2541, 0]"] + 85["Segment
[2547, 2579, 0]"] + 86["Segment
[2585, 2618, 0]"] + 87["Segment
[2624, 2680, 0]"] + 88["Segment
[2686, 2693, 0]"] 89[Solid2d] end subgraph path111 [Path] - 111["Path
[2983, 3021, 0]"] - 112["Segment
[3027, 3059, 0]"] - 113["Segment
[3065, 3091, 0]"] - 114["Segment
[3097, 3130, 0]"] - 115["Segment
[3136, 3192, 0]"] - 116["Segment
[3198, 3205, 0]"] + 111["Path
[2995, 3036, 0]"] + 112["Segment
[3042, 3074, 0]"] + 113["Segment
[3080, 3106, 0]"] + 114["Segment
[3112, 3145, 0]"] + 115["Segment
[3151, 3207, 0]"] + 116["Segment
[3213, 3220, 0]"] 117[Solid2d] end subgraph path134 [Path] - 134["Path
[3388, 3441, 0]"] - 135["Segment
[3447, 3479, 0]"] - 136["Segment
[3485, 3517, 0]"] - 137["Segment
[3523, 3556, 0]"] - 138["Segment
[3562, 3618, 0]"] - 139["Segment
[3624, 3631, 0]"] + 134["Path
[3403, 3459, 0]"] + 135["Segment
[3465, 3497, 0]"] + 136["Segment
[3503, 3535, 0]"] + 137["Segment
[3541, 3574, 0]"] + 138["Segment
[3580, 3636, 0]"] + 139["Segment
[3642, 3649, 0]"] 140[Solid2d] end subgraph path158 [Path] - 158["Path
[3859, 3896, 0]"] - 159["Segment
[3902, 3928, 0]"] - 160["Segment
[3934, 3960, 0]"] - 161["Segment
[3966, 3993, 0]"] - 162["Segment
[3999, 4055, 0]"] - 163["Segment
[4061, 4068, 0]"] + 158["Path
[3877, 3917, 0]"] + 159["Segment
[3923, 3949, 0]"] + 160["Segment
[3955, 3981, 0]"] + 161["Segment
[3987, 4014, 0]"] + 162["Segment
[4020, 4076, 0]"] + 163["Segment
[4082, 4089, 0]"] 164[Solid2d] end subgraph path180 [Path] - 180["Path
[4355, 4423, 0]"] - 181["Segment
[4429, 4455, 0]"] - 182["Segment
[4461, 4487, 0]"] - 183["Segment
[4493, 4520, 0]"] - 184["Segment
[4526, 4582, 0]"] - 185["Segment
[4588, 4595, 0]"] + 180["Path
[4376, 4447, 0]"] + 181["Segment
[4453, 4479, 0]"] + 182["Segment
[4485, 4511, 0]"] + 183["Segment
[4517, 4544, 0]"] + 184["Segment
[4550, 4606, 0]"] + 185["Segment
[4612, 4619, 0]"] 186[Solid2d] end subgraph path202 [Path] - 202["Path
[4789, 4910, 0]"] - 203["Segment
[4916, 4965, 0]"] - 204["Segment
[4971, 5019, 0]"] - 205["Segment
[5025, 5073, 0]"] - 206["Segment
[5079, 5135, 0]"] - 207["Segment
[5141, 5148, 0]"] + 202["Path
[4813, 4965, 0]"] + 203["Segment
[4971, 5020, 0]"] + 204["Segment
[5026, 5074, 0]"] + 205["Segment
[5080, 5128, 0]"] + 206["Segment
[5134, 5190, 0]"] + 207["Segment
[5196, 5203, 0]"] 208[Solid2d] end subgraph path225 [Path] - 225["Path
[5680, 5721, 0]"] - 226["Segment
[5727, 5759, 0]"] - 227["Segment
[5765, 5790, 0]"] - 228["Segment
[5796, 5829, 0]"] - 229["Segment
[5835, 5891, 0]"] - 230["Segment
[5897, 5904, 0]"] + 225["Path
[5735, 5779, 0]"] + 226["Segment
[5785, 5817, 0]"] + 227["Segment
[5823, 5848, 0]"] + 228["Segment
[5854, 5887, 0]"] + 229["Segment
[5893, 5949, 0]"] + 230["Segment
[5955, 5962, 0]"] 231[Solid2d] end subgraph path252 [Path] - 252["Path
[6191, 6232, 0]"] - 253["Segment
[6238, 6264, 0]"] - 254["Segment
[6270, 6302, 0]"] - 255["Segment
[6308, 6335, 0]"] - 256["Segment
[6341, 6397, 0]"] - 257["Segment
[6403, 6410, 0]"] + 252["Path
[6249, 6293, 0]"] + 253["Segment
[6299, 6325, 0]"] + 254["Segment
[6331, 6363, 0]"] + 255["Segment
[6369, 6396, 0]"] + 256["Segment
[6402, 6458, 0]"] + 257["Segment
[6464, 6471, 0]"] 258[Solid2d] end subgraph path276 [Path] - 276["Path
[6887, 6937, 0]"] - 277["Segment
[6943, 6980, 0]"] - 278["Segment
[6986, 7079, 0]"] - 279["Segment
[7085, 7121, 0]"] - 280["Segment
[7127, 7228, 0]"] - 281["Segment
[7234, 7270, 0]"] + 276["Path
[6948, 7001, 0]"] + 277["Segment
[7007, 7044, 0]"] + 278["Segment
[7050, 7143, 0]"] + 279["Segment
[7149, 7185, 0]"] + 280["Segment
[7191, 7292, 0]"] + 281["Segment
[7298, 7334, 0]"] end subgraph path283 [Path] - 283["Path
[7333, 7444, 0]"] - 284["Segment
[7333, 7444, 0]"] + 283["Path
[7397, 7508, 0]"] + 284["Segment
[7397, 7508, 0]"] 285[Solid2d] end 1["Plane
[565, 582, 0]"] - 9["Sweep Extrusion
[1057, 1084, 0]"] + 9["Sweep Extrusion
[1060, 1087, 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
[1057, 1084, 0]"] - 25["Sweep Extrusion
[1057, 1084, 0]"] - 26["Sweep Extrusion
[1057, 1084, 0]"] - 27["Sweep Extrusion
[1057, 1084, 0]"] - 28["Sweep Extrusion
[1057, 1084, 0]"] - 29["Sweep Extrusion
[1057, 1084, 0]"] - 30["Sweep Extrusion
[1057, 1084, 0]"] - 31["Plane
[1216, 1270, 0]"] - 39["Sweep Extrusion
[1695, 1729, 0]"] + 24["Sweep Extrusion
[1060, 1087, 0]"] + 25["Sweep Extrusion
[1060, 1087, 0]"] + 26["Sweep Extrusion
[1060, 1087, 0]"] + 27["Sweep Extrusion
[1060, 1087, 0]"] + 28["Sweep Extrusion
[1060, 1087, 0]"] + 29["Sweep Extrusion
[1060, 1087, 0]"] + 30["Sweep Extrusion
[1060, 1087, 0]"] + 31["Plane
[1219, 1273, 0]"] + 39["Sweep Extrusion
[1701, 1735, 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
[1695, 1729, 0]"] - 55["Sweep Extrusion
[1695, 1729, 0]"] - 56["Sweep Extrusion
[1695, 1729, 0]"] - 57["Sweep Extrusion
[1695, 1729, 0]"] - 58["Sweep Extrusion
[1695, 1729, 0]"] - 66["Sweep Extrusion
[2139, 2173, 0]"] + 54["Sweep Extrusion
[1701, 1735, 0]"] + 55["Sweep Extrusion
[1701, 1735, 0]"] + 56["Sweep Extrusion
[1701, 1735, 0]"] + 57["Sweep Extrusion
[1701, 1735, 0]"] + 58["Sweep Extrusion
[1701, 1735, 0]"] + 66["Sweep Extrusion
[2148, 2182, 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
[2139, 2173, 0]"] - 82["Plane
[2290, 2341, 0]"] - 90["Sweep Extrusion
[2844, 2879, 0]"] + 81["Sweep Extrusion
[2148, 2182, 0]"] + 82["Plane
[2299, 2350, 0]"] + 90["Sweep Extrusion
[2856, 2891, 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
[2844, 2879, 0]"] - 106["Sweep Extrusion
[2844, 2879, 0]"] - 107["Sweep Extrusion
[2844, 2879, 0]"] - 108["Sweep Extrusion
[2844, 2879, 0]"] - 109["Sweep Extrusion
[2844, 2879, 0]"] - 110["Plane
[2926, 2963, 0]"] - 118["Sweep Extrusion
[3285, 3320, 0]"] + 105["Sweep Extrusion
[2856, 2891, 0]"] + 106["Sweep Extrusion
[2856, 2891, 0]"] + 107["Sweep Extrusion
[2856, 2891, 0]"] + 108["Sweep Extrusion
[2856, 2891, 0]"] + 109["Sweep Extrusion
[2856, 2891, 0]"] + 110["Plane
[2938, 2975, 0]"] + 118["Sweep Extrusion
[3300, 3335, 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
[3285, 3320, 0]"] - 141["Sweep Extrusion
[3730, 3765, 0]"] + 133["Sweep Extrusion
[3300, 3335, 0]"] + 141["Sweep Extrusion
[3748, 3783, 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
[3730, 3765, 0]"] - 157["Plane
[3805, 3842, 0]"] - 165["Sweep Extrusion
[4074, 4107, 0]"] + 156["Sweep Extrusion
[3748, 3783, 0]"] + 157["Plane
[3823, 3860, 0]"] + 165["Sweep Extrusion
[4095, 4128, 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
[4685, 4712, 0]"] + 187["Sweep Extrusion
[4709, 4736, 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
[4685, 4712, 0]"] - 209["Sweep Extrusion
[5237, 5265, 0]"] + 201["Sweep Extrusion
[4709, 4736, 0]"] + 209["Sweep Extrusion
[5292, 5320, 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
[5237, 5265, 0]"] - 224["Plane
[5618, 5667, 0]"] - 232["Sweep Extrusion
[6003, 6031, 0]"] + 223["Sweep Extrusion
[5292, 5320, 0]"] + 224["Plane
[5673, 5722, 0]"] + 232["Sweep Extrusion
[6061, 6089, 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
[6003, 6031, 0]"] - 248["Sweep Extrusion
[6003, 6031, 0]"] - 249["Sweep Extrusion
[6003, 6031, 0]"] - 250["Sweep Extrusion
[6003, 6031, 0]"] - 251["Sweep Extrusion
[6003, 6031, 0]"] - 259["Sweep Extrusion
[6492, 6520, 0]"] + 247["Sweep Extrusion
[6061, 6089, 0]"] + 248["Sweep Extrusion
[6061, 6089, 0]"] + 249["Sweep Extrusion
[6061, 6089, 0]"] + 250["Sweep Extrusion
[6061, 6089, 0]"] + 251["Sweep Extrusion
[6061, 6089, 0]"] + 259["Sweep Extrusion
[6553, 6581, 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
[6492, 6520, 0]"] - 275["Plane
[6813, 6864, 0]"] - 282["Plane
[7292, 7309, 0]"] - 286["Sweep Sweep
[7458, 7511, 0]"] + 274["Sweep Extrusion
[6553, 6581, 0]"] + 275["Plane
[6874, 6925, 0]"] + 282["Plane
[7356, 7373, 0]"] + 286["Sweep Sweep
[7522, 7575, 0]"] 287[Wall] 288["Cap Start"] 289["Cap Start"] 290["SweepEdge Opposite"] 291["SweepEdge Adjacent"] - 292["StartSketchOnPlane
[1202, 1271, 0]"] - 293["StartSketchOnPlane
[2276, 2342, 0]"] - 294["StartSketchOnPlane
[2912, 2964, 0]"] - 295["StartSketchOnPlane
[3791, 3843, 0]"] - 296["StartSketchOnFace
[4295, 4336, 0]"] - 297["StartSketchOnFace
[4732, 4771, 0]"] - 298["StartSketchOnPlane
[5604, 5668, 0]"] - 299["StartSketchOnPlane
[6799, 6865, 0]"] + 292["StartSketchOnPlane
[1205, 1274, 0]"] + 293["StartSketchOnPlane
[2285, 2351, 0]"] + 294["StartSketchOnPlane
[2924, 2976, 0]"] + 295["StartSketchOnPlane
[3809, 3861, 0]"] + 296["StartSketchOnFace
[4316, 4357, 0]"] + 297["StartSketchOnFace
[4756, 4795, 0]"] + 298["StartSketchOnPlane
[5659, 5723, 0]"] + 299["StartSketchOnPlane
[6860, 6926, 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 bca7dc670..e40c10fe0 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 @@ -729,53 +729,47 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "floorPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -785,7 +779,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -796,8 +790,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "floorPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -1632,57 +1642,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "profileThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "lowerBeltPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "profileThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1692,7 +1696,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1703,8 +1707,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "lowerBeltPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -2377,57 +2397,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "profileThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "lowerBeltPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "profileThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2437,7 +2451,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2448,8 +2462,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "lowerBeltPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -3240,57 +3270,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "blockSubdivisionWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "pillarPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "blockSubdivisionWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3300,7 +3324,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3311,8 +3335,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "pillarPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -4053,53 +4093,47 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "upperBeltPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4109,7 +4143,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4120,8 +4154,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "upperBeltPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -4682,57 +4732,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "profileThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "upperBeltPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "profileThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4742,7 +4786,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4753,8 +4797,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "upperBeltPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -5407,53 +5467,47 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "tableTopPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5463,7 +5517,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5474,8 +5528,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "tableTopPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -6249,17 +6319,49 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sinkOffsetLeft", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "sinkOffsetLeft", + "name": "sinkOffsetFront", "start": 0, "type": "Identifier" }, @@ -6267,51 +6369,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "start": 0, "type": "Name", "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sinkOffsetFront", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, + } + ], "end": 0, - "name": "sinkPlaneOutside", "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -6321,7 +6385,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -6332,8 +6396,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sinkPlaneOutside", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -6932,109 +7012,103 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sinkOffsetLeft", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "metalThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "sinkOffsetFront", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "metalThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sinkPlaneInside", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sinkOffsetLeft", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "metalThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sinkOffsetFront", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "metalThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -7044,7 +7118,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -7055,8 +7129,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sinkPlaneInside", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -8251,57 +8341,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "doorStart", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "doorPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "doorStart", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -8311,7 +8395,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -8322,8 +8406,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "doorPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -9060,57 +9160,51 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "doorStart", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "doorPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "doorStart", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -9120,7 +9214,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -9131,8 +9225,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "doorPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -10152,12 +10262,54 @@ description: Result of parsing dual-basin-utility-sink.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "handleOffset", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { "commentStart": 0, "end": 0, "raw": "0", @@ -10168,61 +10320,13 @@ description: Result of parsing dual-basin-utility-sink.kcl "value": 0.0, "suffix": "None" } - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "handleOffset", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, + ], "end": 0, - "name": "handlePlane", "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -10232,7 +10336,7 @@ description: Result of parsing dual-basin-utility-sink.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -10243,8 +10347,24 @@ description: Result of parsing dual-basin-utility-sink.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "handlePlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/enclosure/ast.snap b/rust/kcl-lib/tests/kcl_samples/enclosure/ast.snap index a894c43e6..05f66210b 100644 --- a/rust/kcl-lib/tests/kcl_samples/enclosure/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/enclosure/ast.snap @@ -230,44 +230,47 @@ description: Result of parsing enclosure.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -277,7 +280,7 @@ description: Result of parsing enclosure.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -288,8 +291,9 @@ description: Result of parsing enclosure.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2949,68 +2953,71 @@ description: Result of parsing enclosure.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "width", + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "1.2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.2, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "*", - "right": { + { "commentStart": 0, "end": 0, - "raw": "1.2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 1.2, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3020,7 +3027,7 @@ description: Result of parsing enclosure.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3031,8 +3038,9 @@ description: Result of parsing enclosure.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5138,22 +5146,65 @@ description: Result of parsing enclosure.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "1.2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.2, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "width", + "name": "wallThickness", "start": 0, "type": "Identifier" }, @@ -5162,25 +5213,11 @@ description: Result of parsing enclosure.kcl "type": "Name", "type": "Name" }, - "operator": "*", - "right": { - "commentStart": 0, - "end": 0, - "raw": "1.2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.2, - "suffix": "None" - } - }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { + { "abs_path": false, "commentStart": 0, "end": 0, @@ -5195,39 +5232,13 @@ description: Result of parsing enclosure.kcl "start": 0, "type": "Name", "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "wallThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5237,7 +5248,7 @@ description: Result of parsing enclosure.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5248,8 +5259,9 @@ description: Result of parsing enclosure.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ast.snap b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ast.snap index da9ff35e2..3e4a6f2c0 100644 --- a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ast.snap @@ -663,48 +663,51 @@ description: Result of parsing exhaust-manifold.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": "plateHeight", + "raw": "0", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "plateHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -714,7 +717,7 @@ description: Result of parsing exhaust-manifold.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -725,8 +728,9 @@ description: Result of parsing exhaust-manifold.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2177,72 +2181,75 @@ description: Result of parsing exhaust-manifold.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "raw": "3", + "left": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + "operator": "+", + "right": { + "commentStart": 0, + "end": 0, + "raw": "1.3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.3, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "+", - "right": { + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "1.25", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.25, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "1.3", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.3, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "1.25", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.25, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2252,7 +2259,7 @@ description: Result of parsing exhaust-manifold.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2263,8 +2270,9 @@ description: Result of parsing exhaust-manifold.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ops.snap b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ops.snap index b30b4f7fa..25f9ce025 100644 --- a/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/exhaust-manifold/ops.snap @@ -24,8 +24,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -60,8 +60,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -362,8 +362,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -398,8 +398,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -700,8 +700,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -736,8 +736,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1038,8 +1038,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1074,8 +1074,8 @@ description: Operations executed exhaust-manifold.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/ast.snap b/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/ast.snap index feab342a3..7dfba3014 100644 --- a/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/focusrite-scarlett-mounting-bracket/ast.snap @@ -377,164 +377,167 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "pos", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, + "computed": false, "end": 0, - "name": { + "object": { "commentStart": 0, "end": 0, - "name": "w", + "name": "pos", "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, - "operator": "/", + "operator": "-", "right": { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "w", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "pos", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, + "computed": false, "end": 0, - "name": { + "object": { "commentStart": 0, "end": 0, - "name": "l", + "name": "pos", "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, - "operator": "/", + "operator": "-", "right": { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "l", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -544,7 +547,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -555,8 +558,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1866,128 +1870,131 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "w", + "name": { + "commentStart": 0, + "end": 0, + "name": "w", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", + "operator": "-", "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "raw": "2", + "name": { + "commentStart": 0, + "end": 0, + "name": "t", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "t", + "name": { + "commentStart": 0, + "end": 0, + "name": "d", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "+", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "d", + "name": { + "commentStart": 0, + "end": 0, + "name": "t", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "t", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1997,7 +2004,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2008,8 +2015,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -4210,22 +4218,65 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "width", + "name": "thk", "start": 0, "type": "Identifier" }, @@ -4234,58 +4285,58 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "thk", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "length", + "name": "thk", "start": 0, "type": "Identifier" }, @@ -4294,56 +4345,16 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "thk", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4353,7 +4364,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4364,8 +4375,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5718,90 +5730,73 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "width", + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", + "operator": "-", "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "thk", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "length", + "name": "thk", "start": 0, "type": "Identifier" }, @@ -5810,56 +5805,76 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "thk", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier" + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "thk", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5869,7 +5884,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5880,8 +5895,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -7707,100 +7723,103 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "length", + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", + "operator": "-", "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "raw": "2", + "name": { + "commentStart": 0, + "end": 0, + "name": "thk", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "thk", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -7810,7 +7829,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -7821,8 +7840,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -8170,22 +8190,65 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "length", + "name": "thk", "start": 0, "type": "Identifier" }, @@ -8194,68 +8257,28 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "thk", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -8265,7 +8288,7 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -8276,8 +8299,9 @@ description: Result of parsing focusrite-scarlett-mounting-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_graph_flowchart.snap.md index 58e45026b..b22b3f4f9 100644 --- a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/artifact_graph_flowchart.snap.md @@ -1,76 +1,76 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[1445, 1499, 0]"] - 3["Segment
[1505, 1537, 0]"] - 4["Segment
[1543, 1580, 0]"] - 5["Segment
[1586, 1619, 0]"] - 6["Segment
[1625, 1692, 0]"] - 7["Segment
[1698, 1705, 0]"] + 2["Path
[1448, 1505, 0]"] + 3["Segment
[1511, 1543, 0]"] + 4["Segment
[1549, 1586, 0]"] + 5["Segment
[1592, 1625, 0]"] + 6["Segment
[1631, 1698, 0]"] + 7["Segment
[1704, 1711, 0]"] 8[Solid2d] end subgraph path9 [Path] - 9["Path
[1001, 1042, 0]"] - 10["Segment
[1050, 1090, 0]"] - 11["Segment
[1098, 1144, 0]"] - 12["Segment
[1152, 1193, 0]"] - 13["Segment
[1201, 1266, 0]"] - 14["Segment
[1274, 1281, 0]"] + 9["Path
[1001, 1045, 0]"] + 10["Segment
[1053, 1093, 0]"] + 11["Segment
[1101, 1147, 0]"] + 12["Segment
[1155, 1196, 0]"] + 13["Segment
[1204, 1269, 0]"] + 14["Segment
[1277, 1284, 0]"] 15[Solid2d] end subgraph path16 [Path] - 16["Path
[1001, 1042, 0]"] - 17["Segment
[1050, 1090, 0]"] - 18["Segment
[1098, 1144, 0]"] - 19["Segment
[1152, 1193, 0]"] - 20["Segment
[1201, 1266, 0]"] - 21["Segment
[1274, 1281, 0]"] + 16["Path
[1001, 1045, 0]"] + 17["Segment
[1053, 1093, 0]"] + 18["Segment
[1101, 1147, 0]"] + 19["Segment
[1155, 1196, 0]"] + 20["Segment
[1204, 1269, 0]"] + 21["Segment
[1277, 1284, 0]"] 22[Solid2d] end subgraph path23 [Path] - 23["Path
[1001, 1042, 0]"] - 24["Segment
[1050, 1090, 0]"] - 25["Segment
[1098, 1144, 0]"] - 26["Segment
[1152, 1193, 0]"] - 27["Segment
[1201, 1266, 0]"] - 28["Segment
[1274, 1281, 0]"] + 23["Path
[1001, 1045, 0]"] + 24["Segment
[1053, 1093, 0]"] + 25["Segment
[1101, 1147, 0]"] + 26["Segment
[1155, 1196, 0]"] + 27["Segment
[1204, 1269, 0]"] + 28["Segment
[1277, 1284, 0]"] 29[Solid2d] end subgraph path49 [Path] - 49["Path
[2708, 2761, 0]"] - 50["Segment
[2767, 2826, 0]"] - 51["Segment
[2832, 2867, 0]"] - 52["Segment
[2873, 2906, 0]"] - 53["Segment
[2912, 2971, 0]"] - 54["Segment
[2977, 3013, 0]"] - 55["Segment
[3019, 3043, 0]"] - 56["Segment
[3049, 3056, 0]"] + 49["Path
[2714, 2770, 0]"] + 50["Segment
[2776, 2835, 0]"] + 51["Segment
[2841, 2876, 0]"] + 52["Segment
[2882, 2915, 0]"] + 53["Segment
[2921, 2980, 0]"] + 54["Segment
[2986, 3022, 0]"] + 55["Segment
[3028, 3052, 0]"] + 56["Segment
[3058, 3065, 0]"] 57[Solid2d] end subgraph path83 [Path] - 83["Path
[3651, 3698, 0]"] - 84["Segment
[3704, 3754, 0]"] - 85["Segment
[3760, 3826, 0]"] - 86["Segment
[3832, 3883, 0]"] - 87["Segment
[3889, 3954, 0]"] - 88["Segment
[3960, 4013, 0]"] - 89["Segment
[4019, 4086, 0]"] - 90["Segment
[4092, 4166, 0]"] - 91["Segment
[4172, 4240, 0]"] - 92["Segment
[4246, 4253, 0]"] + 83["Path
[3660, 3710, 0]"] + 84["Segment
[3716, 3766, 0]"] + 85["Segment
[3772, 3838, 0]"] + 86["Segment
[3844, 3895, 0]"] + 87["Segment
[3901, 3966, 0]"] + 88["Segment
[3972, 4025, 0]"] + 89["Segment
[4031, 4098, 0]"] + 90["Segment
[4104, 4178, 0]"] + 91["Segment
[4184, 4252, 0]"] + 92["Segment
[4258, 4265, 0]"] 93[Solid2d] end subgraph path121 [Path] - 121["Path
[1001, 1042, 0]"] - 122["Segment
[1050, 1090, 0]"] - 123["Segment
[1098, 1144, 0]"] - 124["Segment
[1152, 1193, 0]"] - 125["Segment
[1201, 1266, 0]"] - 126["Segment
[1274, 1281, 0]"] + 121["Path
[1001, 1045, 0]"] + 122["Segment
[1053, 1093, 0]"] + 123["Segment
[1101, 1147, 0]"] + 124["Segment
[1155, 1196, 0]"] + 125["Segment
[1204, 1269, 0]"] + 126["Segment
[1277, 1284, 0]"] 127[Solid2d] end - 1["Plane
[1374, 1391, 0]"] - 30["Sweep Extrusion
[2280, 2330, 0]"] + 1["Plane
[1377, 1394, 0]"] + 30["Sweep Extrusion
[2286, 2336, 0]"] 31[Wall] 32[Wall] 33[Wall] @@ -88,8 +88,8 @@ flowchart LR 45["SweepEdge Adjacent"] 46["SweepEdge Opposite"] 47["SweepEdge Adjacent"] - 48["Plane
[2605, 2647, 0]"] - 58["Sweep Extrusion
[3090, 3134, 0]"] + 48["Plane
[2611, 2653, 0]"] + 58["Sweep Extrusion
[3099, 3143, 0]"] 59[Wall] 60[Wall] 61[Wall] @@ -113,8 +113,8 @@ flowchart LR 79["SweepEdge Adjacent"] 80["SweepEdge Opposite"] 81["SweepEdge Adjacent"] - 82["Plane
[3577, 3603, 0]"] - 94["Sweep Extrusion
[4309, 4351, 0]"] + 82["Plane
[3586, 3612, 0]"] + 94["Sweep Extrusion
[4321, 4363, 0]"] 95[Wall] 96[Wall] 97[Wall] @@ -141,7 +141,7 @@ flowchart LR 118["SweepEdge Adjacent"] 119["SweepEdge Opposite"] 120["SweepEdge Adjacent"] - 128["Sweep Extrusion
[4586, 4636, 0]"] + 128["Sweep Extrusion
[4598, 4648, 0]"] 129[Wall] 130[Wall] 131[Wall] @@ -154,12 +154,12 @@ flowchart LR 138["SweepEdge Adjacent"] 139["SweepEdge Opposite"] 140["SweepEdge Adjacent"] - 141["EdgeCut Fillet
[2367, 2508, 0]"] - 142["EdgeCut Fillet
[2367, 2508, 0]"] - 143["EdgeCut Fillet
[3177, 3308, 0]"] - 144["EdgeCut Fillet
[3177, 3308, 0]"] - 145["StartSketchOnPlane
[2591, 2648, 0]"] - 146["StartSketchOnFace
[4410, 4449, 0]"] + 141["EdgeCut Fillet
[2373, 2514, 0]"] + 142["EdgeCut Fillet
[2373, 2514, 0]"] + 143["EdgeCut Fillet
[3186, 3317, 0]"] + 144["EdgeCut Fillet
[3186, 3317, 0]"] + 145["StartSketchOnPlane
[2597, 2654, 0]"] + 146["StartSketchOnFace
[4422, 4461, 0]"] 1 --- 2 1 --- 9 1 --- 16 diff --git a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ast.snap b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ast.snap index 51d7a0860..e0923d5db 100644 --- a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ast.snap @@ -1729,61 +1729,55 @@ description: Result of parsing food-service-spatula.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "xstart", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "ystart", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch1", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "xstart", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "ystart", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1793,7 +1787,7 @@ description: Result of parsing food-service-spatula.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1804,8 +1798,24 @@ description: Result of parsing food-service-spatula.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch1", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -2380,73 +2390,67 @@ description: Result of parsing food-service-spatula.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "flipperLength", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "32.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 32.0, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "flipperSketch", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "flipperLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "32.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 32.0, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2456,7 +2460,7 @@ description: Result of parsing food-service-spatula.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2467,8 +2471,24 @@ description: Result of parsing food-service-spatula.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "flipperSketch", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -3978,57 +3998,51 @@ description: Result of parsing food-service-spatula.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "flipperThickness", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "handleSketch", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "flipperThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4038,7 +4052,7 @@ description: Result of parsing food-service-spatula.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4049,8 +4063,24 @@ description: Result of parsing food-service-spatula.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "handleSketch", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -5211,69 +5241,63 @@ description: Result of parsing food-service-spatula.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "26.806746", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 26.806746, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "10.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 10.0, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "gripSketch", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "26.806746", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 26.806746, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "10.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 10.0, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5283,7 +5307,7 @@ description: Result of parsing food-service-spatula.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5294,8 +5318,24 @@ description: Result of parsing food-service-spatula.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "gripSketch", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ops.snap b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ops.snap index e11665622..26e090f39 100644 --- a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/ops.snap @@ -25,7 +25,7 @@ description: Operations executed food-service-spatula.kcl "name": "slot", "functionSourceRange": [ 462, - 1303, + 1306, 0 ], "unlabeledArg": null, @@ -39,8 +39,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -57,8 +57,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -93,8 +93,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -133,7 +133,7 @@ description: Operations executed food-service-spatula.kcl "name": "slot", "functionSourceRange": [ 462, - 1303, + 1306, 0 ], "unlabeledArg": null, @@ -147,8 +147,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -165,8 +165,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -201,8 +201,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -241,7 +241,7 @@ description: Operations executed food-service-spatula.kcl "name": "slot", "functionSourceRange": [ 462, - 1303, + 1306, 0 ], "unlabeledArg": null, @@ -255,8 +255,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -273,8 +273,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -309,8 +309,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -880,7 +880,7 @@ description: Operations executed food-service-spatula.kcl "name": "slot", "functionSourceRange": [ 462, - 1303, + 1306, 0 ], "unlabeledArg": null, @@ -894,8 +894,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -930,8 +930,8 @@ description: Operations executed food-service-spatula.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/program_memory.snap index 2c3267964..7802ea61f 100644 --- a/rust/kcl-lib/tests/kcl_samples/food-service-spatula/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/food-service-spatula/program_memory.snap @@ -27,9 +27,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 1570, - "end": 1579, - "start": 1570, + "commentStart": 1576, + "end": 1585, + "start": 1576, "type": "TagDeclarator", "value": "backEdge" }, @@ -90,9 +90,9 @@ description: Variables in memory after executing food-service-spatula.kcl -30.0 ], "tag": { - "commentStart": 1570, - "end": 1579, - "start": 1570, + "commentStart": 1576, + "end": 1585, + "start": 1576, "type": "TagDeclarator", "value": "backEdge" }, @@ -299,9 +299,9 @@ description: Variables in memory after executing food-service-spatula.kcl -30.0 ], "tag": { - "commentStart": 1570, - "end": 1579, - "start": 1570, + "commentStart": 1576, + "end": 1585, + "start": 1576, "type": "TagDeclarator", "value": "backEdge" }, @@ -551,9 +551,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -713,9 +713,9 @@ description: Variables in memory after executing food-service-spatula.kcl 7.0 ], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -1058,9 +1058,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -1220,9 +1220,9 @@ description: Variables in memory after executing food-service-spatula.kcl 7.0 ], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -1538,9 +1538,9 @@ description: Variables in memory after executing food-service-spatula.kcl 7.0 ], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -1729,9 +1729,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2808, - "end": 2825, - "start": 2808, + "commentStart": 2817, + "end": 2834, + "start": 2817, "type": "TagDeclarator", "value": "handleBottomEdge" }, @@ -1756,9 +1756,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2956, - "end": 2970, - "start": 2956, + "commentStart": 2965, + "end": 2979, + "start": 2965, "type": "TagDeclarator", "value": "handleTopEdge" }, @@ -1800,9 +1800,9 @@ description: Variables in memory after executing food-service-spatula.kcl 3.5 ], "tag": { - "commentStart": 2808, - "end": 2825, - "start": 2808, + "commentStart": 2817, + "end": 2834, + "start": 2817, "type": "TagDeclarator", "value": "handleBottomEdge" }, @@ -1863,9 +1863,9 @@ description: Variables in memory after executing food-service-spatula.kcl 91.3213 ], "tag": { - "commentStart": 2956, - "end": 2970, - "start": 2956, + "commentStart": 2965, + "end": 2979, + "start": 2965, "type": "TagDeclarator", "value": "handleTopEdge" }, @@ -2211,9 +2211,9 @@ description: Variables in memory after executing food-service-spatula.kcl 3.5 ], "tag": { - "commentStart": 2808, - "end": 2825, - "start": 2808, + "commentStart": 2817, + "end": 2834, + "start": 2817, "type": "TagDeclarator", "value": "handleBottomEdge" }, @@ -2274,9 +2274,9 @@ description: Variables in memory after executing food-service-spatula.kcl 91.3213 ], "tag": { - "commentStart": 2956, - "end": 2970, - "start": 2956, + "commentStart": 2965, + "end": 2979, + "start": 2965, "type": "TagDeclarator", "value": "handleTopEdge" }, @@ -2536,9 +2536,9 @@ description: Variables in memory after executing food-service-spatula.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -2698,9 +2698,9 @@ description: Variables in memory after executing food-service-spatula.kcl 7.0 ], "tag": { - "commentStart": 4153, - "end": 4165, - "start": 4153, + "commentStart": 4165, + "end": 4177, + "start": 4165, "type": "TagDeclarator", "value": "gripEdgeTop" }, @@ -3370,9 +3370,9 @@ description: Variables in memory after executing food-service-spatula.kcl -30.0 ], "tag": { - "commentStart": 1570, - "end": 1579, - "start": 1570, + "commentStart": 1576, + "end": 1585, + "start": 1576, "type": "TagDeclarator", "value": "backEdge" }, diff --git a/rust/kcl-lib/tests/kcl_samples/french-press/ast.snap b/rust/kcl-lib/tests/kcl_samples/french-press/ast.snap index 777643459..74a94f223 100644 --- a/rust/kcl-lib/tests/kcl_samples/french-press/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/french-press/ast.snap @@ -164,68 +164,71 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "carafeDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "carafeDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "5.7", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 5.7, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "5.7", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.7, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -235,7 +238,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -246,8 +249,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1198,68 +1202,71 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "carafeDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "carafeDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "5.7", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 5.7, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "5.7", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.7, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1269,7 +1276,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1280,8 +1287,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -3503,44 +3511,47 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.3, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.3, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0.17", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.17, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0.17", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.17, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3550,7 +3561,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3561,8 +3572,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -4134,44 +4146,47 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.15", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.15, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.15", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.15, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "1.11", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.11, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "1.11", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.11, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4181,7 +4196,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4192,8 +4207,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -4922,44 +4938,47 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.1, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.1, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4969,7 +4988,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4980,8 +4999,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -7321,68 +7341,71 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.2, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "carafeHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "commentStart": 0, - "end": 0, - "raw": "0.7", + "raw": "0.2", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 0.7, + "value": 0.2, "suffix": "None" } }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "carafeHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "commentStart": 0, + "end": 0, + "raw": "0.7", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.7, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -7392,7 +7415,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -7403,8 +7426,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -8293,44 +8317,47 @@ description: Result of parsing french-press.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "2.3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.3, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "2.3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.3, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "6.4", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 6.4, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "6.4", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 6.4, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -8340,7 +8367,7 @@ description: Result of parsing french-press.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -8351,8 +8378,9 @@ description: Result of parsing french-press.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gear-rack/ast.snap b/rust/kcl-lib/tests/kcl_samples/gear-rack/ast.snap index 37a8025d4..97efdd8a4 100644 --- a/rust/kcl-lib/tests/kcl_samples/gear-rack/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gear-rack/ast.snap @@ -230,76 +230,79 @@ description: Result of parsing gear-rack.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "length", + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -309,7 +312,7 @@ description: Result of parsing gear-rack.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -320,8 +323,9 @@ description: Result of parsing gear-rack.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -732,48 +736,74 @@ description: Result of parsing gear-rack.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "length", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, "commentStart": 0, "end": 0, - "operator": "-", + "left": { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", + "operator": "+", "right": { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0.567672", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.567672, "suffix": "None" } }, @@ -781,51 +811,28 @@ description: Result of parsing gear-rack.kcl "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "raw": "0.567672", + "name": { + "commentStart": 0, + "end": 0, + "name": "minHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.567672, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "minHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -835,7 +842,7 @@ description: Result of parsing gear-rack.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -846,8 +853,9 @@ description: Result of parsing gear-rack.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1740,76 +1748,79 @@ description: Result of parsing gear-rack.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "length", + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "11.849525", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 11.849525, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "11.849525", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 11.849525, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1819,7 +1830,7 @@ description: Result of parsing gear-rack.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1830,8 +1841,9 @@ description: Result of parsing gear-rack.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2254,68 +2266,71 @@ description: Result of parsing gear-rack.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "length", + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "11.849525", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 11.849525, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "11.849525", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 11.849525, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2325,7 +2340,7 @@ description: Result of parsing gear-rack.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2336,8 +2351,9 @@ description: Result of parsing gear-rack.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gear/ast.snap b/rust/kcl-lib/tests/kcl_samples/gear/ast.snap index 9d904d857..d2d189bce 100644 --- a/rust/kcl-lib/tests/kcl_samples/gear/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gear/ast.snap @@ -2892,76 +2892,79 @@ description: Result of parsing gear.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, + "computed": false, "end": 0, - "name": "xs", + "object": { + "commentStart": 0, + "end": 0, + "name": "xs", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "101", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 101.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier", - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "property": { + { "commentStart": 0, + "computed": false, "end": 0, - "raw": "101", + "object": { + "commentStart": 0, + "end": 0, + "name": "ys", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "101", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 101.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 101.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "ys", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "101", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 101.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "MemberExpression", + "type": "MemberExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2971,7 +2974,7 @@ description: Result of parsing gear.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2982,8 +2985,9 @@ description: Result of parsing gear.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null } ], "commentStart": 0, @@ -3960,148 +3964,151 @@ description: Result of parsing gear.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "holeRadius", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "startAngle", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "callee": { + "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "cos", + "name": "holeRadius", "start": 0, "type": "Identifier" }, "path": [], "start": 0, + "type": "Name", "type": "Name" }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "holeRadius", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "arguments": [ - { + "operator": "*", + "right": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startAngle", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "callee": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "startAngle", + "name": "cos", "start": 0, "type": "Identifier" }, "path": [], "start": 0, - "type": "Name", "type": "Name" - } - ], - "callee": { + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "sin", + "name": "holeRadius", "start": 0, "type": "Identifier" }, "path": [], "start": 0, + "type": "Name", "type": "Name" }, - "commentStart": 0, - "end": 0, + "operator": "*", + "right": { + "arguments": [ + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "startAngle", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "callee": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sin", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "start": 0, + "type": "CallExpression", + "type": "CallExpression" + }, "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4111,7 +4118,7 @@ description: Result of parsing gear.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4122,8 +4129,9 @@ description: Result of parsing gear.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gear/ops.snap b/rust/kcl-lib/tests/kcl_samples/gear/ops.snap index f5ecc658e..a327c7506 100644 --- a/rust/kcl-lib/tests/kcl_samples/gear/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/gear/ops.snap @@ -9,8 +9,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -45,8 +45,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -63,8 +63,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -81,8 +81,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -99,8 +99,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -117,8 +117,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -135,8 +135,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -153,8 +153,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -171,8 +171,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -189,8 +189,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -207,8 +207,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -225,8 +225,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -243,8 +243,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -261,8 +261,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -279,8 +279,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -297,8 +297,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -315,8 +315,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -333,8 +333,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -351,8 +351,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -369,8 +369,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -387,8 +387,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -405,8 +405,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -423,8 +423,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -441,8 +441,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -459,8 +459,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -477,8 +477,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -495,8 +495,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -513,8 +513,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -531,8 +531,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -549,8 +549,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -567,8 +567,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -585,8 +585,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -603,8 +603,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -621,8 +621,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -639,8 +639,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -657,8 +657,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -675,8 +675,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -693,8 +693,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -711,8 +711,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -729,8 +729,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -747,8 +747,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -765,8 +765,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -783,8 +783,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -801,8 +801,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -819,8 +819,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -837,8 +837,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -855,8 +855,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -873,8 +873,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -891,8 +891,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -909,8 +909,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -927,8 +927,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -945,8 +945,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -963,8 +963,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -981,8 +981,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -999,8 +999,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1017,8 +1017,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1035,8 +1035,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1053,8 +1053,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1071,8 +1071,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1089,8 +1089,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1107,8 +1107,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1125,8 +1125,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1143,8 +1143,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1161,8 +1161,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1179,8 +1179,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1197,8 +1197,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1215,8 +1215,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1233,8 +1233,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1251,8 +1251,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1269,8 +1269,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1287,8 +1287,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1305,8 +1305,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1323,8 +1323,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1341,8 +1341,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1359,8 +1359,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1377,8 +1377,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1395,8 +1395,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1413,8 +1413,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1431,8 +1431,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1449,8 +1449,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1467,8 +1467,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1485,8 +1485,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1503,8 +1503,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1521,8 +1521,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1539,8 +1539,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1557,8 +1557,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1575,8 +1575,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1593,8 +1593,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1611,8 +1611,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1629,8 +1629,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1647,8 +1647,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1665,8 +1665,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1683,8 +1683,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1701,8 +1701,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1719,8 +1719,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1737,8 +1737,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1755,8 +1755,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1773,8 +1773,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1791,8 +1791,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1809,8 +1809,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1827,8 +1827,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1845,8 +1845,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1863,8 +1863,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -1881,8 +1881,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1917,8 +1917,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1935,8 +1935,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1971,8 +1971,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1989,8 +1989,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2025,8 +2025,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2043,8 +2043,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2079,8 +2079,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2097,8 +2097,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2133,8 +2133,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2151,8 +2151,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2187,8 +2187,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2205,8 +2205,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2241,8 +2241,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2259,8 +2259,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2295,8 +2295,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2313,8 +2313,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2349,8 +2349,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2367,8 +2367,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2403,8 +2403,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2421,8 +2421,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2457,8 +2457,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2475,8 +2475,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2511,8 +2511,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2529,8 +2529,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2565,8 +2565,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2583,8 +2583,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2619,8 +2619,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2637,8 +2637,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2673,8 +2673,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2691,8 +2691,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2727,8 +2727,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2745,8 +2745,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2781,8 +2781,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2799,8 +2799,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2835,8 +2835,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2853,8 +2853,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2889,8 +2889,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2907,8 +2907,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2943,8 +2943,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2961,8 +2961,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2997,8 +2997,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3015,8 +3015,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3051,8 +3051,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3069,8 +3069,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3105,8 +3105,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3123,8 +3123,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3159,8 +3159,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3177,8 +3177,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3213,8 +3213,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3231,8 +3231,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3267,8 +3267,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3285,8 +3285,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3321,8 +3321,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3339,8 +3339,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3375,8 +3375,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3393,8 +3393,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3429,8 +3429,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3447,8 +3447,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3483,8 +3483,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3501,8 +3501,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3537,8 +3537,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3555,8 +3555,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3591,8 +3591,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3609,8 +3609,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3645,8 +3645,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3663,8 +3663,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3699,8 +3699,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3717,8 +3717,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3753,8 +3753,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3771,8 +3771,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3807,8 +3807,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3825,8 +3825,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3861,8 +3861,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3879,8 +3879,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3915,8 +3915,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3933,8 +3933,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3969,8 +3969,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3987,8 +3987,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4023,8 +4023,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4041,8 +4041,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4077,8 +4077,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4095,8 +4095,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4131,8 +4131,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4149,8 +4149,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4185,8 +4185,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4203,8 +4203,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4239,8 +4239,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4257,8 +4257,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4293,8 +4293,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4311,8 +4311,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4347,8 +4347,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4365,8 +4365,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4401,8 +4401,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4419,8 +4419,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4455,8 +4455,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4473,8 +4473,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4509,8 +4509,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4527,8 +4527,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4563,8 +4563,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4581,8 +4581,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4617,8 +4617,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4635,8 +4635,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4671,8 +4671,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4689,8 +4689,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4725,8 +4725,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4743,8 +4743,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4779,8 +4779,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4797,8 +4797,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4833,8 +4833,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4851,8 +4851,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4887,8 +4887,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4905,8 +4905,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4941,8 +4941,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4959,8 +4959,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4995,8 +4995,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5013,8 +5013,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5049,8 +5049,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5067,8 +5067,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5103,8 +5103,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5121,8 +5121,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5157,8 +5157,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5175,8 +5175,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5211,8 +5211,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5229,8 +5229,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5265,8 +5265,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5283,8 +5283,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5319,8 +5319,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5337,8 +5337,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5373,8 +5373,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5391,8 +5391,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5427,8 +5427,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5445,8 +5445,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5481,8 +5481,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5499,8 +5499,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5535,8 +5535,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5553,8 +5553,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5589,8 +5589,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5607,8 +5607,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5643,8 +5643,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5661,8 +5661,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5697,8 +5697,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5715,8 +5715,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5751,8 +5751,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5769,8 +5769,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5805,8 +5805,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5823,8 +5823,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5859,8 +5859,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5877,8 +5877,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5913,8 +5913,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5931,8 +5931,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5967,8 +5967,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -5985,8 +5985,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6021,8 +6021,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6039,8 +6039,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6075,8 +6075,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6093,8 +6093,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6129,8 +6129,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6147,8 +6147,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6183,8 +6183,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6201,8 +6201,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6237,8 +6237,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6255,8 +6255,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6291,8 +6291,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6309,8 +6309,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6345,8 +6345,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6363,8 +6363,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6399,8 +6399,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6417,8 +6417,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6453,8 +6453,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6471,8 +6471,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6507,8 +6507,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6525,8 +6525,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6561,8 +6561,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6579,8 +6579,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6615,8 +6615,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6633,8 +6633,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6669,8 +6669,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6687,8 +6687,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6723,8 +6723,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6741,8 +6741,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6777,8 +6777,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6795,8 +6795,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6831,8 +6831,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6849,8 +6849,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6885,8 +6885,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6903,8 +6903,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6939,8 +6939,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6957,8 +6957,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -6993,8 +6993,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7011,8 +7011,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7047,8 +7047,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7065,8 +7065,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7101,8 +7101,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7119,8 +7119,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7155,8 +7155,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7173,8 +7173,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7209,8 +7209,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7227,8 +7227,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7263,8 +7263,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7281,8 +7281,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7317,8 +7317,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7335,8 +7335,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7371,8 +7371,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11123,8 +11123,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11141,8 +11141,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11177,8 +11177,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11195,8 +11195,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11231,8 +11231,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11249,8 +11249,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11285,8 +11285,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11303,8 +11303,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11339,8 +11339,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11357,8 +11357,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11393,8 +11393,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11411,8 +11411,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11447,8 +11447,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11465,8 +11465,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11501,8 +11501,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11519,8 +11519,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11555,8 +11555,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11573,8 +11573,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11609,8 +11609,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11627,8 +11627,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11663,8 +11663,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11681,8 +11681,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11717,8 +11717,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11735,8 +11735,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11771,8 +11771,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11789,8 +11789,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11825,8 +11825,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11843,8 +11843,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11879,8 +11879,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11897,8 +11897,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11933,8 +11933,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -11951,8 +11951,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -11987,8 +11987,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12005,8 +12005,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12041,8 +12041,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12059,8 +12059,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12095,8 +12095,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12113,8 +12113,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12149,8 +12149,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12167,8 +12167,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12203,8 +12203,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12221,8 +12221,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12257,8 +12257,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12275,8 +12275,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12311,8 +12311,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12329,8 +12329,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12365,8 +12365,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12383,8 +12383,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12419,8 +12419,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12437,8 +12437,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12473,8 +12473,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12491,8 +12491,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12527,8 +12527,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12545,8 +12545,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12581,8 +12581,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12599,8 +12599,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12635,8 +12635,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12653,8 +12653,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12689,8 +12689,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12707,8 +12707,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12743,8 +12743,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12761,8 +12761,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12797,8 +12797,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12815,8 +12815,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12851,8 +12851,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12869,8 +12869,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12905,8 +12905,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12923,8 +12923,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -12959,8 +12959,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -12977,8 +12977,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13013,8 +13013,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13031,8 +13031,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13067,8 +13067,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13085,8 +13085,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13121,8 +13121,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13139,8 +13139,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13175,8 +13175,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13193,8 +13193,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13229,8 +13229,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13247,8 +13247,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13283,8 +13283,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13301,8 +13301,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13337,8 +13337,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13355,8 +13355,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13391,8 +13391,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13409,8 +13409,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13445,8 +13445,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13463,8 +13463,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13499,8 +13499,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13517,8 +13517,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13553,8 +13553,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13571,8 +13571,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13607,8 +13607,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13625,8 +13625,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13661,8 +13661,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13679,8 +13679,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13715,8 +13715,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13733,8 +13733,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13769,8 +13769,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13787,8 +13787,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13823,8 +13823,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13841,8 +13841,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13877,8 +13877,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13895,8 +13895,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13931,8 +13931,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -13949,8 +13949,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -13985,8 +13985,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14003,8 +14003,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14039,8 +14039,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14057,8 +14057,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14093,8 +14093,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14111,8 +14111,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14147,8 +14147,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14165,8 +14165,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14201,8 +14201,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14219,8 +14219,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14255,8 +14255,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14273,8 +14273,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14309,8 +14309,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14327,8 +14327,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14363,8 +14363,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14381,8 +14381,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14417,8 +14417,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14435,8 +14435,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14471,8 +14471,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14489,8 +14489,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14525,8 +14525,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14543,8 +14543,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14579,8 +14579,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14597,8 +14597,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14633,8 +14633,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14651,8 +14651,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14687,8 +14687,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14705,8 +14705,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14741,8 +14741,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14759,8 +14759,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14795,8 +14795,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14813,8 +14813,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14849,8 +14849,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14867,8 +14867,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14903,8 +14903,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14921,8 +14921,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -14957,8 +14957,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -14975,8 +14975,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15011,8 +15011,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15029,8 +15029,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15065,8 +15065,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15083,8 +15083,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15119,8 +15119,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15137,8 +15137,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15173,8 +15173,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15191,8 +15191,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15227,8 +15227,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15245,8 +15245,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15281,8 +15281,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15299,8 +15299,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15335,8 +15335,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15353,8 +15353,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15389,8 +15389,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15407,8 +15407,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15443,8 +15443,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15461,8 +15461,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15497,8 +15497,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15515,8 +15515,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15551,8 +15551,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15569,8 +15569,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15605,8 +15605,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15623,8 +15623,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15659,8 +15659,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15677,8 +15677,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15713,8 +15713,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15731,8 +15731,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15767,8 +15767,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15785,8 +15785,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15821,8 +15821,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15839,8 +15839,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15875,8 +15875,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15893,8 +15893,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15929,8 +15929,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -15947,8 +15947,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -15983,8 +15983,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16001,8 +16001,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16037,8 +16037,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16055,8 +16055,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16091,8 +16091,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16109,8 +16109,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16145,8 +16145,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16163,8 +16163,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16199,8 +16199,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16217,8 +16217,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16253,8 +16253,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16271,8 +16271,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16307,8 +16307,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16325,8 +16325,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16361,8 +16361,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16379,8 +16379,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16415,8 +16415,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16433,8 +16433,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16469,8 +16469,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16487,8 +16487,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16523,8 +16523,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16541,8 +16541,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16577,8 +16577,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16595,8 +16595,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16631,8 +16631,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16649,8 +16649,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16685,8 +16685,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16703,8 +16703,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16739,8 +16739,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16757,8 +16757,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16793,8 +16793,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16811,8 +16811,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16847,8 +16847,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16865,8 +16865,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16901,8 +16901,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16919,8 +16919,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -16955,8 +16955,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -16973,8 +16973,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17009,8 +17009,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17027,8 +17027,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17063,8 +17063,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17081,8 +17081,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17117,8 +17117,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17135,8 +17135,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17171,8 +17171,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17189,8 +17189,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17225,8 +17225,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17243,8 +17243,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17279,8 +17279,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17297,8 +17297,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17333,8 +17333,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17351,8 +17351,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17387,8 +17387,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17405,8 +17405,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17441,8 +17441,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17459,8 +17459,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17495,8 +17495,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17513,8 +17513,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17549,8 +17549,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17567,8 +17567,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17603,8 +17603,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17621,8 +17621,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17657,8 +17657,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17675,8 +17675,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17711,8 +17711,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17729,8 +17729,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17765,8 +17765,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17783,8 +17783,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17819,8 +17819,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17837,8 +17837,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17873,8 +17873,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17891,8 +17891,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17927,8 +17927,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17945,8 +17945,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -17981,8 +17981,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -17999,8 +17999,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18035,8 +18035,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18053,8 +18053,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18089,8 +18089,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18107,8 +18107,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18143,8 +18143,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18161,8 +18161,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18197,8 +18197,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18215,8 +18215,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18251,8 +18251,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18269,8 +18269,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18305,8 +18305,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18323,8 +18323,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18359,8 +18359,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18377,8 +18377,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18413,8 +18413,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18431,8 +18431,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18467,8 +18467,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18485,8 +18485,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18521,8 +18521,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18539,8 +18539,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18575,8 +18575,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18593,8 +18593,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18629,8 +18629,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18647,8 +18647,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18683,8 +18683,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18701,8 +18701,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18737,8 +18737,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18755,8 +18755,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18791,8 +18791,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18809,8 +18809,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18845,8 +18845,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18863,8 +18863,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18899,8 +18899,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18917,8 +18917,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -18953,8 +18953,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -18971,8 +18971,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19007,8 +19007,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19025,8 +19025,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19061,8 +19061,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19079,8 +19079,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19115,8 +19115,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19133,8 +19133,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19169,8 +19169,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19187,8 +19187,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19223,8 +19223,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19241,8 +19241,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19277,8 +19277,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19295,8 +19295,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19331,8 +19331,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19349,8 +19349,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19385,8 +19385,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19403,8 +19403,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19439,8 +19439,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19457,8 +19457,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19493,8 +19493,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19511,8 +19511,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19547,8 +19547,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19565,8 +19565,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19601,8 +19601,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19619,8 +19619,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19655,8 +19655,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19673,8 +19673,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19709,8 +19709,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19727,8 +19727,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19763,8 +19763,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19781,8 +19781,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19817,8 +19817,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19835,8 +19835,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19871,8 +19871,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19889,8 +19889,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19925,8 +19925,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19943,8 +19943,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -19979,8 +19979,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -19997,8 +19997,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20033,8 +20033,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20051,8 +20051,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20087,8 +20087,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20105,8 +20105,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20141,8 +20141,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20159,8 +20159,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20195,8 +20195,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20213,8 +20213,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20249,8 +20249,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20267,8 +20267,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20303,8 +20303,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20321,8 +20321,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20357,8 +20357,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20375,8 +20375,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20411,8 +20411,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20429,8 +20429,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20465,8 +20465,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20483,8 +20483,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20519,8 +20519,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20537,8 +20537,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20573,8 +20573,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20591,8 +20591,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20627,8 +20627,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20645,8 +20645,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20681,8 +20681,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20699,8 +20699,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20735,8 +20735,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20753,8 +20753,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20789,8 +20789,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20807,8 +20807,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20843,8 +20843,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20861,8 +20861,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20897,8 +20897,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20915,8 +20915,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -20951,8 +20951,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -20969,8 +20969,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21005,8 +21005,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21023,8 +21023,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21059,8 +21059,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21077,8 +21077,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21113,8 +21113,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21131,8 +21131,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21167,8 +21167,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21185,8 +21185,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21221,8 +21221,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21239,8 +21239,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21275,8 +21275,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21293,8 +21293,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21329,8 +21329,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21347,8 +21347,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21383,8 +21383,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21401,8 +21401,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21437,8 +21437,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21455,8 +21455,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21491,8 +21491,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21509,8 +21509,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21545,8 +21545,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21563,8 +21563,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21599,8 +21599,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21617,8 +21617,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21653,8 +21653,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21671,8 +21671,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21707,8 +21707,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21725,8 +21725,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21761,8 +21761,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21779,8 +21779,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21815,8 +21815,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21833,8 +21833,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21869,8 +21869,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21887,8 +21887,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21923,8 +21923,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21941,8 +21941,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -21977,8 +21977,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -21995,8 +21995,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -22271,8 +22271,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, @@ -22289,8 +22289,8 @@ description: Operations executed gear.kcl "type": "FunctionCall", "name": "toDegrees", "functionSourceRange": [ - 11927, - 11976, + 11933, + 11982, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/ast.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/ast.snap index 331fc9103..6791e081a 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate-magnets/ast.snap @@ -505,44 +505,47 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -552,7 +555,7 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -563,8 +566,9 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2783,96 +2787,99 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "firstStep", + "name": { + "commentStart": 0, + "end": 0, + "name": "firstStep", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "+", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "thirdStep", + "name": { + "commentStart": 0, + "end": 0, + "name": "thirdStep", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { + { "commentStart": 0, "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "magOuterDiam", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "magOuterDiam", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2882,7 +2889,7 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2893,8 +2900,9 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5272,44 +5280,47 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5319,7 +5330,7 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5330,8 +5341,9 @@ description: Result of parsing gridfinity-baseplate-magnets.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/ast.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/ast.snap index 893a685bc..8ebb63b09 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-baseplate/ast.snap @@ -406,44 +406,47 @@ description: Result of parsing gridfinity-baseplate.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -453,7 +456,7 @@ description: Result of parsing gridfinity-baseplate.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -464,8 +467,9 @@ description: Result of parsing gridfinity-baseplate.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/ast.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/ast.snap index 775761641..b9cbd0d43 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins-stacking-lip/ast.snap @@ -1001,72 +1001,75 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "+", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "binTol", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1076,7 +1079,7 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1087,8 +1090,9 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2964,100 +2968,103 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "+", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binTol", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "+", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "binTol", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3067,7 +3074,7 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3078,8 +3085,9 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5781,44 +5789,47 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5828,7 +5839,7 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5839,8 +5850,9 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -6740,44 +6752,47 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -6787,7 +6802,7 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -6798,8 +6813,9 @@ description: Result of parsing gridfinity-bins-stacking-lip.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/ast.snap b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/ast.snap index e506961fe..2e34fea9d 100644 --- a/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/gridfinity-bins/ast.snap @@ -670,72 +670,75 @@ description: Result of parsing gridfinity-bins.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "+", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "binTol", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -745,7 +748,7 @@ description: Result of parsing gridfinity-bins.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -756,8 +759,9 @@ description: Result of parsing gridfinity-bins.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2633,100 +2637,103 @@ description: Result of parsing gridfinity-bins.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "+", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binTol", + "name": { + "commentStart": 0, + "end": 0, + "name": "binBaseLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "+", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "binBaseLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "binTol", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "binTol", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2736,7 +2743,7 @@ description: Result of parsing gridfinity-bins.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2747,8 +2754,9 @@ description: Result of parsing gridfinity-bins.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5468,44 +5476,47 @@ description: Result of parsing gridfinity-bins.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5515,7 +5526,7 @@ description: Result of parsing gridfinity-bins.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5526,8 +5537,9 @@ description: Result of parsing gridfinity-bins.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/hex-nut/ast.snap b/rust/kcl-lib/tests/kcl_samples/hex-nut/ast.snap index 4249a267d..5d4ff81a6 100644 --- a/rust/kcl-lib/tests/kcl_samples/hex-nut/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/hex-nut/ast.snap @@ -187,12 +187,70 @@ description: Result of parsing hex-nut.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "start", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "innerDia", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { "commentStart": 0, "computed": false, "end": 0, @@ -207,80 +265,25 @@ description: Result of parsing hex-nut.kcl "property": { "commentStart": 0, "end": 0, - "raw": "0", + "raw": "1", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 0.0, + "value": 1.0, "suffix": "None" } }, "start": 0, "type": "MemberExpression", "type": "MemberExpression" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "innerDia", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "start", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -290,7 +293,7 @@ description: Result of parsing hex-nut.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -301,8 +304,9 @@ description: Result of parsing hex-nut.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 2a7150c8e..001f44eb0 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/ast.snap @@ -295,68 +295,71 @@ description: Result of parsing i-beam.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "beamHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "beamHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -366,7 +369,7 @@ description: Result of parsing i-beam.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -377,8 +380,9 @@ description: Result of parsing i-beam.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_graph_flowchart.snap.md index 939f77e74..a00857e7a 100644 --- a/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/keyboard/artifact_graph_flowchart.snap.md @@ -30,328 +30,328 @@ flowchart LR 39[Solid2d] end subgraph path61 [Path] - 61["Path
[1993, 2052, 0]"] - 62["Segment
[2060, 2111, 0]"] - 63["Segment
[2119, 2193, 0]"] - 64["Segment
[2201, 2240, 0]"] - 65["Segment
[2248, 2355, 0]"] - 66["Segment
[2363, 2402, 0]"] - 67["Segment
[2410, 2527, 0]"] - 68["Segment
[2535, 2574, 0]"] - 69["Segment
[2582, 2667, 0]"] - 70["Segment
[2675, 2682, 0]"] + 61["Path
[1993, 2055, 0]"] + 62["Segment
[2063, 2114, 0]"] + 63["Segment
[2122, 2196, 0]"] + 64["Segment
[2204, 2243, 0]"] + 65["Segment
[2251, 2358, 0]"] + 66["Segment
[2366, 2405, 0]"] + 67["Segment
[2413, 2530, 0]"] + 68["Segment
[2538, 2577, 0]"] + 69["Segment
[2585, 2670, 0]"] + 70["Segment
[2678, 2685, 0]"] 71[Solid2d] end subgraph path100 [Path] - 100["Path
[1993, 2052, 0]"] - 101["Segment
[2060, 2111, 0]"] - 102["Segment
[2119, 2193, 0]"] - 103["Segment
[2201, 2240, 0]"] - 104["Segment
[2248, 2355, 0]"] - 105["Segment
[2363, 2402, 0]"] - 106["Segment
[2410, 2527, 0]"] - 107["Segment
[2535, 2574, 0]"] - 108["Segment
[2582, 2667, 0]"] - 109["Segment
[2675, 2682, 0]"] + 100["Path
[1993, 2055, 0]"] + 101["Segment
[2063, 2114, 0]"] + 102["Segment
[2122, 2196, 0]"] + 103["Segment
[2204, 2243, 0]"] + 104["Segment
[2251, 2358, 0]"] + 105["Segment
[2366, 2405, 0]"] + 106["Segment
[2413, 2530, 0]"] + 107["Segment
[2538, 2577, 0]"] + 108["Segment
[2585, 2670, 0]"] + 109["Segment
[2678, 2685, 0]"] 110[Solid2d] end subgraph path139 [Path] - 139["Path
[1993, 2052, 0]"] - 140["Segment
[2060, 2111, 0]"] - 141["Segment
[2119, 2193, 0]"] - 142["Segment
[2201, 2240, 0]"] - 143["Segment
[2248, 2355, 0]"] - 144["Segment
[2363, 2402, 0]"] - 145["Segment
[2410, 2527, 0]"] - 146["Segment
[2535, 2574, 0]"] - 147["Segment
[2582, 2667, 0]"] - 148["Segment
[2675, 2682, 0]"] + 139["Path
[1993, 2055, 0]"] + 140["Segment
[2063, 2114, 0]"] + 141["Segment
[2122, 2196, 0]"] + 142["Segment
[2204, 2243, 0]"] + 143["Segment
[2251, 2358, 0]"] + 144["Segment
[2366, 2405, 0]"] + 145["Segment
[2413, 2530, 0]"] + 146["Segment
[2538, 2577, 0]"] + 147["Segment
[2585, 2670, 0]"] + 148["Segment
[2678, 2685, 0]"] 149[Solid2d] end subgraph path178 [Path] - 178["Path
[1993, 2052, 0]"] - 179["Segment
[2060, 2111, 0]"] - 180["Segment
[2119, 2193, 0]"] - 181["Segment
[2201, 2240, 0]"] - 182["Segment
[2248, 2355, 0]"] - 183["Segment
[2363, 2402, 0]"] - 184["Segment
[2410, 2527, 0]"] - 185["Segment
[2535, 2574, 0]"] - 186["Segment
[2582, 2667, 0]"] - 187["Segment
[2675, 2682, 0]"] + 178["Path
[1993, 2055, 0]"] + 179["Segment
[2063, 2114, 0]"] + 180["Segment
[2122, 2196, 0]"] + 181["Segment
[2204, 2243, 0]"] + 182["Segment
[2251, 2358, 0]"] + 183["Segment
[2366, 2405, 0]"] + 184["Segment
[2413, 2530, 0]"] + 185["Segment
[2538, 2577, 0]"] + 186["Segment
[2585, 2670, 0]"] + 187["Segment
[2678, 2685, 0]"] 188[Solid2d] end subgraph path217 [Path] - 217["Path
[1993, 2052, 0]"] - 218["Segment
[2060, 2111, 0]"] - 219["Segment
[2119, 2193, 0]"] - 220["Segment
[2201, 2240, 0]"] - 221["Segment
[2248, 2355, 0]"] - 222["Segment
[2363, 2402, 0]"] - 223["Segment
[2410, 2527, 0]"] - 224["Segment
[2535, 2574, 0]"] - 225["Segment
[2582, 2667, 0]"] - 226["Segment
[2675, 2682, 0]"] + 217["Path
[1993, 2055, 0]"] + 218["Segment
[2063, 2114, 0]"] + 219["Segment
[2122, 2196, 0]"] + 220["Segment
[2204, 2243, 0]"] + 221["Segment
[2251, 2358, 0]"] + 222["Segment
[2366, 2405, 0]"] + 223["Segment
[2413, 2530, 0]"] + 224["Segment
[2538, 2577, 0]"] + 225["Segment
[2585, 2670, 0]"] + 226["Segment
[2678, 2685, 0]"] 227[Solid2d] end subgraph path256 [Path] - 256["Path
[1993, 2052, 0]"] - 257["Segment
[2060, 2111, 0]"] - 258["Segment
[2119, 2193, 0]"] - 259["Segment
[2201, 2240, 0]"] - 260["Segment
[2248, 2355, 0]"] - 261["Segment
[2363, 2402, 0]"] - 262["Segment
[2410, 2527, 0]"] - 263["Segment
[2535, 2574, 0]"] - 264["Segment
[2582, 2667, 0]"] - 265["Segment
[2675, 2682, 0]"] + 256["Path
[1993, 2055, 0]"] + 257["Segment
[2063, 2114, 0]"] + 258["Segment
[2122, 2196, 0]"] + 259["Segment
[2204, 2243, 0]"] + 260["Segment
[2251, 2358, 0]"] + 261["Segment
[2366, 2405, 0]"] + 262["Segment
[2413, 2530, 0]"] + 263["Segment
[2538, 2577, 0]"] + 264["Segment
[2585, 2670, 0]"] + 265["Segment
[2678, 2685, 0]"] 266[Solid2d] end subgraph path295 [Path] - 295["Path
[1993, 2052, 0]"] - 296["Segment
[2060, 2111, 0]"] - 297["Segment
[2119, 2193, 0]"] - 298["Segment
[2201, 2240, 0]"] - 299["Segment
[2248, 2355, 0]"] - 300["Segment
[2363, 2402, 0]"] - 301["Segment
[2410, 2527, 0]"] - 302["Segment
[2535, 2574, 0]"] - 303["Segment
[2582, 2667, 0]"] - 304["Segment
[2675, 2682, 0]"] + 295["Path
[1993, 2055, 0]"] + 296["Segment
[2063, 2114, 0]"] + 297["Segment
[2122, 2196, 0]"] + 298["Segment
[2204, 2243, 0]"] + 299["Segment
[2251, 2358, 0]"] + 300["Segment
[2366, 2405, 0]"] + 301["Segment
[2413, 2530, 0]"] + 302["Segment
[2538, 2577, 0]"] + 303["Segment
[2585, 2670, 0]"] + 304["Segment
[2678, 2685, 0]"] 305[Solid2d] end subgraph path334 [Path] - 334["Path
[1993, 2052, 0]"] - 335["Segment
[2060, 2111, 0]"] - 336["Segment
[2119, 2193, 0]"] - 337["Segment
[2201, 2240, 0]"] - 338["Segment
[2248, 2355, 0]"] - 339["Segment
[2363, 2402, 0]"] - 340["Segment
[2410, 2527, 0]"] - 341["Segment
[2535, 2574, 0]"] - 342["Segment
[2582, 2667, 0]"] - 343["Segment
[2675, 2682, 0]"] + 334["Path
[1993, 2055, 0]"] + 335["Segment
[2063, 2114, 0]"] + 336["Segment
[2122, 2196, 0]"] + 337["Segment
[2204, 2243, 0]"] + 338["Segment
[2251, 2358, 0]"] + 339["Segment
[2366, 2405, 0]"] + 340["Segment
[2413, 2530, 0]"] + 341["Segment
[2538, 2577, 0]"] + 342["Segment
[2585, 2670, 0]"] + 343["Segment
[2678, 2685, 0]"] 344[Solid2d] end subgraph path373 [Path] - 373["Path
[1993, 2052, 0]"] - 374["Segment
[2060, 2111, 0]"] - 375["Segment
[2119, 2193, 0]"] - 376["Segment
[2201, 2240, 0]"] - 377["Segment
[2248, 2355, 0]"] - 378["Segment
[2363, 2402, 0]"] - 379["Segment
[2410, 2527, 0]"] - 380["Segment
[2535, 2574, 0]"] - 381["Segment
[2582, 2667, 0]"] - 382["Segment
[2675, 2682, 0]"] + 373["Path
[1993, 2055, 0]"] + 374["Segment
[2063, 2114, 0]"] + 375["Segment
[2122, 2196, 0]"] + 376["Segment
[2204, 2243, 0]"] + 377["Segment
[2251, 2358, 0]"] + 378["Segment
[2366, 2405, 0]"] + 379["Segment
[2413, 2530, 0]"] + 380["Segment
[2538, 2577, 0]"] + 381["Segment
[2585, 2670, 0]"] + 382["Segment
[2678, 2685, 0]"] 383[Solid2d] end subgraph path412 [Path] - 412["Path
[1993, 2052, 0]"] - 413["Segment
[2060, 2111, 0]"] - 414["Segment
[2119, 2193, 0]"] - 415["Segment
[2201, 2240, 0]"] - 416["Segment
[2248, 2355, 0]"] - 417["Segment
[2363, 2402, 0]"] - 418["Segment
[2410, 2527, 0]"] - 419["Segment
[2535, 2574, 0]"] - 420["Segment
[2582, 2667, 0]"] - 421["Segment
[2675, 2682, 0]"] + 412["Path
[1993, 2055, 0]"] + 413["Segment
[2063, 2114, 0]"] + 414["Segment
[2122, 2196, 0]"] + 415["Segment
[2204, 2243, 0]"] + 416["Segment
[2251, 2358, 0]"] + 417["Segment
[2366, 2405, 0]"] + 418["Segment
[2413, 2530, 0]"] + 419["Segment
[2538, 2577, 0]"] + 420["Segment
[2585, 2670, 0]"] + 421["Segment
[2678, 2685, 0]"] 422[Solid2d] end subgraph path451 [Path] - 451["Path
[1993, 2052, 0]"] - 452["Segment
[2060, 2111, 0]"] - 453["Segment
[2119, 2193, 0]"] - 454["Segment
[2201, 2240, 0]"] - 455["Segment
[2248, 2355, 0]"] - 456["Segment
[2363, 2402, 0]"] - 457["Segment
[2410, 2527, 0]"] - 458["Segment
[2535, 2574, 0]"] - 459["Segment
[2582, 2667, 0]"] - 460["Segment
[2675, 2682, 0]"] + 451["Path
[1993, 2055, 0]"] + 452["Segment
[2063, 2114, 0]"] + 453["Segment
[2122, 2196, 0]"] + 454["Segment
[2204, 2243, 0]"] + 455["Segment
[2251, 2358, 0]"] + 456["Segment
[2366, 2405, 0]"] + 457["Segment
[2413, 2530, 0]"] + 458["Segment
[2538, 2577, 0]"] + 459["Segment
[2585, 2670, 0]"] + 460["Segment
[2678, 2685, 0]"] 461[Solid2d] end subgraph path490 [Path] - 490["Path
[1993, 2052, 0]"] - 491["Segment
[2060, 2111, 0]"] - 492["Segment
[2119, 2193, 0]"] - 493["Segment
[2201, 2240, 0]"] - 494["Segment
[2248, 2355, 0]"] - 495["Segment
[2363, 2402, 0]"] - 496["Segment
[2410, 2527, 0]"] - 497["Segment
[2535, 2574, 0]"] - 498["Segment
[2582, 2667, 0]"] - 499["Segment
[2675, 2682, 0]"] + 490["Path
[1993, 2055, 0]"] + 491["Segment
[2063, 2114, 0]"] + 492["Segment
[2122, 2196, 0]"] + 493["Segment
[2204, 2243, 0]"] + 494["Segment
[2251, 2358, 0]"] + 495["Segment
[2366, 2405, 0]"] + 496["Segment
[2413, 2530, 0]"] + 497["Segment
[2538, 2577, 0]"] + 498["Segment
[2585, 2670, 0]"] + 499["Segment
[2678, 2685, 0]"] 500[Solid2d] end subgraph path529 [Path] - 529["Path
[1993, 2052, 0]"] - 530["Segment
[2060, 2111, 0]"] - 531["Segment
[2119, 2193, 0]"] - 532["Segment
[2201, 2240, 0]"] - 533["Segment
[2248, 2355, 0]"] - 534["Segment
[2363, 2402, 0]"] - 535["Segment
[2410, 2527, 0]"] - 536["Segment
[2535, 2574, 0]"] - 537["Segment
[2582, 2667, 0]"] - 538["Segment
[2675, 2682, 0]"] + 529["Path
[1993, 2055, 0]"] + 530["Segment
[2063, 2114, 0]"] + 531["Segment
[2122, 2196, 0]"] + 532["Segment
[2204, 2243, 0]"] + 533["Segment
[2251, 2358, 0]"] + 534["Segment
[2366, 2405, 0]"] + 535["Segment
[2413, 2530, 0]"] + 536["Segment
[2538, 2577, 0]"] + 537["Segment
[2585, 2670, 0]"] + 538["Segment
[2678, 2685, 0]"] 539[Solid2d] end subgraph path568 [Path] - 568["Path
[1993, 2052, 0]"] - 569["Segment
[2060, 2111, 0]"] - 570["Segment
[2119, 2193, 0]"] - 571["Segment
[2201, 2240, 0]"] - 572["Segment
[2248, 2355, 0]"] - 573["Segment
[2363, 2402, 0]"] - 574["Segment
[2410, 2527, 0]"] - 575["Segment
[2535, 2574, 0]"] - 576["Segment
[2582, 2667, 0]"] - 577["Segment
[2675, 2682, 0]"] + 568["Path
[1993, 2055, 0]"] + 569["Segment
[2063, 2114, 0]"] + 570["Segment
[2122, 2196, 0]"] + 571["Segment
[2204, 2243, 0]"] + 572["Segment
[2251, 2358, 0]"] + 573["Segment
[2366, 2405, 0]"] + 574["Segment
[2413, 2530, 0]"] + 575["Segment
[2538, 2577, 0]"] + 576["Segment
[2585, 2670, 0]"] + 577["Segment
[2678, 2685, 0]"] 578[Solid2d] end subgraph path607 [Path] - 607["Path
[1993, 2052, 0]"] - 608["Segment
[2060, 2111, 0]"] - 609["Segment
[2119, 2193, 0]"] - 610["Segment
[2201, 2240, 0]"] - 611["Segment
[2248, 2355, 0]"] - 612["Segment
[2363, 2402, 0]"] - 613["Segment
[2410, 2527, 0]"] - 614["Segment
[2535, 2574, 0]"] - 615["Segment
[2582, 2667, 0]"] - 616["Segment
[2675, 2682, 0]"] + 607["Path
[1993, 2055, 0]"] + 608["Segment
[2063, 2114, 0]"] + 609["Segment
[2122, 2196, 0]"] + 610["Segment
[2204, 2243, 0]"] + 611["Segment
[2251, 2358, 0]"] + 612["Segment
[2366, 2405, 0]"] + 613["Segment
[2413, 2530, 0]"] + 614["Segment
[2538, 2577, 0]"] + 615["Segment
[2585, 2670, 0]"] + 616["Segment
[2678, 2685, 0]"] 617[Solid2d] end subgraph path646 [Path] - 646["Path
[1993, 2052, 0]"] - 647["Segment
[2060, 2111, 0]"] - 648["Segment
[2119, 2193, 0]"] - 649["Segment
[2201, 2240, 0]"] - 650["Segment
[2248, 2355, 0]"] - 651["Segment
[2363, 2402, 0]"] - 652["Segment
[2410, 2527, 0]"] - 653["Segment
[2535, 2574, 0]"] - 654["Segment
[2582, 2667, 0]"] - 655["Segment
[2675, 2682, 0]"] + 646["Path
[1993, 2055, 0]"] + 647["Segment
[2063, 2114, 0]"] + 648["Segment
[2122, 2196, 0]"] + 649["Segment
[2204, 2243, 0]"] + 650["Segment
[2251, 2358, 0]"] + 651["Segment
[2366, 2405, 0]"] + 652["Segment
[2413, 2530, 0]"] + 653["Segment
[2538, 2577, 0]"] + 654["Segment
[2585, 2670, 0]"] + 655["Segment
[2678, 2685, 0]"] 656[Solid2d] end subgraph path685 [Path] - 685["Path
[1993, 2052, 0]"] - 686["Segment
[2060, 2111, 0]"] - 687["Segment
[2119, 2193, 0]"] - 688["Segment
[2201, 2240, 0]"] - 689["Segment
[2248, 2355, 0]"] - 690["Segment
[2363, 2402, 0]"] - 691["Segment
[2410, 2527, 0]"] - 692["Segment
[2535, 2574, 0]"] - 693["Segment
[2582, 2667, 0]"] - 694["Segment
[2675, 2682, 0]"] + 685["Path
[1993, 2055, 0]"] + 686["Segment
[2063, 2114, 0]"] + 687["Segment
[2122, 2196, 0]"] + 688["Segment
[2204, 2243, 0]"] + 689["Segment
[2251, 2358, 0]"] + 690["Segment
[2366, 2405, 0]"] + 691["Segment
[2413, 2530, 0]"] + 692["Segment
[2538, 2577, 0]"] + 693["Segment
[2585, 2670, 0]"] + 694["Segment
[2678, 2685, 0]"] 695[Solid2d] end subgraph path724 [Path] - 724["Path
[1993, 2052, 0]"] - 725["Segment
[2060, 2111, 0]"] - 726["Segment
[2119, 2193, 0]"] - 727["Segment
[2201, 2240, 0]"] - 728["Segment
[2248, 2355, 0]"] - 729["Segment
[2363, 2402, 0]"] - 730["Segment
[2410, 2527, 0]"] - 731["Segment
[2535, 2574, 0]"] - 732["Segment
[2582, 2667, 0]"] - 733["Segment
[2675, 2682, 0]"] + 724["Path
[1993, 2055, 0]"] + 725["Segment
[2063, 2114, 0]"] + 726["Segment
[2122, 2196, 0]"] + 727["Segment
[2204, 2243, 0]"] + 728["Segment
[2251, 2358, 0]"] + 729["Segment
[2366, 2405, 0]"] + 730["Segment
[2413, 2530, 0]"] + 731["Segment
[2538, 2577, 0]"] + 732["Segment
[2585, 2670, 0]"] + 733["Segment
[2678, 2685, 0]"] 734[Solid2d] end subgraph path763 [Path] - 763["Path
[1993, 2052, 0]"] - 764["Segment
[2060, 2111, 0]"] - 765["Segment
[2119, 2193, 0]"] - 766["Segment
[2201, 2240, 0]"] - 767["Segment
[2248, 2355, 0]"] - 768["Segment
[2363, 2402, 0]"] - 769["Segment
[2410, 2527, 0]"] - 770["Segment
[2535, 2574, 0]"] - 771["Segment
[2582, 2667, 0]"] - 772["Segment
[2675, 2682, 0]"] + 763["Path
[1993, 2055, 0]"] + 764["Segment
[2063, 2114, 0]"] + 765["Segment
[2122, 2196, 0]"] + 766["Segment
[2204, 2243, 0]"] + 767["Segment
[2251, 2358, 0]"] + 768["Segment
[2366, 2405, 0]"] + 769["Segment
[2413, 2530, 0]"] + 770["Segment
[2538, 2577, 0]"] + 771["Segment
[2585, 2670, 0]"] + 772["Segment
[2678, 2685, 0]"] 773[Solid2d] end subgraph path802 [Path] - 802["Path
[1993, 2052, 0]"] - 803["Segment
[2060, 2111, 0]"] - 804["Segment
[2119, 2193, 0]"] - 805["Segment
[2201, 2240, 0]"] - 806["Segment
[2248, 2355, 0]"] - 807["Segment
[2363, 2402, 0]"] - 808["Segment
[2410, 2527, 0]"] - 809["Segment
[2535, 2574, 0]"] - 810["Segment
[2582, 2667, 0]"] - 811["Segment
[2675, 2682, 0]"] + 802["Path
[1993, 2055, 0]"] + 803["Segment
[2063, 2114, 0]"] + 804["Segment
[2122, 2196, 0]"] + 805["Segment
[2204, 2243, 0]"] + 806["Segment
[2251, 2358, 0]"] + 807["Segment
[2366, 2405, 0]"] + 808["Segment
[2413, 2530, 0]"] + 809["Segment
[2538, 2577, 0]"] + 810["Segment
[2585, 2670, 0]"] + 811["Segment
[2678, 2685, 0]"] 812[Solid2d] end subgraph path841 [Path] - 841["Path
[1993, 2052, 0]"] - 842["Segment
[2060, 2111, 0]"] - 843["Segment
[2119, 2193, 0]"] - 844["Segment
[2201, 2240, 0]"] - 845["Segment
[2248, 2355, 0]"] - 846["Segment
[2363, 2402, 0]"] - 847["Segment
[2410, 2527, 0]"] - 848["Segment
[2535, 2574, 0]"] - 849["Segment
[2582, 2667, 0]"] - 850["Segment
[2675, 2682, 0]"] + 841["Path
[1993, 2055, 0]"] + 842["Segment
[2063, 2114, 0]"] + 843["Segment
[2122, 2196, 0]"] + 844["Segment
[2204, 2243, 0]"] + 845["Segment
[2251, 2358, 0]"] + 846["Segment
[2366, 2405, 0]"] + 847["Segment
[2413, 2530, 0]"] + 848["Segment
[2538, 2577, 0]"] + 849["Segment
[2585, 2670, 0]"] + 850["Segment
[2678, 2685, 0]"] 851[Solid2d] end subgraph path880 [Path] - 880["Path
[4914, 5001, 0]"] - 881["Segment
[5009, 5038, 0]"] - 882["Segment
[5046, 5074, 0]"] - 883["Segment
[5082, 5160, 0]"] - 884["Segment
[5168, 5215, 0]"] - 885["Segment
[5223, 5251, 0]"] - 886["Segment
[5259, 5288, 0]"] - 887["Segment
[5296, 5325, 0]"] - 888["Segment
[5333, 5399, 0]"] - 889["Segment
[5407, 5435, 0]"] - 890["Segment
[5443, 5472, 0]"] - 891["Segment
[5480, 5542, 0]"] - 892["Segment
[5550, 5578, 0]"] - 893["Segment
[5586, 5620, 0]"] - 894["Segment
[5628, 5658, 0]"] - 895["Segment
[5666, 5734, 0]"] - 896["Segment
[5742, 5749, 0]"] + 880["Path
[4917, 5004, 0]"] + 881["Segment
[5012, 5041, 0]"] + 882["Segment
[5049, 5077, 0]"] + 883["Segment
[5085, 5163, 0]"] + 884["Segment
[5171, 5218, 0]"] + 885["Segment
[5226, 5254, 0]"] + 886["Segment
[5262, 5291, 0]"] + 887["Segment
[5299, 5328, 0]"] + 888["Segment
[5336, 5402, 0]"] + 889["Segment
[5410, 5438, 0]"] + 890["Segment
[5446, 5475, 0]"] + 891["Segment
[5483, 5545, 0]"] + 892["Segment
[5553, 5581, 0]"] + 893["Segment
[5589, 5623, 0]"] + 894["Segment
[5631, 5661, 0]"] + 895["Segment
[5669, 5737, 0]"] + 896["Segment
[5745, 5752, 0]"] 897[Solid2d] end subgraph path950 [Path] - 950["Path
[5949, 6047, 0]"] - 951["Segment
[6055, 6133, 0]"] - 952["Segment
[6141, 6188, 0]"] - 953["Segment
[6196, 6276, 0]"] - 954["Segment
[6284, 6291, 0]"] + 950["Path
[5952, 6050, 0]"] + 951["Segment
[6058, 6136, 0]"] + 952["Segment
[6144, 6191, 0]"] + 953["Segment
[6199, 6279, 0]"] + 954["Segment
[6287, 6294, 0]"] 955[Solid2d] end subgraph path972 [Path] - 972["Path
[6399, 6496, 0]"] - 973["Segment
[6504, 6582, 0]"] - 974["Segment
[6590, 6638, 0]"] - 975["Segment
[6646, 6726, 0]"] - 976["Segment
[6734, 6741, 0]"] + 972["Path
[6402, 6499, 0]"] + 973["Segment
[6507, 6585, 0]"] + 974["Segment
[6593, 6641, 0]"] + 975["Segment
[6649, 6729, 0]"] + 976["Segment
[6737, 6744, 0]"] 977[Solid2d] end subgraph path994 [Path] - 994["Path
[5949, 6047, 0]"] - 995["Segment
[6055, 6133, 0]"] - 996["Segment
[6141, 6188, 0]"] - 997["Segment
[6196, 6276, 0]"] - 998["Segment
[6284, 6291, 0]"] + 994["Path
[5952, 6050, 0]"] + 995["Segment
[6058, 6136, 0]"] + 996["Segment
[6144, 6191, 0]"] + 997["Segment
[6199, 6279, 0]"] + 998["Segment
[6287, 6294, 0]"] 999[Solid2d] end subgraph path1016 [Path] - 1016["Path
[6399, 6496, 0]"] - 1017["Segment
[6504, 6582, 0]"] - 1018["Segment
[6590, 6638, 0]"] - 1019["Segment
[6646, 6726, 0]"] - 1020["Segment
[6734, 6741, 0]"] + 1016["Path
[6402, 6499, 0]"] + 1017["Segment
[6507, 6585, 0]"] + 1018["Segment
[6593, 6641, 0]"] + 1019["Segment
[6649, 6729, 0]"] + 1020["Segment
[6737, 6744, 0]"] 1021[Solid2d] end 1["Plane
[532, 549, 0]"] @@ -395,7 +395,7 @@ flowchart LR 58["SweepEdge Opposite"] 59["SweepEdge Adjacent"] 60["Plane
[1954, 1977, 0]"] - 72["Sweep Extrusion
[2690, 2716, 0]"] + 72["Sweep Extrusion
[2693, 2719, 0]"] 73[Wall] 74[Wall] 75[Wall] @@ -423,7 +423,7 @@ flowchart LR 97["SweepEdge Opposite"] 98["SweepEdge Adjacent"] 99["Plane
[1954, 1977, 0]"] - 111["Sweep Extrusion
[2690, 2716, 0]"] + 111["Sweep Extrusion
[2693, 2719, 0]"] 112[Wall] 113[Wall] 114[Wall] @@ -451,7 +451,7 @@ flowchart LR 136["SweepEdge Opposite"] 137["SweepEdge Adjacent"] 138["Plane
[1954, 1977, 0]"] - 150["Sweep Extrusion
[2690, 2716, 0]"] + 150["Sweep Extrusion
[2693, 2719, 0]"] 151[Wall] 152[Wall] 153[Wall] @@ -479,7 +479,7 @@ flowchart LR 175["SweepEdge Opposite"] 176["SweepEdge Adjacent"] 177["Plane
[1954, 1977, 0]"] - 189["Sweep Extrusion
[2690, 2716, 0]"] + 189["Sweep Extrusion
[2693, 2719, 0]"] 190[Wall] 191[Wall] 192[Wall] @@ -507,7 +507,7 @@ flowchart LR 214["SweepEdge Opposite"] 215["SweepEdge Adjacent"] 216["Plane
[1954, 1977, 0]"] - 228["Sweep Extrusion
[2690, 2716, 0]"] + 228["Sweep Extrusion
[2693, 2719, 0]"] 229[Wall] 230[Wall] 231[Wall] @@ -535,7 +535,7 @@ flowchart LR 253["SweepEdge Opposite"] 254["SweepEdge Adjacent"] 255["Plane
[1954, 1977, 0]"] - 267["Sweep Extrusion
[2690, 2716, 0]"] + 267["Sweep Extrusion
[2693, 2719, 0]"] 268[Wall] 269[Wall] 270[Wall] @@ -563,7 +563,7 @@ flowchart LR 292["SweepEdge Opposite"] 293["SweepEdge Adjacent"] 294["Plane
[1954, 1977, 0]"] - 306["Sweep Extrusion
[2690, 2716, 0]"] + 306["Sweep Extrusion
[2693, 2719, 0]"] 307[Wall] 308[Wall] 309[Wall] @@ -591,7 +591,7 @@ flowchart LR 331["SweepEdge Opposite"] 332["SweepEdge Adjacent"] 333["Plane
[1954, 1977, 0]"] - 345["Sweep Extrusion
[2690, 2716, 0]"] + 345["Sweep Extrusion
[2693, 2719, 0]"] 346[Wall] 347[Wall] 348[Wall] @@ -619,7 +619,7 @@ flowchart LR 370["SweepEdge Opposite"] 371["SweepEdge Adjacent"] 372["Plane
[1954, 1977, 0]"] - 384["Sweep Extrusion
[2690, 2716, 0]"] + 384["Sweep Extrusion
[2693, 2719, 0]"] 385[Wall] 386[Wall] 387[Wall] @@ -647,7 +647,7 @@ flowchart LR 409["SweepEdge Opposite"] 410["SweepEdge Adjacent"] 411["Plane
[1954, 1977, 0]"] - 423["Sweep Extrusion
[2690, 2716, 0]"] + 423["Sweep Extrusion
[2693, 2719, 0]"] 424[Wall] 425[Wall] 426[Wall] @@ -675,7 +675,7 @@ flowchart LR 448["SweepEdge Opposite"] 449["SweepEdge Adjacent"] 450["Plane
[1954, 1977, 0]"] - 462["Sweep Extrusion
[2690, 2716, 0]"] + 462["Sweep Extrusion
[2693, 2719, 0]"] 463[Wall] 464[Wall] 465[Wall] @@ -703,7 +703,7 @@ flowchart LR 487["SweepEdge Opposite"] 488["SweepEdge Adjacent"] 489["Plane
[1954, 1977, 0]"] - 501["Sweep Extrusion
[2690, 2716, 0]"] + 501["Sweep Extrusion
[2693, 2719, 0]"] 502[Wall] 503[Wall] 504[Wall] @@ -731,7 +731,7 @@ flowchart LR 526["SweepEdge Opposite"] 527["SweepEdge Adjacent"] 528["Plane
[1954, 1977, 0]"] - 540["Sweep Extrusion
[2690, 2716, 0]"] + 540["Sweep Extrusion
[2693, 2719, 0]"] 541[Wall] 542[Wall] 543[Wall] @@ -759,7 +759,7 @@ flowchart LR 565["SweepEdge Opposite"] 566["SweepEdge Adjacent"] 567["Plane
[1954, 1977, 0]"] - 579["Sweep Extrusion
[2690, 2716, 0]"] + 579["Sweep Extrusion
[2693, 2719, 0]"] 580[Wall] 581[Wall] 582[Wall] @@ -787,7 +787,7 @@ flowchart LR 604["SweepEdge Opposite"] 605["SweepEdge Adjacent"] 606["Plane
[1954, 1977, 0]"] - 618["Sweep Extrusion
[2690, 2716, 0]"] + 618["Sweep Extrusion
[2693, 2719, 0]"] 619[Wall] 620[Wall] 621[Wall] @@ -815,7 +815,7 @@ flowchart LR 643["SweepEdge Opposite"] 644["SweepEdge Adjacent"] 645["Plane
[1954, 1977, 0]"] - 657["Sweep Extrusion
[2690, 2716, 0]"] + 657["Sweep Extrusion
[2693, 2719, 0]"] 658[Wall] 659[Wall] 660[Wall] @@ -843,7 +843,7 @@ flowchart LR 682["SweepEdge Opposite"] 683["SweepEdge Adjacent"] 684["Plane
[1954, 1977, 0]"] - 696["Sweep Extrusion
[2690, 2716, 0]"] + 696["Sweep Extrusion
[2693, 2719, 0]"] 697[Wall] 698[Wall] 699[Wall] @@ -871,7 +871,7 @@ flowchart LR 721["SweepEdge Opposite"] 722["SweepEdge Adjacent"] 723["Plane
[1954, 1977, 0]"] - 735["Sweep Extrusion
[2690, 2716, 0]"] + 735["Sweep Extrusion
[2693, 2719, 0]"] 736[Wall] 737[Wall] 738[Wall] @@ -899,7 +899,7 @@ flowchart LR 760["SweepEdge Opposite"] 761["SweepEdge Adjacent"] 762["Plane
[1954, 1977, 0]"] - 774["Sweep Extrusion
[2690, 2716, 0]"] + 774["Sweep Extrusion
[2693, 2719, 0]"] 775[Wall] 776[Wall] 777[Wall] @@ -927,7 +927,7 @@ flowchart LR 799["SweepEdge Opposite"] 800["SweepEdge Adjacent"] 801["Plane
[1954, 1977, 0]"] - 813["Sweep Extrusion
[2690, 2716, 0]"] + 813["Sweep Extrusion
[2693, 2719, 0]"] 814[Wall] 815[Wall] 816[Wall] @@ -955,7 +955,7 @@ flowchart LR 838["SweepEdge Opposite"] 839["SweepEdge Adjacent"] 840["Plane
[1954, 1977, 0]"] - 852["Sweep Extrusion
[2690, 2716, 0]"] + 852["Sweep Extrusion
[2693, 2719, 0]"] 853[Wall] 854[Wall] 855[Wall] @@ -982,8 +982,8 @@ flowchart LR 876["SweepEdge Adjacent"] 877["SweepEdge Opposite"] 878["SweepEdge Adjacent"] - 879["Plane
[4883, 4906, 0]"] - 898["Sweep Extrusion
[5757, 5781, 0]"] + 879["Plane
[4886, 4909, 0]"] + 898["Sweep Extrusion
[5760, 5784, 0]"] 899[Wall] 900[Wall] 901[Wall] @@ -1034,8 +1034,8 @@ flowchart LR 946["SweepEdge Adjacent"] 947["SweepEdge Opposite"] 948["SweepEdge Adjacent"] - 949["Plane
[5918, 5941, 0]"] - 956["Sweep Extrusion
[6299, 6323, 0]"] + 949["Plane
[5921, 5944, 0]"] + 956["Sweep Extrusion
[6302, 6326, 0]"] 957[Wall] 958[Wall] 959[Wall] @@ -1050,8 +1050,8 @@ flowchart LR 968["SweepEdge Adjacent"] 969["SweepEdge Opposite"] 970["SweepEdge Adjacent"] - 971["Plane
[6368, 6391, 0]"] - 978["Sweep Extrusion
[6749, 6773, 0]"] + 971["Plane
[6371, 6394, 0]"] + 978["Sweep Extrusion
[6752, 6776, 0]"] 979[Wall] 980[Wall] 981[Wall] @@ -1066,8 +1066,8 @@ flowchart LR 990["SweepEdge Adjacent"] 991["SweepEdge Opposite"] 992["SweepEdge Adjacent"] - 993["Plane
[5918, 5941, 0]"] - 1000["Sweep Extrusion
[6299, 6323, 0]"] + 993["Plane
[5921, 5944, 0]"] + 1000["Sweep Extrusion
[6302, 6326, 0]"] 1001[Wall] 1002[Wall] 1003[Wall] @@ -1082,8 +1082,8 @@ flowchart LR 1012["SweepEdge Adjacent"] 1013["SweepEdge Opposite"] 1014["SweepEdge Adjacent"] - 1015["Plane
[6368, 6391, 0]"] - 1022["Sweep Extrusion
[6749, 6773, 0]"] + 1015["Plane
[6371, 6394, 0]"] + 1022["Sweep Extrusion
[6752, 6776, 0]"] 1023[Wall] 1024[Wall] 1025[Wall] diff --git a/rust/kcl-lib/tests/kcl_samples/keyboard/ast.snap b/rust/kcl-lib/tests/kcl_samples/keyboard/ast.snap index 922d7ab4e..81ee66fe5 100644 --- a/rust/kcl-lib/tests/kcl_samples/keyboard/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/keyboard/ast.snap @@ -736,44 +736,47 @@ description: Result of parsing keyboard.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -783,7 +786,7 @@ description: Result of parsing keyboard.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -794,8 +797,9 @@ description: Result of parsing keyboard.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2763,85 +2767,79 @@ description: Result of parsing keyboard.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "originStart", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "originStart", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch002", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "originStart", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "originStart", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2851,7 +2849,7 @@ description: Result of parsing keyboard.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2862,8 +2860,24 @@ description: Result of parsing keyboard.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -8106,37 +8120,21 @@ description: Result of parsing keyboard.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "operator": "+", - "right": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "origin", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { + "left": { "commentStart": 0, "end": 0, "raw": "0", @@ -8148,98 +8146,117 @@ description: Result of parsing keyboard.kcl "suffix": "None" } }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "raw": "0.15", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.15, - "suffix": "None" - } - }, - "operator": "*", + "operator": "+", "right": { - "abs_path": false, "commentStart": 0, + "computed": false, "end": 0, - "name": { + "object": { "commentStart": 0, "end": 0, - "name": "scale", + "name": "origin", "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { + { "commentStart": 0, - "computed": false, "end": 0, - "object": { + "left": { "commentStart": 0, "end": 0, - "name": "origin", + "left": { + "commentStart": 0, + "end": 0, + "raw": "0.15", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.15, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "scale", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, "start": 0, - "type": "Identifier", - "type": "Identifier" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "property": { + "operator": "+", + "right": { "commentStart": 0, + "computed": false, "end": 0, - "raw": "1", + "object": { + "commentStart": 0, + "end": 0, + "name": "origin", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -8249,7 +8266,7 @@ description: Result of parsing keyboard.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -8260,8 +8277,9 @@ description: Result of parsing keyboard.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -9917,164 +9935,167 @@ description: Result of parsing keyboard.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { "commentStart": 0, "end": 0, - "raw": ".788", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.788, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "scale", + "raw": ".788", "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.788, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "scale", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "origin", + "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "origin", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { + { "commentStart": 0, "end": 0, "left": { "commentStart": 0, "end": 0, - "raw": ".921", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.921, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "scale", + "raw": ".921", "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.921, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "scale", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "origin", + "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "origin", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -10084,7 +10105,7 @@ description: Result of parsing keyboard.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -10095,8 +10116,9 @@ description: Result of parsing keyboard.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -10747,164 +10769,167 @@ description: Result of parsing keyboard.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { "commentStart": 0, "end": 0, - "raw": ".16", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.16, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "scale", + "raw": ".16", "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.16, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "scale", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "origin", + "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "+", - "right": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "origin", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { + { "commentStart": 0, "end": 0, "left": { "commentStart": 0, "end": 0, - "raw": ".079", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.079, - "suffix": "None" - } - }, - "operator": "*", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "left": { "commentStart": 0, "end": 0, - "name": "scale", + "raw": ".079", "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.079, + "suffix": "None" + } + }, + "operator": "*", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "scale", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "+", + "right": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "origin", + "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "operator": "+", - "right": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "origin", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -10914,7 +10939,7 @@ description: Result of parsing keyboard.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -10925,8 +10950,9 @@ description: Result of parsing keyboard.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/keyboard/ops.snap b/rust/kcl-lib/tests/kcl_samples/keyboard/ops.snap index 3a704ac16..3c8a3fe3a 100644 --- a/rust/kcl-lib/tests/kcl_samples/keyboard/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/keyboard/ops.snap @@ -193,8 +193,8 @@ description: Operations executed keyboard.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -230,7 +230,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -562,7 +562,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -894,7 +894,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -1226,7 +1226,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -1558,7 +1558,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -1890,7 +1890,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -2222,7 +2222,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -2554,7 +2554,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -2886,7 +2886,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -3218,7 +3218,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -3550,7 +3550,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -3882,7 +3882,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -4214,7 +4214,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -4546,7 +4546,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -4878,7 +4878,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -5210,7 +5210,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -5542,7 +5542,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -5874,7 +5874,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -6206,7 +6206,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -6538,7 +6538,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -6870,7 +6870,7 @@ description: Operations executed keyboard.kcl "name": "keyFn", "functionSourceRange": [ 1887, - 2974, + 2977, 0 ], "unlabeledArg": null, @@ -7201,8 +7201,8 @@ description: Operations executed keyboard.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -7237,8 +7237,8 @@ description: Operations executed keyboard.kcl "type": "FunctionCall", "name": "z", "functionSourceRange": [ - 4852, - 5831, + 4855, + 5834, 0 ], "unlabeledArg": null, @@ -7474,8 +7474,8 @@ description: Operations executed keyboard.kcl "type": "FunctionCall", "name": "o", "functionSourceRange": [ - 5878, - 6823, + 5881, + 6826, 0 ], "unlabeledArg": null, @@ -7930,8 +7930,8 @@ description: Operations executed keyboard.kcl "type": "FunctionCall", "name": "o", "functionSourceRange": [ - 5878, - 6823, + 5881, + 6826, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/kitt/ast.snap b/rust/kcl-lib/tests/kcl_samples/kitt/ast.snap index 9ddafc75f..2a311a73d 100644 --- a/rust/kcl-lib/tests/kcl_samples/kitt/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/kitt/ast.snap @@ -103,52 +103,55 @@ description: Result of parsing kitt.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "positionY", + "name": { + "commentStart": 0, + "end": 0, + "name": "positionY", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "positionZ", + "name": { + "commentStart": 0, + "end": 0, + "name": "positionZ", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -158,7 +161,7 @@ description: Result of parsing kitt.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -169,8 +172,9 @@ description: Result of parsing kitt.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -908,80 +912,83 @@ description: Result of parsing kitt.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "kitBodyWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitBodyWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "abs_path": false, "commentStart": 0, "end": 0, - "operator": "-", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitBodyElevation", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "kitBodyElevation", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -991,7 +998,7 @@ description: Result of parsing kitt.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1002,8 +1009,9 @@ description: Result of parsing kitt.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2293,80 +2301,83 @@ description: Result of parsing kitt.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "kitFaceWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitFaceWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "abs_path": false, "commentStart": 0, "end": 0, - "operator": "-", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitFaceElevation", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "kitFaceElevation", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2376,7 +2387,7 @@ description: Result of parsing kitt.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2387,8 +2398,9 @@ description: Result of parsing kitt.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -4570,56 +4582,59 @@ description: Result of parsing kitt.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "2", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "kitNoseElevation", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitNoseElevation", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4629,7 +4644,7 @@ description: Result of parsing kitt.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4640,8 +4655,9 @@ description: Result of parsing kitt.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -9688,52 +9704,55 @@ description: Result of parsing kitt.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "offsetSide", + "name": { + "commentStart": 0, + "end": 0, + "name": "offsetSide", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "kitShoeOffsetFront", + "name": { + "commentStart": 0, + "end": 0, + "name": "kitShoeOffsetFront", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -9743,7 +9762,7 @@ description: Result of parsing kitt.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -9754,8 +9773,9 @@ description: Result of parsing kitt.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/lego/ast.snap b/rust/kcl-lib/tests/kcl_samples/lego/ast.snap index 734bb14be..7a62ca09f 100644 --- a/rust/kcl-lib/tests/kcl_samples/lego/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/lego/ast.snap @@ -1000,108 +1000,111 @@ description: Result of parsing lego.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "totalWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "totalWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, "commentStart": 0, "end": 0, - "name": { + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "totalLength", + "name": { + "commentStart": 0, + "end": 0, + "name": "totalLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1111,7 +1114,7 @@ description: Result of parsing lego.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1122,8 +1125,9 @@ description: Result of parsing lego.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1545,23 +1549,66 @@ description: Result of parsing lego.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "totalWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "totalWidth", + "name": "t", "start": 0, "type": "Identifier" }, @@ -1570,66 +1617,66 @@ description: Result of parsing lego.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "t", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { "commentStart": 0, "end": 0, - "left": { + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "argument": { "commentStart": 0, "end": 0, "left": { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "totalLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "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": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "totalLength", + "name": "t", "start": 0, "type": "Identifier" }, @@ -1638,63 +1685,23 @@ description: Result of parsing lego.kcl "type": "Name", "type": "Name" }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, + "commentStart": 0, + "end": 0, "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "t", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1704,7 +1711,7 @@ description: Result of parsing lego.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1715,8 +1722,9 @@ description: Result of parsing lego.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 e902a3c30..a8d8de6c7 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 @@ -51,12 +51,12 @@ flowchart LR 94[Solid2d] end subgraph path101 [Path] - 101["Path
[1785, 1841, 0]"] - 102["Segment
[1849, 1873, 0]"] - 103["Segment
[1881, 1981, 0]"] - 104["Segment
[1989, 2013, 0]"] - 105["Segment
[2021, 2199, 0]"] - 106["Segment
[2207, 2214, 0]"] + 101["Path
[1785, 1844, 0]"] + 102["Segment
[1852, 1876, 0]"] + 103["Segment
[1884, 1984, 0]"] + 104["Segment
[1992, 2016, 0]"] + 105["Segment
[2024, 2202, 0]"] + 106["Segment
[2210, 2217, 0]"] 107[Solid2d] end 1["Plane
[547, 574, 0]"] @@ -129,7 +129,7 @@ flowchart LR 98["Cap End"] 99["SweepEdge Opposite"] 100["SweepEdge Adjacent"] - 108["Sweep Extrusion
[2222, 2245, 0]"] + 108["Sweep Extrusion
[2225, 2248, 0]"] 109[Wall] 110[Wall] 111[Wall] 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 8da5a8168..b488d5676 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap @@ -2717,85 +2717,79 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "offsetX", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "gestellR", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "altitude", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "armPlane", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "offsetX", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "gestellR", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "altitude", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2805,7 +2799,7 @@ description: Result of parsing makeup-mirror.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2816,8 +2810,24 @@ description: Result of parsing makeup-mirror.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "armPlane", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ 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 93e439b9a..bbc587136 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ops.snap @@ -805,7 +805,7 @@ description: Operations executed makeup-mirror.kcl "name": "mirrorFn", "functionSourceRange": [ 1510, - 2264, + 2267, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/mounting-plate/ast.snap b/rust/kcl-lib/tests/kcl_samples/mounting-plate/ast.snap index ff824d874..b8533145e 100644 --- a/rust/kcl-lib/tests/kcl_samples/mounting-plate/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/mounting-plate/ast.snap @@ -245,164 +245,167 @@ description: Result of parsing mounting-plate.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "pos", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, + "computed": false, "end": 0, - "name": { + "object": { "commentStart": 0, "end": 0, - "name": "w", + "name": "pos", "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, - "operator": "/", + "operator": "-", "right": { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "w", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "pos", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, "commentStart": 0, + "computed": false, "end": 0, - "name": { + "object": { "commentStart": 0, "end": 0, - "name": "l", + "name": "pos", "start": 0, + "type": "Identifier", "type": "Identifier" }, - "path": [], + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Name", - "type": "Name" + "type": "MemberExpression", + "type": "MemberExpression" }, - "operator": "/", + "operator": "-", "right": { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "l", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -412,7 +415,7 @@ description: Result of parsing mounting-plate.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -423,8 +426,9 @@ description: Result of parsing mounting-plate.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/ops.snap b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/ops.snap index a366660ae..a972d03c0 100644 --- a/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/multi-axis-robot/ops.snap @@ -934,8 +934,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -970,8 +970,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1105,8 +1105,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1141,8 +1141,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1177,8 +1177,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1213,8 +1213,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1327,8 +1327,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1363,8 +1363,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1799,8 +1799,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -1835,8 +1835,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2025,8 +2025,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2061,8 +2061,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2298,8 +2298,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2334,8 +2334,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2370,8 +2370,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2406,8 +2406,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2520,8 +2520,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2556,8 +2556,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2776,8 +2776,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2812,8 +2812,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2848,8 +2848,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2884,8 +2884,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -2975,8 +2975,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3011,8 +3011,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3146,8 +3146,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3182,8 +3182,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3218,8 +3218,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3254,8 +3254,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3392,8 +3392,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3428,8 +3428,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3464,8 +3464,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3500,8 +3500,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3591,8 +3591,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3627,8 +3627,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3663,8 +3663,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3699,8 +3699,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3845,8 +3845,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3881,8 +3881,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3917,8 +3917,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -3953,8 +3953,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4044,8 +4044,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4080,8 +4080,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4116,8 +4116,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -4152,8 +4152,8 @@ description: Operations executed multi-axis-robot.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/parametric-bearing-pillow-block/ast.snap b/rust/kcl-lib/tests/kcl_samples/parametric-bearing-pillow-block/ast.snap index cd454c063..253c8dba7 100644 --- a/rust/kcl-lib/tests/kcl_samples/parametric-bearing-pillow-block/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/parametric-bearing-pillow-block/ast.snap @@ -329,108 +329,111 @@ description: Result of parsing parametric-bearing-pillow-block.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "width", + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, "commentStart": 0, "end": 0, - "name": { + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "length", + "name": { + "commentStart": 0, + "end": 0, + "name": "length", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -440,7 +443,7 @@ description: Result of parsing parametric-bearing-pillow-block.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -451,8 +454,9 @@ description: Result of parsing parametric-bearing-pillow-block.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 c9c51095a..6da1732d0 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 @@ -9,8 +9,8 @@ description: Operations executed pipe-flange-assembly.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -45,8 +45,8 @@ description: Operations executed pipe-flange-assembly.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kcl_samples/poopy-shoe/ast.snap b/rust/kcl-lib/tests/kcl_samples/poopy-shoe/ast.snap index 363226574..7a0c3f4e1 100644 --- a/rust/kcl-lib/tests/kcl_samples/poopy-shoe/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/poopy-shoe/ast.snap @@ -304,68 +304,71 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallsWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallsWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -375,7 +378,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -386,8 +389,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1614,68 +1618,71 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallsWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallsWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1685,7 +1692,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1696,8 +1703,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -3165,44 +3173,47 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3212,7 +3223,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3223,8 +3234,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -3559,44 +3571,47 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3606,7 +3621,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3617,8 +3632,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5107,44 +5123,47 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5154,7 +5173,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5165,8 +5184,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -5840,100 +5860,103 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } - }, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "operator": "-", + "raw": "0", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } }, - "operator": "*", - "right": { + { "commentStart": 0, "end": 0, "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "argument": { "commentStart": 0, "end": 0, - "name": "backLength", + "raw": "1", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "operator": "-", + "operator": "*", "right": { - "abs_path": false, "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "height", + "name": { + "commentStart": 0, + "end": 0, + "name": "backLength", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "height", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -5943,7 +5966,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -5954,8 +5977,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -6295,44 +6319,47 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -6342,7 +6369,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -6353,8 +6380,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -7109,52 +7137,55 @@ description: Result of parsing poopy-shoe.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallThickness", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallThickness", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallThickness", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -7164,7 +7195,7 @@ description: Result of parsing poopy-shoe.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -7175,8 +7206,9 @@ description: Result of parsing poopy-shoe.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 57445cce9..f96dfd786 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 @@ -571,72 +571,75 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "depth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "+", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "templateGap", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "depth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "templateGap", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -646,7 +649,7 @@ description: Result of parsing router-template-cross-bar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -657,8 +660,9 @@ description: Result of parsing router-template-cross-bar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2783,48 +2787,51 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "distanceToInsideEdge", + "name": { + "commentStart": 0, + "end": 0, + "name": "distanceToInsideEdge", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2834,7 +2841,7 @@ description: Result of parsing router-template-cross-bar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2845,8 +2852,9 @@ description: Result of parsing router-template-cross-bar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -3563,56 +3571,59 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "distanceToInsideEdge", + "name": { + "commentStart": 0, + "end": 0, + "name": "distanceToInsideEdge", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3622,7 +3633,7 @@ description: Result of parsing router-template-cross-bar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3633,8 +3644,9 @@ description: Result of parsing router-template-cross-bar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -4351,56 +4363,59 @@ description: Result of parsing router-template-cross-bar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "distanceToInsideEdge", + "name": { + "commentStart": 0, + "end": 0, + "name": "distanceToInsideEdge", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -4410,7 +4425,7 @@ description: Result of parsing router-template-cross-bar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -4421,8 +4436,9 @@ description: Result of parsing router-template-cross-bar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ 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 8ad781395..e6348a095 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 @@ -608,72 +608,75 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "depth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "templateGap", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" } - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "depth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "templateGap", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -683,7 +686,7 @@ description: Result of parsing router-template-slate.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -694,8 +697,9 @@ description: Result of parsing router-template-slate.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2035,91 +2039,26 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "slateWidthHalf", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "templateGap", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "*", - "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "templateDiameter", + "name": "slateWidthHalf", "start": 0, "type": "Identifier" }, @@ -2128,39 +2067,107 @@ description: Result of parsing router-template-slate.kcl "type": "Name", "type": "Name" }, - "operator": "/", + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "templateGap", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "*", + "right": { + "commentStart": 0, + "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": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "templateDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2170,7 +2177,7 @@ description: Result of parsing router-template-slate.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2181,8 +2188,9 @@ description: Result of parsing router-template-slate.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2881,39 +2889,92 @@ description: Result of parsing router-template-slate.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "slateWidthHalf", + "name": { + "commentStart": 0, + "end": 0, + "name": "slateWidthHalf", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "left": { + { "commentStart": 0, "end": 0, "left": { - "argument": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "templateGap", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "*", + "right": { + "commentStart": 0, + "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": 0, + "end": 0, + "left": { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "templateGap", + "name": "templateDiameter", "start": 0, "type": "Identifier" }, @@ -2922,83 +2983,33 @@ description: Result of parsing router-template-slate.kcl "type": "Name", "type": "Name" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - "operator": "*", - "right": { - "commentStart": 0, - "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": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "/", + "right": { "commentStart": 0, "end": 0, - "name": "templateDiameter", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "BinaryExpression", + "type": "BinaryExpression" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -3008,7 +3019,7 @@ description: Result of parsing router-template-slate.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -3019,8 +3030,9 @@ description: Result of parsing router-template-slate.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/ast.snap b/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/ast.snap index f10e62c64..cf5b35d7e 100644 --- a/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/sheet-metal-bracket/ast.snap @@ -843,100 +843,103 @@ description: Result of parsing sheet-metal-bracket.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, "left": { - "argument": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "commentStart": 0, + "end": 0, + "left": { + "argument": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "mountingBoltPatternX", + "name": { + "commentStart": 0, + "end": 0, + "name": "mountingBoltPatternX", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, + "operator": "-", "start": 0, - "type": "Name", - "type": "Name" + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "commentStart": 0, - "end": 0, - "operator": "-", "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", + "operator": "-", "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "raw": "2", + "name": { + "commentStart": 0, + "end": 0, + "name": "overhang", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, "type": "BinaryExpression", "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "overhang", - "start": 0, - "type": "Identifier" - }, - "path": [], + "raw": "0", "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -946,7 +949,7 @@ description: Result of parsing sheet-metal-bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -957,8 +960,9 @@ description: Result of parsing sheet-metal-bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ast.snap b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ast.snap index 2e732a4dc..f581489a5 100644 --- a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ast.snap @@ -811,92 +811,95 @@ description: Result of parsing socket-head-cap-screw.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "boltHexDrive", + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexDrive", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "/", + "right": { "commentStart": 0, "end": 0, - "name": "boltHexFlatLength", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexFlatLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -906,7 +909,7 @@ description: Result of parsing socket-head-cap-screw.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -917,8 +920,9 @@ description: Result of parsing socket-head-cap-screw.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ops.snap b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ops.snap index 9bccc11a3..9b062e5f1 100644 --- a/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/socket-head-cap-screw/ops.snap @@ -9,8 +9,8 @@ description: Operations executed socket-head-cap-screw.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, 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 abca05434..0306c86fc 100644 --- a/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap +++ b/rust/kcl-lib/tests/kcl_samples/walkie-talkie/ops.snap @@ -144,8 +144,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -180,8 +180,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -216,8 +216,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -252,8 +252,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -587,8 +587,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -623,8 +623,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -659,8 +659,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -695,8 +695,8 @@ description: Operations executed walkie-talkie.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/kittycad_svg/ast.snap b/rust/kcl-lib/tests/kittycad_svg/ast.snap index e11721e06..01d0ca1b5 100644 --- a/rust/kcl-lib/tests/kittycad_svg/ast.snap +++ b/rust/kcl-lib/tests/kittycad_svg/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing kittycad_svg.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing kittycad_svg.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing kittycad_svg.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/kittycad_svg/input.kcl b/rust/kcl-lib/tests/kittycad_svg/input.kcl index d502a4763..e20a2356d 100644 --- a/rust/kcl-lib/tests/kittycad_svg/input.kcl +++ b/rust/kcl-lib/tests/kittycad_svg/input.kcl @@ -1,5 +1,5 @@ svg = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [2.52, -26.04]) // MoveAbsolute |> line(endAbsolute = [2.52, -25.2]) // VerticalLineAbsolute |> line(endAbsolute = [0.84, -25.2]) // HorizontalLineAbsolute diff --git a/rust/kcl-lib/tests/kittycad_svg/unparsed.snap b/rust/kcl-lib/tests/kittycad_svg/unparsed.snap index 3c95b0300..3294d833d 100644 --- a/rust/kcl-lib/tests/kittycad_svg/unparsed.snap +++ b/rust/kcl-lib/tests/kittycad_svg/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing kittycad_svg.kcl --- svg = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [2.52, -26.04]) // MoveAbsolute |> line(endAbsolute = [2.52, -25.2]) // VerticalLineAbsolute |> line(endAbsolute = [0.84, -25.2]) // HorizontalLineAbsolute diff --git a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/ast.snap b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/ast.snap index 03e30709c..8e4d04224 100644 --- a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/ast.snap +++ b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing linear_pattern3d_a_pattern.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing linear_pattern3d_a_pattern.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing linear_pattern3d_a_pattern.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/input.kcl b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/input.kcl index 827fa105c..8b0859470 100644 --- a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/input.kcl +++ b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/input.kcl @@ -1,5 +1,5 @@ exampleSketch = startSketchOn('XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap index 0338a53db..df6109563 100644 --- a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing linear_pattern3d_a_pattern.kcl --- exampleSketch = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 2]) |> line(end = [3, 1]) |> line(end = [0, -4]) diff --git a/rust/kcl-lib/tests/loop_tag/ast.snap b/rust/kcl-lib/tests/loop_tag/ast.snap index e9c16cad8..fb78e1183 100644 --- a/rust/kcl-lib/tests/loop_tag/ast.snap +++ b/rust/kcl-lib/tests/loop_tag/ast.snap @@ -640,47 +640,50 @@ description: Result of parsing loop_tag.kcl { "arguments": [ { - "arguments": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "callee": { - "abs_path": false, + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": { + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "arguments": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "callee": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "calculatePoint", + "name": { + "commentStart": 0, + "end": 0, + "name": "calculatePoint", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name" }, - "path": [], + "commentStart": 0, + "end": 0, "start": 0, - "type": "Name" - }, - "commentStart": 0, - "end": 0, - "start": 0, - "type": "CallExpression", - "type": "CallExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "CallExpression", + "type": "CallExpression" + } } ], "callee": { @@ -690,7 +693,7 @@ description: Result of parsing loop_tag.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -701,8 +704,9 @@ description: Result of parsing loop_tag.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null } ], "commentStart": 0, diff --git a/rust/kcl-lib/tests/loop_tag/input.kcl b/rust/kcl-lib/tests/loop_tag/input.kcl index f8fb78c74..24ba94e15 100644 --- a/rust/kcl-lib/tests/loop_tag/input.kcl +++ b/rust/kcl-lib/tests/loop_tag/input.kcl @@ -21,7 +21,7 @@ fn calculatePoint(index) { // Start sketch on the XY plane initialSketch = startSketchOn(XY) - |> startProfileAt(calculatePoint(0), %) + |> startProfile(at = calculatePoint(0)) // Draw lines to form the base of the cylinder finalSketch = reduce( diff --git a/rust/kcl-lib/tests/loop_tag/unparsed.snap b/rust/kcl-lib/tests/loop_tag/unparsed.snap index f084296b6..27c6f9c75 100644 --- a/rust/kcl-lib/tests/loop_tag/unparsed.snap +++ b/rust/kcl-lib/tests/loop_tag/unparsed.snap @@ -28,7 +28,7 @@ fn calculatePoint(index) { // Start sketch on the XY plane initialSketch = startSketchOn(XY) - |> startProfileAt(calculatePoint(0), %) + |> startProfile(at = calculatePoint(0)) // Draw lines to form the base of the cylinder finalSketch = reduce([1 .. numSides - 1], initialSketch, fn(index, sketch) { diff --git a/rust/kcl-lib/tests/mike_stress_test/ast.snap b/rust/kcl-lib/tests/mike_stress_test/ast.snap index 551086133..f22ea6299 100644 --- a/rust/kcl-lib/tests/mike_stress_test/ast.snap +++ b/rust/kcl-lib/tests/mike_stress_test/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing mike_stress_test.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing mike_stress_test.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing mike_stress_test.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/mike_stress_test/input.kcl b/rust/kcl-lib/tests/mike_stress_test/input.kcl index d1274fda0..4784a5653 100644 --- a/rust/kcl-lib/tests/mike_stress_test/input.kcl +++ b/rust/kcl-lib/tests/mike_stress_test/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XY') - |> startProfileAt([0.0, 0.0], %) + |> startProfile(at = [0.0, 0.0]) |> line(end = [ -0.3670208139314082, 0.21201331909674526 diff --git a/rust/kcl-lib/tests/mike_stress_test/unparsed.snap b/rust/kcl-lib/tests/mike_stress_test/unparsed.snap index 88ce32802..efe2749bf 100644 --- a/rust/kcl-lib/tests/mike_stress_test/unparsed.snap +++ b/rust/kcl-lib/tests/mike_stress_test/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing mike_stress_test.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([0.0, 0.0], %) + |> startProfile(at = [0.0, 0.0]) |> line(end = [ -0.3670208139314082, 0.21201331909674526 diff --git a/rust/kcl-lib/tests/multi_transform/ast.snap b/rust/kcl-lib/tests/multi_transform/ast.snap index 44e217e00..2f5183e48 100644 --- a/rust/kcl-lib/tests/multi_transform/ast.snap +++ b/rust/kcl-lib/tests/multi_transform/ast.snap @@ -287,44 +287,47 @@ description: Result of parsing multi_transform.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -334,7 +337,7 @@ description: Result of parsing multi_transform.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -345,8 +348,9 @@ description: Result of parsing multi_transform.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/multi_transform/input.kcl b/rust/kcl-lib/tests/multi_transform/input.kcl index f106b629a..351d57b37 100644 --- a/rust/kcl-lib/tests/multi_transform/input.kcl +++ b/rust/kcl-lib/tests/multi_transform/input.kcl @@ -5,7 +5,7 @@ fn transform(i) { ] } startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> polygon( radius = 10, numSides = 4, diff --git a/rust/kcl-lib/tests/multi_transform/unparsed.snap b/rust/kcl-lib/tests/multi_transform/unparsed.snap index 33fae0b51..acc908239 100644 --- a/rust/kcl-lib/tests/multi_transform/unparsed.snap +++ b/rust/kcl-lib/tests/multi_transform/unparsed.snap @@ -9,7 +9,7 @@ fn transform(i) { ] } startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> polygon( radius = 10, numSides = 4, diff --git a/rust/kcl-lib/tests/neg_xz_plane/ast.snap b/rust/kcl-lib/tests/neg_xz_plane/ast.snap index a5e958a03..ab49de26b 100644 --- a/rust/kcl-lib/tests/neg_xz_plane/ast.snap +++ b/rust/kcl-lib/tests/neg_xz_plane/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing neg_xz_plane.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing neg_xz_plane.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing neg_xz_plane.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/neg_xz_plane/input.kcl b/rust/kcl-lib/tests/neg_xz_plane/input.kcl index be0bf418a..1fed2ec0e 100644 --- a/rust/kcl-lib/tests/neg_xz_plane/input.kcl +++ b/rust/kcl-lib/tests/neg_xz_plane/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('-XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close(%) diff --git a/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap b/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap index 32c698dba..6982d223b 100644 --- a/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap +++ b/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing neg_xz_plane.kcl --- part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close(%) diff --git a/rust/kcl-lib/tests/out_of_band_sketches/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/out_of_band_sketches/artifact_graph_flowchart.snap.md index 404852433..6c3ba724c 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/out_of_band_sketches/artifact_graph_flowchart.snap.md @@ -1,24 +1,24 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[45, 87, 0]"] - 3["Segment
[164, 187, 0]"] - 4["Segment
[208, 236, 0]"] - 9["Segment
[543, 567, 0]"] - 10["Segment
[588, 595, 0]"] + 2["Path
[45, 90, 0]"] + 3["Segment
[167, 190, 0]"] + 4["Segment
[211, 239, 0]"] + 9["Segment
[549, 573, 0]"] + 10["Segment
[594, 601, 0]"] 11[Solid2d] end subgraph path6 [Path] - 6["Path
[298, 339, 0]"] - 7["Segment
[416, 439, 0]"] - 8["Segment
[460, 489, 0]"] - 12["Segment
[643, 671, 0]"] - 13["Segment
[692, 699, 0]"] + 6["Path
[301, 345, 0]"] + 7["Segment
[422, 445, 0]"] + 8["Segment
[466, 495, 0]"] + 12["Segment
[649, 677, 0]"] + 13["Segment
[698, 705, 0]"] 14[Solid2d] end 1["Plane
[12, 31, 0]"] - 5["Plane
[265, 284, 0]"] - 15["Sweep Extrusion
[710, 775, 0]"] + 5["Plane
[268, 287, 0]"] + 15["Sweep Extrusion
[716, 781, 0]"] 16[Wall] 17[Wall] 18[Wall] @@ -33,7 +33,7 @@ flowchart LR 27["SweepEdge Adjacent"] 28["SweepEdge Opposite"] 29["SweepEdge Adjacent"] - 30["Sweep Extrusion
[710, 775, 0]"] + 30["Sweep Extrusion
[716, 781, 0]"] 31[Wall] 32[Wall] 33[Wall] diff --git a/rust/kcl-lib/tests/out_of_band_sketches/ast.snap b/rust/kcl-lib/tests/out_of_band_sketches/ast.snap index 9a12d38b1..f6f7a48b8 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/ast.snap +++ b/rust/kcl-lib/tests/out_of_band_sketches/ast.snap @@ -76,53 +76,47 @@ description: Result of parsing out_of_band_sketches.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "27.67", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 27.67, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "239.34", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 239.34, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch001", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "27.67", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 27.67, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "239.34", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 239.34, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -132,7 +126,7 @@ description: Result of parsing out_of_band_sketches.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -143,8 +137,24 @@ description: Result of parsing out_of_band_sketches.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch001", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ @@ -421,61 +431,55 @@ description: Result of parsing out_of_band_sketches.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "67.04", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 67.04, - "suffix": "None" - } - }, - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "raw": "63.5", + "raw": "67.04", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 63.5, + "value": 67.04, "suffix": "None" } }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "63.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 63.5, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], "end": 0, - "name": "sketch002", "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -485,7 +489,7 @@ description: Result of parsing out_of_band_sketches.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -496,8 +500,24 @@ description: Result of parsing out_of_band_sketches.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch002", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ diff --git a/rust/kcl-lib/tests/out_of_band_sketches/input.kcl b/rust/kcl-lib/tests/out_of_band_sketches/input.kcl index d2cf728f4..bd345ad68 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/input.kcl +++ b/rust/kcl-lib/tests/out_of_band_sketches/input.kcl @@ -1,11 +1,11 @@ sketch001 = startSketchOn('XZ') -profile001 = startProfileAt([27.67, 239.34], sketch001) +profile001 = startProfile(sketch001, at = [27.67, 239.34]) // enter sketch mode, start path, move path pen, disable sketch mode |> line(end = [414.61, 0]) // extend path |> line(end = [33.98, -389.36]) // extend path sketch002 = startSketchOn('XY') -profile002 = startProfileAt([67.04, -63.5], sketch002) +profile002 = startProfile(sketch002, at = [67.04, -63.5]) // enter sketch mode, start path, move path pen, disable sketch mode |> line(end = [282.37, 0]) // extend path |> line(end = [-12.77, -178.07]) // extend path diff --git a/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap b/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap index d791c0954..685b2fe0b 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap +++ b/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap @@ -3,13 +3,13 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing out_of_band_sketches.kcl --- sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([27.67, 239.34], sketch001) +profile001 = startProfile(sketch001, at = [27.67, 239.34]) // enter sketch mode, start path, move path pen, disable sketch mode |> line(end = [414.61, 0]) // extend path |> line(end = [33.98, -389.36]) // extend path sketch002 = startSketchOn(XY) -profile002 = startProfileAt([67.04, -63.5], sketch002) +profile002 = startProfile(sketch002, at = [67.04, -63.5]) // enter sketch mode, start path, move path pen, disable sketch mode |> line(end = [282.37, 0]) // extend path |> line(end = [-12.77, -178.07]) // extend path diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile0.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile0.png new file mode 100644 index 000000000..a7cbc75e1 Binary files /dev/null and b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile0.png differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile1.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile1.png new file mode 100644 index 000000000..d6e57761f Binary files /dev/null and b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile1.png differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile2.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile2.png new file mode 100644 index 000000000..6362e805d Binary files /dev/null and b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile2.png differ diff --git a/rust/kcl-lib/tests/parametric/ast.snap b/rust/kcl-lib/tests/parametric/ast.snap index 2cda057c8..85c52e6f4 100644 --- a/rust/kcl-lib/tests/parametric/ast.snap +++ b/rust/kcl-lib/tests/parametric/ast.snap @@ -463,44 +463,47 @@ description: Result of parsing parametric.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -510,7 +513,7 @@ description: Result of parsing parametric.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -521,8 +524,9 @@ description: Result of parsing parametric.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/parametric/input.kcl b/rust/kcl-lib/tests/parametric/input.kcl index fffa557ae..9f8f141af 100644 --- a/rust/kcl-lib/tests/parametric/input.kcl +++ b/rust/kcl-lib/tests/parametric/input.kcl @@ -8,7 +8,7 @@ leg1 = 5 // inches leg2 = 8 // inches thickness = sqrt(distance * p * FOS * 6 / sigmaAllow / width) // inches bracket = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) diff --git a/rust/kcl-lib/tests/parametric/unparsed.snap b/rust/kcl-lib/tests/parametric/unparsed.snap index e31e84fe4..4aa27f63f 100644 --- a/rust/kcl-lib/tests/parametric/unparsed.snap +++ b/rust/kcl-lib/tests/parametric/unparsed.snap @@ -12,7 +12,7 @@ leg1 = 5 // inches leg2 = 8 // inches thickness = sqrt(distance * p * FOS * 6 / sigmaAllow / width) // inches bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) |> line(end = [0, -thickness]) diff --git a/rust/kcl-lib/tests/parametric_with_tan_arc/ast.snap b/rust/kcl-lib/tests/parametric_with_tan_arc/ast.snap index 8cf62c5cd..44b091190 100644 --- a/rust/kcl-lib/tests/parametric_with_tan_arc/ast.snap +++ b/rust/kcl-lib/tests/parametric_with_tan_arc/ast.snap @@ -527,44 +527,47 @@ description: Result of parsing parametric_with_tan_arc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -574,7 +577,7 @@ description: Result of parsing parametric_with_tan_arc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -585,8 +588,9 @@ description: Result of parsing parametric_with_tan_arc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/parametric_with_tan_arc/input.kcl b/rust/kcl-lib/tests/parametric_with_tan_arc/input.kcl index 73c238f1a..76226836c 100644 --- a/rust/kcl-lib/tests/parametric_with_tan_arc/input.kcl +++ b/rust/kcl-lib/tests/parametric_with_tan_arc/input.kcl @@ -9,7 +9,7 @@ shelfMountL = 9 wallMountL = 8 bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL]) |> tangentialArc(radius = filletR, angle = 90) |> line(end = [-shelfMountL, 0]) diff --git a/rust/kcl-lib/tests/parametric_with_tan_arc/unparsed.snap b/rust/kcl-lib/tests/parametric_with_tan_arc/unparsed.snap index 0377fd103..61aad4046 100644 --- a/rust/kcl-lib/tests/parametric_with_tan_arc/unparsed.snap +++ b/rust/kcl-lib/tests/parametric_with_tan_arc/unparsed.snap @@ -13,7 +13,7 @@ shelfMountL = 9 wallMountL = 8 bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL]) |> tangentialArc(radius = filletR, angle = 90) |> line(end = [-shelfMountL, 0]) diff --git a/rust/kcl-lib/tests/pattern_circular_in_module/thing.kcl b/rust/kcl-lib/tests/pattern_circular_in_module/thing.kcl index 38710c21c..102d9b2e4 100644 --- a/rust/kcl-lib/tests/pattern_circular_in_module/thing.kcl +++ b/rust/kcl-lib/tests/pattern_circular_in_module/thing.kcl @@ -1,6 +1,6 @@ export fn thing() { exampleSketch = startSketchOn(XZ) - |> startProfileAt([.5, 25], %) + |> startProfile(at = [.5, 25]) |> line(end = [0, 5]) |> line(end = [-1, 0]) |> line(end = [0, -5]) diff --git a/rust/kcl-lib/tests/pattern_circular_in_module/unparsed@thing.kcl.snap b/rust/kcl-lib/tests/pattern_circular_in_module/unparsed@thing.kcl.snap index 58b9ca134..07aabbd2c 100644 --- a/rust/kcl-lib/tests/pattern_circular_in_module/unparsed@thing.kcl.snap +++ b/rust/kcl-lib/tests/pattern_circular_in_module/unparsed@thing.kcl.snap @@ -4,7 +4,7 @@ description: Result of unparsing tests/pattern_circular_in_module/thing.kcl --- export fn thing() { exampleSketch = startSketchOn(XZ) - |> startProfileAt([.5, 25], %) + |> startProfile(at = [.5, 25]) |> line(end = [0, 5]) |> line(end = [-1, 0]) |> line(end = [0, -5]) diff --git a/rust/kcl-lib/tests/pattern_into_union/ast.snap b/rust/kcl-lib/tests/pattern_into_union/ast.snap index 88c229340..0c6839faf 100644 --- a/rust/kcl-lib/tests/pattern_into_union/ast.snap +++ b/rust/kcl-lib/tests/pattern_into_union/ast.snap @@ -670,44 +670,47 @@ description: Result of parsing pattern_into_union.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -717,7 +720,7 @@ description: Result of parsing pattern_into_union.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -728,8 +731,9 @@ description: Result of parsing pattern_into_union.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1331,52 +1335,55 @@ description: Result of parsing pattern_into_union.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "endWidth", + "name": { + "commentStart": 0, + "end": 0, + "name": "endWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "baseHeight", + "name": { + "commentStart": 0, + "end": 0, + "name": "baseHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1386,7 +1393,7 @@ description: Result of parsing pattern_into_union.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1397,8 +1404,9 @@ description: Result of parsing pattern_into_union.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -2122,19 +2130,65 @@ description: Result of parsing pattern_into_union.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "-", + "right": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "endWidth", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + { "abs_path": false, "commentStart": 0, "end": 0, "name": { "commentStart": 0, "end": 0, - "name": "width", + "name": "baseHeight", "start": 0, "type": "Identifier" }, @@ -2142,56 +2196,13 @@ description: Result of parsing pattern_into_union.kcl "start": 0, "type": "Name", "type": "Name" - }, - "operator": "-", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "endWidth", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { - "commentStart": 0, - "end": 0, - "name": "baseHeight", - "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -2201,7 +2212,7 @@ description: Result of parsing pattern_into_union.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -2212,8 +2223,9 @@ description: Result of parsing pattern_into_union.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/pattern_into_union/input.kcl b/rust/kcl-lib/tests/pattern_into_union/input.kcl index 7d0ecab72..34518c025 100644 --- a/rust/kcl-lib/tests/pattern_into_union/input.kcl +++ b/rust/kcl-lib/tests/pattern_into_union/input.kcl @@ -12,7 +12,7 @@ depth = nPlates * (buildPlateThickness + thicknessTolerance) + (nPlates + 1) * e baseHeight = 0.25 base = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(endAbsolute = width, tag = $seg01) |> yLine(endAbsolute = baseHeight + endTabHeight) |> xLine(length = -endWidth) @@ -24,7 +24,7 @@ base = startSketchOn(XZ) |> extrude(length = -depth) endTabs = startSketchOn(XZ) - |> startProfileAt([endWidth, baseHeight], %) + |> startProfile(at = [endWidth, baseHeight]) |> xLine(endAbsolute = endWidth + endTabWidth) |> angledLine( angle = 135, @@ -44,7 +44,7 @@ endTabs = startSketchOn(XZ) ) endTabs2 = startSketchOn(XZ) - |> startProfileAt([width - endWidth, baseHeight], %) + |> startProfile(at = [width - endWidth, baseHeight]) |> xLine(endAbsolute = width - endTabWidth) |> angledLine( angle = 45, diff --git a/rust/kcl-lib/tests/pattern_into_union/unparsed.snap b/rust/kcl-lib/tests/pattern_into_union/unparsed.snap index 3efba27d5..6befc3dd2 100644 --- a/rust/kcl-lib/tests/pattern_into_union/unparsed.snap +++ b/rust/kcl-lib/tests/pattern_into_union/unparsed.snap @@ -16,7 +16,7 @@ depth = nPlates * (buildPlateThickness + thicknessTolerance) + (nPlates + 1) * e baseHeight = 0.25 base = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(endAbsolute = width, tag = $seg01) |> yLine(endAbsolute = baseHeight + endTabHeight) |> xLine(length = -endWidth) @@ -28,7 +28,7 @@ base = startSketchOn(XZ) |> extrude(length = -depth) endTabs = startSketchOn(XZ) - |> startProfileAt([endWidth, baseHeight], %) + |> startProfile(at = [endWidth, baseHeight]) |> xLine(endAbsolute = endWidth + endTabWidth) |> angledLine(angle = 135, endAbsoluteY = baseHeight + endTabHeight, tag = $toFillet) |> xLine(endAbsolute = endWidth) @@ -38,7 +38,7 @@ endTabs = startSketchOn(XZ) |> patternLinear3d(axis = [0, 1, 0], distance = buildPlateThickness + thicknessTolerance + endTabThickness, instances = nPlates + 1) endTabs2 = startSketchOn(XZ) - |> startProfileAt([width - endWidth, baseHeight], %) + |> startProfile(at = [width - endWidth, baseHeight]) |> xLine(endAbsolute = width - endTabWidth) |> angledLine(angle = 45, endAbsoluteY = baseHeight + endTabHeight, tag = $toFillet2) |> xLine(endAbsolute = width - endWidth) diff --git a/rust/kcl-lib/tests/pentagon_fillet_sugar/ast.snap b/rust/kcl-lib/tests/pentagon_fillet_sugar/ast.snap index 311ffb8e5..b865ec7ed 100644 --- a/rust/kcl-lib/tests/pentagon_fillet_sugar/ast.snap +++ b/rust/kcl-lib/tests/pentagon_fillet_sugar/ast.snap @@ -194,44 +194,47 @@ description: Result of parsing pentagon_fillet_sugar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -241,7 +244,7 @@ description: Result of parsing pentagon_fillet_sugar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -252,8 +255,9 @@ description: Result of parsing pentagon_fillet_sugar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -682,96 +686,99 @@ description: Result of parsing pentagon_fillet_sugar.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "x", + "name": { + "commentStart": 0, + "end": 0, + "name": "x", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "+", - "right": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "+", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "radius", + "name": { + "commentStart": 0, + "end": 0, + "name": "radius", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "triangleHeight", + "name": { + "commentStart": 0, + "end": 0, + "name": "triangleHeight", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -781,7 +788,7 @@ description: Result of parsing pentagon_fillet_sugar.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -792,8 +799,9 @@ description: Result of parsing pentagon_fillet_sugar.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/pentagon_fillet_sugar/input.kcl b/rust/kcl-lib/tests/pentagon_fillet_sugar/input.kcl index 4d2f262d5..720347125 100644 --- a/rust/kcl-lib/tests/pentagon_fillet_sugar/input.kcl +++ b/rust/kcl-lib/tests/pentagon_fillet_sugar/input.kcl @@ -4,7 +4,7 @@ radius = 80 triangleLen = 500 p = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = triangleLen, tag = $a) |> angledLine(angle = 180, length = triangleLen, tag = $b) |> angledLine(angle = 300, length = triangleLen, tag = $c) @@ -12,7 +12,7 @@ p = startSketchOn(XY) fn circl(x, face) { return startSketchOn(p, face = face) - |> startProfileAt([x + radius, triangleHeight / 2], %) + |> startProfile(at = [x + radius, triangleHeight / 2]) |> arc( angleStart = 0, angleEnd = 360, diff --git a/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap b/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap index 32ef16098..ad50e8395 100644 --- a/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap +++ b/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap @@ -8,7 +8,7 @@ radius = 80 triangleLen = 500 p = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> angledLine(angle = 60, length = triangleLen, tag = $a) |> angledLine(angle = 180, length = triangleLen, tag = $b) |> angledLine(angle = 300, length = triangleLen, tag = $c) @@ -16,7 +16,7 @@ p = startSketchOn(XY) fn circl(x, face) { return startSketchOn(p, face = face) - |> startProfileAt([x + radius, triangleHeight / 2], %) + |> startProfile(at = [x + radius, triangleHeight / 2]) |> arc( angleStart = 0, angleEnd = 360, diff --git a/rust/kcl-lib/tests/pipe_as_arg/ast.snap b/rust/kcl-lib/tests/pipe_as_arg/ast.snap index 3fd097b8d..06d8a6239 100644 --- a/rust/kcl-lib/tests/pipe_as_arg/ast.snap +++ b/rust/kcl-lib/tests/pipe_as_arg/ast.snap @@ -693,27 +693,30 @@ description: Result of parsing pipe_as_arg.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "p0", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "p0", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -723,7 +726,7 @@ description: Result of parsing pipe_as_arg.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -734,8 +737,9 @@ description: Result of parsing pipe_as_arg.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/pipe_as_arg/input.kcl b/rust/kcl-lib/tests/pipe_as_arg/input.kcl index 835227df8..5cbd93152 100644 --- a/rust/kcl-lib/tests/pipe_as_arg/input.kcl +++ b/rust/kcl-lib/tests/pipe_as_arg/input.kcl @@ -8,7 +8,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/pipe_as_arg/unparsed.snap b/rust/kcl-lib/tests/pipe_as_arg/unparsed.snap index a52a44789..750543f10 100644 --- a/rust/kcl-lib/tests/pipe_as_arg/unparsed.snap +++ b/rust/kcl-lib/tests/pipe_as_arg/unparsed.snap @@ -12,7 +12,7 @@ fn cube(length, center) { p3 = [l + x, -l + y] return startSketchOn(XY) - |> startProfileAt(p0, %) + |> startProfile(at = p0) |> line(endAbsolute = p1) |> line(endAbsolute = p2) |> line(endAbsolute = p3) diff --git a/rust/kcl-lib/tests/poop_chute/ast.snap b/rust/kcl-lib/tests/poop_chute/ast.snap index e476696ad..1f256dbad 100644 --- a/rust/kcl-lib/tests/poop_chute/ast.snap +++ b/rust/kcl-lib/tests/poop_chute/ast.snap @@ -400,68 +400,71 @@ description: Result of parsing poop_chute.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "back_walls_width", + "name": { + "commentStart": 0, + "end": 0, + "name": "back_walls_width", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -471,7 +474,7 @@ description: Result of parsing poop_chute.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -482,8 +485,9 @@ description: Result of parsing poop_chute.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1713,68 +1717,71 @@ description: Result of parsing poop_chute.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "back_walls_width", + "name": { + "commentStart": 0, + "end": 0, + "name": "back_walls_width", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "raw": "0", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 2.0, + "value": 0.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1784,7 +1791,7 @@ description: Result of parsing poop_chute.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1795,8 +1802,9 @@ description: Result of parsing poop_chute.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/poop_chute/input.kcl b/rust/kcl-lib/tests/poop_chute/input.kcl index 5a5e13b1d..edd6665cb 100644 --- a/rust/kcl-lib/tests/poop_chute/input.kcl +++ b/rust/kcl-lib/tests/poop_chute/input.kcl @@ -10,7 +10,7 @@ Fx = 0.5 Fy = 0.5 sketch001 = startSketchOn(-YZ) - |> startProfileAt([back_walls_width / 2, 0], %) + |> startProfile(at = [back_walls_width / 2, 0]) |> xLine(length = wall_thickness / 2) |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg01) |> yLine(endAbsolute = height) @@ -34,7 +34,7 @@ part001 = revolve( ) sketch002 = startSketchOn(-YZ) - |> startProfileAt([back_walls_width / 2, 0], %) + |> startProfile(at = [back_walls_width / 2, 0]) |> xLine(length = wall_thickness / 2) |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg02) |> yLine(endAbsolute = height) diff --git a/rust/kcl-lib/tests/poop_chute/unparsed.snap b/rust/kcl-lib/tests/poop_chute/unparsed.snap index e0b2d1c8a..495b9d04d 100644 --- a/rust/kcl-lib/tests/poop_chute/unparsed.snap +++ b/rust/kcl-lib/tests/poop_chute/unparsed.snap @@ -14,7 +14,7 @@ Fx = 0.5 Fy = 0.5 sketch001 = startSketchOn(-YZ) - |> startProfileAt([back_walls_width / 2, 0], %) + |> startProfile(at = [back_walls_width / 2, 0]) |> xLine(length = wall_thickness / 2) |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg01) |> yLine(endAbsolute = height) @@ -38,7 +38,7 @@ part001 = revolve( ) sketch002 = startSketchOn(-YZ) - |> startProfileAt([back_walls_width / 2, 0], %) + |> startProfile(at = [back_walls_width / 2, 0]) |> xLine(length = wall_thickness / 2) |> angledLine(angle = 45, endAbsoluteX = back_walls_width, tag = $seg02) |> yLine(endAbsolute = height) diff --git a/rust/kcl-lib/tests/revolve_about_edge/ast.snap b/rust/kcl-lib/tests/revolve_about_edge/ast.snap index ccec32795..83469e44e 100644 --- a/rust/kcl-lib/tests/revolve_about_edge/ast.snap +++ b/rust/kcl-lib/tests/revolve_about_edge/ast.snap @@ -55,10 +55,38 @@ description: Result of parsing revolve_about_edge.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "25", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 25.0, + "suffix": "None" + } + }, + "commentStart": 0, + "end": 0, + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { "commentStart": 0, "end": 0, "raw": "25", @@ -69,38 +97,13 @@ description: Result of parsing revolve_about_edge.kcl "value": 25.0, "suffix": "None" } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "25", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 25.0, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -110,7 +113,7 @@ description: Result of parsing revolve_about_edge.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -121,8 +124,9 @@ description: Result of parsing revolve_about_edge.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/revolve_about_edge/input.kcl b/rust/kcl-lib/tests/revolve_about_edge/input.kcl index 0829bc872..061b0e1f2 100644 --- a/rust/kcl-lib/tests/revolve_about_edge/input.kcl +++ b/rust/kcl-lib/tests/revolve_about_edge/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn('XY') - |> startProfileAt([-25, 25], %) + |> startProfile(at = [-25, 25]) |> yLine(length = -50, tag = $rectangleSegmentB001) sketch002 = startSketchOn('XY') |> circle(center = [-50, 0], radius = 10) diff --git a/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap b/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap index f369a36b6..ef51224dc 100644 --- a/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap +++ b/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing revolve_about_edge.kcl --- sketch001 = startSketchOn(XY) - |> startProfileAt([-25, 25], %) + |> startProfile(at = [-25, 25]) |> yLine(length = -50, tag = $rectangleSegmentB001) sketch002 = startSketchOn(XY) |> circle(center = [-50, 0], radius = 10) diff --git a/rust/kcl-lib/tests/riddle_small/ast.snap b/rust/kcl-lib/tests/riddle_small/ast.snap index fb93376d9..df7eb030f 100644 --- a/rust/kcl-lib/tests/riddle_small/ast.snap +++ b/rust/kcl-lib/tests/riddle_small/ast.snap @@ -490,52 +490,55 @@ description: Result of parsing riddle_small.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "ox", + "name": { + "commentStart": 0, + "end": 0, + "name": "ox", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "oy", + "name": { + "commentStart": 0, + "end": 0, + "name": "oy", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -545,7 +548,7 @@ description: Result of parsing riddle_small.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -556,8 +559,9 @@ description: Result of parsing riddle_small.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/riddle_small/input.kcl b/rust/kcl-lib/tests/riddle_small/input.kcl index 07267dc1a..0aeb5455a 100644 --- a/rust/kcl-lib/tests/riddle_small/input.kcl +++ b/rust/kcl-lib/tests/riddle_small/input.kcl @@ -9,7 +9,7 @@ ys = 71816 ox = 35 - (t(xs) % 70) oy = 35 - (t(ys) % 70) r = startSketchOn('XZ') - |> startProfileAt([ox, oy], %) + |> startProfile(at = [ox, oy]) |> line(end = [1, 0]) |> line(end = [0, -1]) |> line(end = [-1, 0]) diff --git a/rust/kcl-lib/tests/riddle_small/unparsed.snap b/rust/kcl-lib/tests/riddle_small/unparsed.snap index 1b71ac92c..961ad1c39 100644 --- a/rust/kcl-lib/tests/riddle_small/unparsed.snap +++ b/rust/kcl-lib/tests/riddle_small/unparsed.snap @@ -13,7 +13,7 @@ ys = 71816 ox = 35 - (t(xs) % 70) oy = 35 - (t(ys) % 70) r = startSketchOn(XZ) - |> startProfileAt([ox, oy], %) + |> startProfile(at = [ox, oy]) |> line(end = [1, 0]) |> line(end = [0, -1]) |> line(end = [-1, 0]) diff --git a/rust/kcl-lib/tests/rotate_after_fillet/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/rotate_after_fillet/artifact_graph_flowchart.snap.md index e4b679728..0b50a3946 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/rotate_after_fillet/artifact_graph_flowchart.snap.md @@ -6,18 +6,18 @@ flowchart LR 4[Solid2d] end subgraph path13 [Path] - 13["Path
[660, 747, 0]"] - 14["Segment
[755, 834, 0]"] - 15["Segment
[842, 921, 0]"] - 16["Segment
[929, 1008, 0]"] - 17["Segment
[1016, 1094, 0]"] - 18["Segment
[1102, 1180, 0]"] - 19["Segment
[1188, 1195, 0]"] + 13["Path
[660, 720, 0]"] + 14["Segment
[728, 807, 0]"] + 15["Segment
[815, 894, 0]"] + 16["Segment
[902, 981, 0]"] + 17["Segment
[989, 1067, 0]"] + 18["Segment
[1075, 1153, 0]"] + 19["Segment
[1161, 1168, 0]"] 20[Solid2d] end subgraph path41 [Path] - 41["Path
[1303, 1372, 0]"] - 42["Segment
[1303, 1372, 0]"] + 41["Path
[1276, 1345, 0]"] + 42["Segment
[1276, 1345, 0]"] 43[Solid2d] end 1["Plane
[320, 337, 0]"] @@ -29,7 +29,7 @@ flowchart LR 10["SweepEdge Adjacent"] 11["EdgeCut Fillet
[464, 530, 0]"] 12["EdgeCut Fillet
[464, 530, 0]"] - 21["Sweep Extrusion
[1203, 1243, 0]"] + 21["Sweep Extrusion
[1176, 1216, 0]"] 22[Wall] 23[Wall] 24[Wall] @@ -49,14 +49,14 @@ flowchart LR 38["SweepEdge Adjacent"] 39["SweepEdge Opposite"] 40["SweepEdge Adjacent"] - 44["Sweep Extrusion
[1380, 1408, 0]"] + 44["Sweep Extrusion
[1353, 1381, 0]"] 45[Wall] 46["Cap End"] 47["SweepEdge Opposite"] 48["SweepEdge Adjacent"] - 49["EdgeCut Fillet
[1416, 1475, 0]"] + 49["EdgeCut Fillet
[1389, 1448, 0]"] 50["StartSketchOnFace
[613, 652, 0]"] - 51["StartSketchOnFace
[1258, 1295, 0]"] + 51["StartSketchOnFace
[1231, 1268, 0]"] 1 --- 2 2 --- 3 2 ---- 5 diff --git a/rust/kcl-lib/tests/rotate_after_fillet/ast.snap b/rust/kcl-lib/tests/rotate_after_fillet/ast.snap index 359cb9cd2..9faa7248a 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/ast.snap +++ b/rust/kcl-lib/tests/rotate_after_fillet/ast.snap @@ -854,92 +854,95 @@ description: Result of parsing rotate_after_fillet.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "boltHexDrive", + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexDrive", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "/", + "right": { "commentStart": 0, "end": 0, - "name": "boltHexFlatLength", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexFlatLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -949,7 +952,7 @@ description: Result of parsing rotate_after_fillet.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -960,8 +963,9 @@ description: Result of parsing rotate_after_fillet.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/rotate_after_fillet/input.kcl b/rust/kcl-lib/tests/rotate_after_fillet/input.kcl index a9e3e3a76..6c48fad76 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/input.kcl +++ b/rust/kcl-lib/tests/rotate_after_fillet/input.kcl @@ -15,10 +15,7 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = 'start') - |> startProfileAt([ - boltHexDrive / 2, - boltHexFlatLength / 2 - ], %) + |> startProfile(at = [boltHexDrive / 2, boltHexFlatLength / 2]) |> angledLine( angle = 270, length = boltHexFlatLength, diff --git a/rust/kcl-lib/tests/rotate_after_fillet/ops.snap b/rust/kcl-lib/tests/rotate_after_fillet/ops.snap index 2e45b824f..222eee005 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/ops.snap +++ b/rust/kcl-lib/tests/rotate_after_fillet/ops.snap @@ -9,8 +9,8 @@ description: Operations executed rotate_after_fillet.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -46,7 +46,7 @@ description: Operations executed rotate_after_fillet.kcl "name": "bolt", "functionSourceRange": [ 264, - 1565, + 1538, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap b/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap index ca53ee9ef..0cc493c0d 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap @@ -19,10 +19,10 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = START) - |> startProfileAt([ + |> startProfile(at = [ boltHexDrive / 2, boltHexFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = boltHexFlatLength) |> angledLine(angle = 210, length = boltHexFlatLength) |> angledLine(angle = 150, length = boltHexFlatLength) diff --git a/rust/kcl-lib/tests/scale_after_fillet/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/scale_after_fillet/artifact_graph_flowchart.snap.md index e4b679728..0b50a3946 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/scale_after_fillet/artifact_graph_flowchart.snap.md @@ -6,18 +6,18 @@ flowchart LR 4[Solid2d] end subgraph path13 [Path] - 13["Path
[660, 747, 0]"] - 14["Segment
[755, 834, 0]"] - 15["Segment
[842, 921, 0]"] - 16["Segment
[929, 1008, 0]"] - 17["Segment
[1016, 1094, 0]"] - 18["Segment
[1102, 1180, 0]"] - 19["Segment
[1188, 1195, 0]"] + 13["Path
[660, 720, 0]"] + 14["Segment
[728, 807, 0]"] + 15["Segment
[815, 894, 0]"] + 16["Segment
[902, 981, 0]"] + 17["Segment
[989, 1067, 0]"] + 18["Segment
[1075, 1153, 0]"] + 19["Segment
[1161, 1168, 0]"] 20[Solid2d] end subgraph path41 [Path] - 41["Path
[1303, 1372, 0]"] - 42["Segment
[1303, 1372, 0]"] + 41["Path
[1276, 1345, 0]"] + 42["Segment
[1276, 1345, 0]"] 43[Solid2d] end 1["Plane
[320, 337, 0]"] @@ -29,7 +29,7 @@ flowchart LR 10["SweepEdge Adjacent"] 11["EdgeCut Fillet
[464, 530, 0]"] 12["EdgeCut Fillet
[464, 530, 0]"] - 21["Sweep Extrusion
[1203, 1243, 0]"] + 21["Sweep Extrusion
[1176, 1216, 0]"] 22[Wall] 23[Wall] 24[Wall] @@ -49,14 +49,14 @@ flowchart LR 38["SweepEdge Adjacent"] 39["SweepEdge Opposite"] 40["SweepEdge Adjacent"] - 44["Sweep Extrusion
[1380, 1408, 0]"] + 44["Sweep Extrusion
[1353, 1381, 0]"] 45[Wall] 46["Cap End"] 47["SweepEdge Opposite"] 48["SweepEdge Adjacent"] - 49["EdgeCut Fillet
[1416, 1475, 0]"] + 49["EdgeCut Fillet
[1389, 1448, 0]"] 50["StartSketchOnFace
[613, 652, 0]"] - 51["StartSketchOnFace
[1258, 1295, 0]"] + 51["StartSketchOnFace
[1231, 1268, 0]"] 1 --- 2 2 --- 3 2 ---- 5 diff --git a/rust/kcl-lib/tests/scale_after_fillet/ast.snap b/rust/kcl-lib/tests/scale_after_fillet/ast.snap index aeb7091fa..d2dc3773e 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/ast.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/ast.snap @@ -854,92 +854,95 @@ description: Result of parsing scale_after_fillet.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "boltHexDrive", + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexDrive", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "/", + "right": { "commentStart": 0, "end": 0, - "name": "boltHexFlatLength", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexFlatLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -949,7 +952,7 @@ description: Result of parsing scale_after_fillet.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -960,8 +963,9 @@ description: Result of parsing scale_after_fillet.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/scale_after_fillet/input.kcl b/rust/kcl-lib/tests/scale_after_fillet/input.kcl index ba0ab767a..b8709ba36 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/input.kcl +++ b/rust/kcl-lib/tests/scale_after_fillet/input.kcl @@ -15,10 +15,7 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = 'start') - |> startProfileAt([ - boltHexDrive / 2, - boltHexFlatLength / 2 - ], %) + |> startProfile(at = [boltHexDrive / 2, boltHexFlatLength / 2]) |> angledLine( angle = 270, length = boltHexFlatLength, diff --git a/rust/kcl-lib/tests/scale_after_fillet/ops.snap b/rust/kcl-lib/tests/scale_after_fillet/ops.snap index 10481ad85..6e9a031a7 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/ops.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/ops.snap @@ -9,8 +9,8 @@ description: Operations executed scale_after_fillet.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -46,7 +46,7 @@ description: Operations executed scale_after_fillet.kcl "name": "bolt", "functionSourceRange": [ 264, - 1565, + 1538, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap index e8ec73b38..de745bbc9 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap @@ -19,10 +19,10 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = START) - |> startProfileAt([ + |> startProfile(at = [ boltHexDrive / 2, boltHexFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = boltHexFlatLength) |> angledLine(angle = 210, length = boltHexFlatLength) |> angledLine(angle = 150, length = boltHexFlatLength) diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/ast.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/ast.snap index a9d4c56bd..a0091696e 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/ast.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/ast.snap @@ -62,44 +62,47 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "75.8", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 75.8, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "75.8", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 75.8, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "317.2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 317.2, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "317.2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 317.2, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -109,7 +112,7 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -120,8 +123,9 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1140,52 +1144,55 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "69.1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 69.1, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "69.1", + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "raw": "277.34", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 69.1, + "value": 277.34, "suffix": "None" } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "277.34", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 277.34, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1195,7 +1202,7 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1206,8 +1213,9 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1810,44 +1818,47 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "159.25", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 159.25, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "159.25", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 159.25, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "278.35", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 278.35, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "278.35", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 278.35, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1857,7 +1868,7 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1868,8 +1879,9 @@ description: Result of parsing sketch-on-chamfer-two-times-different-order.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/input.kcl b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/input.kcl index e0f64e0f9..1543dcce7 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/input.kcl +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -11,14 +11,14 @@ extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 50, tags = [seg02], tag = $seg04) sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/unparsed.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/unparsed.snap index c60ce4618..bfc575823 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/unparsed.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times-different-order/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch-on-chamfer-two-times-different-order.kcl --- sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -15,14 +15,14 @@ extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 50, tags = [seg02], tag = $seg04) sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/ast.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/ast.snap index 900918343..0ea4e5a13 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/ast.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "75.8", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 75.8, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "75.8", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 75.8, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "317.2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 317.2, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "317.2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 317.2, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1141,52 +1145,55 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "69.1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 69.1, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "69.1", + "operator": "-", + "start": 0, + "type": "UnaryExpression", + "type": "UnaryExpression" + }, + { + "commentStart": 0, + "end": 0, + "raw": "277.34", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 69.1, + "value": 277.34, "suffix": "None" } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "277.34", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 277.34, - "suffix": "None" } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1196,7 +1203,7 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1207,8 +1214,9 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1819,44 +1827,47 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "159.25", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 159.25, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "159.25", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 159.25, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "278.35", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 278.35, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "278.35", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 278.35, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1866,7 +1877,7 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1877,8 +1888,9 @@ description: Result of parsing sketch-on-chamfer-two-times.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/input.kcl b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/input.kcl index edd8f56b3..5404441bb 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/input.kcl +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn('XZ') - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -11,14 +11,14 @@ extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 50, tags = [getOppositeEdge(seg01)], tag = $seg03) sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close(%) sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/unparsed.snap b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/unparsed.snap index 46e6aca48..2eda4dffd 100644 --- a/rust/kcl-lib/tests/sketch-on-chamfer-two-times/unparsed.snap +++ b/rust/kcl-lib/tests/sketch-on-chamfer-two-times/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch-on-chamfer-two-times.kcl --- sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -15,14 +15,14 @@ extrude001 = extrude(sketch001, length = 100) |> chamfer(length = 50, tags = [getOppositeEdge(seg01)], tag = $seg03) sketch003 = startSketchOn(extrude001, face = seg04) - |> startProfileAt([-69.1, 277.34], %) + |> startProfile(at = [-69.1, 277.34]) |> angledLine(angle = 0, length = 41.48, tag = $rectangleSegmentA003) |> angledLine(angle = segAng(rectangleSegmentA003) - 90, length = 104.8, tag = $rectangleSegmentB002) |> angledLine(angle = segAng(rectangleSegmentA003), length = -segLen(rectangleSegmentA003), tag = $rectangleSegmentC002) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close(%) sketch002 = startSketchOn(extrude001, face = seg03) - |> startProfileAt([159.25, 278.35], %) + |> startProfile(at = [159.25, 278.35]) |> angledLine(angle = 0, length = 40.82, tag = $rectangleSegmentA002) |> angledLine(angle = segAng(rectangleSegmentA002) - 90, length = 132.27, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA002), length = -segLen(rectangleSegmentA002), tag = $rectangleSegmentC001) diff --git a/rust/kcl-lib/tests/sketch_in_object/ast.snap b/rust/kcl-lib/tests/sketch_in_object/ast.snap index e396105e4..c66335e00 100644 --- a/rust/kcl-lib/tests/sketch_in_object/ast.snap +++ b/rust/kcl-lib/tests/sketch_in_object/ast.snap @@ -59,44 +59,47 @@ description: Result of parsing sketch_in_object.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -106,7 +109,7 @@ description: Result of parsing sketch_in_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -117,8 +120,9 @@ description: Result of parsing sketch_in_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -483,44 +487,47 @@ description: Result of parsing sketch_in_object.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -530,7 +537,7 @@ description: Result of parsing sketch_in_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -541,8 +548,9 @@ description: Result of parsing sketch_in_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_in_object/input.kcl b/rust/kcl-lib/tests/sketch_in_object/input.kcl index c3e248db9..f4cb5c078 100644 --- a/rust/kcl-lib/tests/sketch_in_object/input.kcl +++ b/rust/kcl-lib/tests/sketch_in_object/input.kcl @@ -1,6 +1,6 @@ fn test() { return startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -11,7 +11,7 @@ fn test2() { return { thing1 = { thing2 = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) diff --git a/rust/kcl-lib/tests/sketch_in_object/unparsed.snap b/rust/kcl-lib/tests/sketch_in_object/unparsed.snap index 655d1a771..6cd7a31cb 100644 --- a/rust/kcl-lib/tests/sketch_in_object/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_in_object/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing sketch_in_object.kcl --- fn test() { return startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) @@ -15,7 +15,7 @@ fn test2() { return { thing1 = { thing2 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 1]) |> line(end = [1, 0]) |> line(end = [0, -1]) diff --git a/rust/kcl-lib/tests/sketch_on_face/ast.snap b/rust/kcl-lib/tests/sketch_on_face/ast.snap index 9d2561461..32ef7c8f3 100644 --- a/rust/kcl-lib/tests/sketch_on_face/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face/ast.snap @@ -62,44 +62,47 @@ description: Result of parsing sketch_on_face.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "11.19", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 11.19, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "11.19", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 11.19, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "28.35", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 28.35, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "28.35", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 28.35, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -109,7 +112,7 @@ description: Result of parsing sketch_on_face.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -120,8 +123,9 @@ description: Result of parsing sketch_on_face.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -554,44 +558,47 @@ description: Result of parsing sketch_on_face.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -601,7 +608,7 @@ description: Result of parsing sketch_on_face.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -612,8 +619,9 @@ description: Result of parsing sketch_on_face.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face/input.kcl b/rust/kcl-lib/tests/sketch_on_face/input.kcl index a11057668..2208a41b5 100644 --- a/rust/kcl-lib/tests/sketch_on_face/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn(XY) - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) @@ -7,7 +7,7 @@ part001 = startSketchOn(XY) |> extrude(length = 5) part002 = startSketchOn(part001, face = here) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face/unparsed.snap index 59c3c0ee2..a7776845d 100644 --- a/rust/kcl-lib/tests/sketch_on_face/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face.kcl --- part001 = startSketchOn(XY) - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) @@ -11,7 +11,7 @@ part001 = startSketchOn(XY) |> extrude(length = 5) part002 = startSketchOn(part001, face = here) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/ast.snap b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/ast.snap index 34788d3c9..702bf9ca8 100644 --- a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/ast.snap @@ -578,44 +578,47 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -625,7 +628,7 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -636,8 +639,9 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -1555,44 +1559,47 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "4.28", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.28, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "4.28", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.28, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "3.83", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.83, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "3.83", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.83, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -1602,7 +1609,7 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -1613,8 +1620,9 @@ description: Result of parsing sketch_on_face_after_fillets_referencing_face.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/input.kcl b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/input.kcl index 2cd53685b..2dcb9009b 100644 --- a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/input.kcl @@ -23,7 +23,7 @@ filletR = 0.25 // Sketch the bracket and extrude with fillets bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0], tag = $seg01) |> line(end = [0, -thickness]) @@ -35,7 +35,7 @@ bracket = startSketchOn(XY) |> fillet(radius = filletR + thickness, tags = [getNextAdjacentEdge(outerEdge)]) sketch001 = startSketchOn(bracket, face = seg01) - |> startProfileAt([4.28, 3.83], %) + |> startProfile(at = [4.28, 3.83]) |> line(end = [2.17, -0.03]) |> line(end = [-0.07, -1.8]) |> line(end = [-2.07, 0.05]) diff --git a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/unparsed.snap index d10f473a5..09cd53f21 100644 --- a/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_after_fillets_referencing_face/unparsed.snap @@ -27,7 +27,7 @@ filletR = 0.25 // Sketch the bracket and extrude with fillets bracket = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0], tag = $seg01) |> line(end = [0, -thickness]) @@ -39,7 +39,7 @@ bracket = startSketchOn(XY) |> fillet(radius = filletR + thickness, tags = [getNextAdjacentEdge(outerEdge)]) sketch001 = startSketchOn(bracket, face = seg01) - |> startProfileAt([4.28, 3.83], %) + |> startProfile(at = [4.28, 3.83]) |> line(end = [2.17, -0.03]) |> line(end = [-0.07, -1.8]) |> line(end = [-2.07, 0.05]) diff --git a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/ast.snap b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/ast.snap index bd1ef93ae..f6ff38b91 100644 --- a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/ast.snap @@ -70,27 +70,30 @@ description: Result of parsing sketch_on_face_circle_tagged.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "pos", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "pos", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -100,7 +103,7 @@ description: Result of parsing sketch_on_face_circle_tagged.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -111,8 +114,9 @@ description: Result of parsing sketch_on_face_circle_tagged.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/input.kcl b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/input.kcl index 8f77a5568..ad887412b 100644 --- a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/input.kcl @@ -1,6 +1,6 @@ fn cube(pos, scale) { sg = startSketchOn('XY') - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/unparsed.snap index 07abe35a5..a96849a0e 100644 --- a/rust/kcl-lib/tests/sketch_on_face_circle_tagged/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_circle_tagged/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing sketch_on_face_circle_tagged.kcl --- fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/rust/kcl-lib/tests/sketch_on_face_end/ast.snap b/rust/kcl-lib/tests/sketch_on_face_end/ast.snap index b8cef3cbc..7231c8344 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end/ast.snap @@ -70,27 +70,30 @@ description: Result of parsing sketch_on_face_end.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "pos", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "pos", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -100,7 +103,7 @@ description: Result of parsing sketch_on_face_end.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -111,8 +114,9 @@ description: Result of parsing sketch_on_face_end.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -688,44 +692,47 @@ description: Result of parsing sketch_on_face_end.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -735,7 +742,7 @@ description: Result of parsing sketch_on_face_end.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -746,8 +753,9 @@ description: Result of parsing sketch_on_face_end.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face_end/input.kcl b/rust/kcl-lib/tests/sketch_on_face_end/input.kcl index 3b0b6add6..9cfece73a 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face_end/input.kcl @@ -1,6 +1,6 @@ fn cube(pos, scale) { sg = startSketchOn('XY') - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = "END") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap index 181740683..9c2d589b1 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing sketch_on_face_end.kcl --- fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -16,7 +16,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/ast.snap b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/ast.snap index a7ee9184a..cdd64df30 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/ast.snap @@ -70,27 +70,30 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "pos", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "pos", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -100,7 +103,7 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -111,8 +114,9 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -688,44 +692,47 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -735,7 +742,7 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -746,8 +753,9 @@ description: Result of parsing sketch_on_face_end_negative_extrude.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/input.kcl b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/input.kcl index 9d0ca7f69..b22488b90 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/input.kcl @@ -1,6 +1,6 @@ fn cube(pos, scale) { sg = startSketchOn('XY') - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = "END") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/unparsed.snap index e6a4bb093..3b968e94d 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end_negative_extrude/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing sketch_on_face_end_negative_extrude.kcl --- fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -16,7 +16,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) part002 = startSketchOn(part001, face = END) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_start/ast.snap b/rust/kcl-lib/tests/sketch_on_face_start/ast.snap index 38b368fa0..767543dc2 100644 --- a/rust/kcl-lib/tests/sketch_on_face_start/ast.snap +++ b/rust/kcl-lib/tests/sketch_on_face_start/ast.snap @@ -77,27 +77,30 @@ description: Result of parsing sketch_on_face_start.kcl { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "pos", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "arg": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "pos", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } } ], "callee": { @@ -107,7 +110,7 @@ description: Result of parsing sketch_on_face_start.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -118,8 +121,9 @@ description: Result of parsing sketch_on_face_start.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ @@ -709,44 +713,47 @@ description: Result of parsing sketch_on_face_start.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -756,7 +763,7 @@ description: Result of parsing sketch_on_face_start.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -767,8 +774,9 @@ description: Result of parsing sketch_on_face_start.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/sketch_on_face_start/input.kcl b/rust/kcl-lib/tests/sketch_on_face_start/input.kcl index 6023775e9..93df3c8f0 100644 --- a/rust/kcl-lib/tests/sketch_on_face_start/input.kcl +++ b/rust/kcl-lib/tests/sketch_on_face_start/input.kcl @@ -1,6 +1,6 @@ fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -12,7 +12,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) as foo part002 = startSketchOn(foo, face = "start") - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap index 40c68d3b9..6dd658d1b 100644 --- a/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing sketch_on_face_start.kcl --- fn cube(pos, scale) { sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -16,7 +16,7 @@ part001 = cube([0, 0], 20) |> extrude(length = 20) as foo part002 = startSketchOn(foo, face = START) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/rust/kcl-lib/tests/ssi_pattern/ast.snap b/rust/kcl-lib/tests/ssi_pattern/ast.snap index cc8789a3f..17fb87a3d 100644 --- a/rust/kcl-lib/tests/ssi_pattern/ast.snap +++ b/rust/kcl-lib/tests/ssi_pattern/ast.snap @@ -55,60 +55,63 @@ description: Result of parsing ssi_pattern.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "argument": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "4.35", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.35, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "4.35", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.35, - "suffix": "None" - } + "type": "UnaryExpression", + "type": "UnaryExpression" }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - }, - { - "argument": { + { + "argument": { + "commentStart": 0, + "end": 0, + "raw": "12.26", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 12.26, + "suffix": "None" + } + }, "commentStart": 0, "end": 0, - "raw": "12.26", + "operator": "-", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 12.26, - "suffix": "None" - } - }, - "commentStart": 0, - "end": 0, - "operator": "-", - "start": 0, - "type": "UnaryExpression", - "type": "UnaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "UnaryExpression", + "type": "UnaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -118,7 +121,7 @@ description: Result of parsing ssi_pattern.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -129,8 +132,9 @@ description: Result of parsing ssi_pattern.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/ssi_pattern/input.kcl b/rust/kcl-lib/tests/ssi_pattern/input.kcl index ee46ae9f4..435097888 100644 --- a/rust/kcl-lib/tests/ssi_pattern/input.kcl +++ b/rust/kcl-lib/tests/ssi_pattern/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn('XZ') - |> startProfileAt([-4.35, -12.26], %) + |> startProfile(at = [-4.35, -12.26]) |> yLine(length = 10.2) |> line(end = [0.54, -0.03]) |> tangentialArc(endAbsolute = [20.4, 14.61]) diff --git a/rust/kcl-lib/tests/ssi_pattern/unparsed.snap b/rust/kcl-lib/tests/ssi_pattern/unparsed.snap index 137fd5dc4..bf3576754 100644 --- a/rust/kcl-lib/tests/ssi_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/ssi_pattern/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing ssi_pattern.kcl --- sketch001 = startSketchOn(XZ) - |> startProfileAt([-4.35, -12.26], %) + |> startProfile(at = [-4.35, -12.26]) |> yLine(length = 10.2) |> line(end = [0.54, -0.03]) |> tangentialArc(endAbsolute = [20.4, 14.61]) diff --git a/rust/kcl-lib/tests/subtract_cylinder_from_cube/ast.snap b/rust/kcl-lib/tests/subtract_cylinder_from_cube/ast.snap index 91d3262ad..af8d0ac0b 100644 --- a/rust/kcl-lib/tests/subtract_cylinder_from_cube/ast.snap +++ b/rust/kcl-lib/tests/subtract_cylinder_from_cube/ast.snap @@ -66,116 +66,119 @@ description: Result of parsing subtract_cylinder_from_cube.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, - "computed": false, "end": 0, - "object": { + "left": { "commentStart": 0, + "computed": false, "end": 0, - "name": "center", + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier", - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "property": { + "operator": "-", + "right": { "commentStart": 0, "end": 0, - "raw": "0", + "raw": "10", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 0.0, + "value": 10.0, "suffix": "None" } }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "-", - "right": { + { "commentStart": 0, "end": 0, - "raw": "10", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 10.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "left": { "commentStart": 0, + "computed": false, "end": 0, - "name": "center", + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier", - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "property": { + "operator": "-", + "right": { "commentStart": 0, "end": 0, - "raw": "1", + "raw": "10", "start": 0, "type": "Literal", "type": "Literal", "value": { - "value": 1.0, + "value": 10.0, "suffix": "None" } }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { - "commentStart": 0, - "end": 0, - "raw": "10", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 10.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -185,7 +188,7 @@ description: Result of parsing subtract_cylinder_from_cube.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -196,8 +199,9 @@ description: Result of parsing subtract_cylinder_from_cube.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/subtract_cylinder_from_cube/input.kcl b/rust/kcl-lib/tests/subtract_cylinder_from_cube/input.kcl index d4cc93b07..2308d46bc 100644 --- a/rust/kcl-lib/tests/subtract_cylinder_from_cube/input.kcl +++ b/rust/kcl-lib/tests/subtract_cylinder_from_cube/input.kcl @@ -1,6 +1,6 @@ fn cube(center) { return startSketchOn(XY) - |> startProfileAt([center[0] - 10, center[1] - 10], %) + |> startProfile(at = [center[0] - 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) |> line(endAbsolute = [center[0] - 10, center[1] + 10]) diff --git a/rust/kcl-lib/tests/subtract_cylinder_from_cube/unparsed.snap b/rust/kcl-lib/tests/subtract_cylinder_from_cube/unparsed.snap index 035e6ab4e..0f276364d 100644 --- a/rust/kcl-lib/tests/subtract_cylinder_from_cube/unparsed.snap +++ b/rust/kcl-lib/tests/subtract_cylinder_from_cube/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing subtract_cylinder_from_cube.kcl --- fn cube(center) { return startSketchOn(XY) - |> startProfileAt([center[0] - 10, center[1] - 10], %) + |> startProfile(at = [center[0] - 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) |> line(endAbsolute = [center[0] - 10, center[1] + 10]) diff --git a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/ast.snap b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/ast.snap index ceb223118..b36956f19 100644 --- a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/ast.snap +++ b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/ast.snap @@ -66,124 +66,127 @@ description: Result of parsing subtract_doesnt_need_brackets.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "center", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { "commentStart": 0, + "computed": false, "end": 0, - "name": "size", + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "center", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "size", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -193,7 +196,7 @@ description: Result of parsing subtract_doesnt_need_brackets.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -204,8 +207,9 @@ description: Result of parsing subtract_doesnt_need_brackets.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/input.kcl b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/input.kcl index 2753bb6f3..262b67e32 100644 --- a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/input.kcl +++ b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/input.kcl @@ -1,6 +1,6 @@ fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/unparsed.snap b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/unparsed.snap index 766d1f90d..0c2094a45 100644 --- a/rust/kcl-lib/tests/subtract_doesnt_need_brackets/unparsed.snap +++ b/rust/kcl-lib/tests/subtract_doesnt_need_brackets/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing subtract_doesnt_need_brackets.kcl --- fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/tan_arc_x_line/ast.snap b/rust/kcl-lib/tests/tan_arc_x_line/ast.snap index b4ee48d1e..83b350807 100644 --- a/rust/kcl-lib/tests/tan_arc_x_line/ast.snap +++ b/rust/kcl-lib/tests/tan_arc_x_line/ast.snap @@ -211,52 +211,55 @@ description: Result of parsing tan_arc_x_line.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "startX", + "name": { + "commentStart": 0, + "end": 0, + "name": "startX", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "startY", + "name": { + "commentStart": 0, + "end": 0, + "name": "startY", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" - }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "Name", + "type": "Name" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -266,7 +269,7 @@ description: Result of parsing tan_arc_x_line.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -277,8 +280,9 @@ description: Result of parsing tan_arc_x_line.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/tan_arc_x_line/input.kcl b/rust/kcl-lib/tests/tan_arc_x_line/input.kcl index 4ac9156f4..9861101f3 100644 --- a/rust/kcl-lib/tests/tan_arc_x_line/input.kcl +++ b/rust/kcl-lib/tests/tan_arc_x_line/input.kcl @@ -5,7 +5,7 @@ r = 1 angleStart = 110 startSketchOn('XY') - |> startProfileAt([startX, startY], %) + |> startProfile(at = [startX, startY]) |> angledLine(angle = angleStart, length = .000001) |> tangentialArc(angle = angleOffset, radius = r, tag = $arc1) |> tangentialArc(angle = angleOffset, radius = 0.5 * r, tag = $arc2) diff --git a/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap b/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap index 492dbea93..cd790a955 100644 --- a/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap +++ b/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap @@ -9,7 +9,7 @@ r = 1 angleStart = 110 startSketchOn(XY) - |> startProfileAt([startX, startY], %) + |> startProfile(at = [startX, startY]) |> angledLine(angle = angleStart, length = .000001) |> tangentialArc(angle = angleOffset, radius = r, tag = $arc1) |> tangentialArc(angle = angleOffset, radius = 0.5 * r, tag = $arc2) diff --git a/rust/kcl-lib/tests/tangent_to_3_point_arc/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/tangent_to_3_point_arc/artifact_graph_flowchart.snap.md index 517b2ce54..1cd09efaa 100644 --- a/rust/kcl-lib/tests/tangent_to_3_point_arc/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/tangent_to_3_point_arc/artifact_graph_flowchart.snap.md @@ -1,10 +1,10 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[43, 82, 0]"] - 3["Segment
[88, 112, 0]"] - 4["Segment
[118, 232, 0]"] - 5["Segment
[238, 315, 0]"] + 2["Path
[43, 85, 0]"] + 3["Segment
[91, 115, 0]"] + 4["Segment
[121, 235, 0]"] + 5["Segment
[241, 318, 0]"] end 1["Plane
[12, 29, 0]"] 1 --- 2 diff --git a/rust/kcl-lib/tests/tangent_to_3_point_arc/ast.snap b/rust/kcl-lib/tests/tangent_to_3_point_arc/ast.snap index 1a8327f42..7c16fa7c6 100644 --- a/rust/kcl-lib/tests/tangent_to_3_point_arc/ast.snap +++ b/rust/kcl-lib/tests/tangent_to_3_point_arc/ast.snap @@ -83,53 +83,47 @@ description: Result of parsing tangent_to_3_point_arc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "100.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 100.0, - "suffix": "None" - } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0.0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "sketch001", + "name": "at", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "100.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 100.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -139,7 +133,7 @@ description: Result of parsing tangent_to_3_point_arc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -150,8 +144,24 @@ description: Result of parsing tangent_to_3_point_arc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "sketch001", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, { "arguments": [ diff --git a/rust/kcl-lib/tests/tangent_to_3_point_arc/input.kcl b/rust/kcl-lib/tests/tangent_to_3_point_arc/input.kcl index a79ccf9b1..bb6cff279 100644 --- a/rust/kcl-lib/tests/tangent_to_3_point_arc/input.kcl +++ b/rust/kcl-lib/tests/tangent_to_3_point_arc/input.kcl @@ -1,5 +1,5 @@ sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([100.0, 0.0], sketch001) +profile001 = startProfile(sketch001, at = [100.0, 0.0]) |> line(end = [0.0, 120.0]) |> arc( interiorAbsolute = [300.0, 100.0], diff --git a/rust/kcl-lib/tests/tangent_to_3_point_arc/program_memory.snap b/rust/kcl-lib/tests/tangent_to_3_point_arc/program_memory.snap index 8bef28f67..3ed8e3d8e 100644 --- a/rust/kcl-lib/tests/tangent_to_3_point_arc/program_memory.snap +++ b/rust/kcl-lib/tests/tangent_to_3_point_arc/program_memory.snap @@ -50,9 +50,9 @@ description: Variables in memory after executing tangent_to_3_point_arc.kcl -100.0 ], "tag": { - "commentStart": 218, - "end": 224, - "start": 218, + "commentStart": 221, + "end": 227, + "start": 221, "type": "TagDeclarator", "value": "seg01" }, diff --git a/rust/kcl-lib/tests/tangent_to_3_point_arc/unparsed.snap b/rust/kcl-lib/tests/tangent_to_3_point_arc/unparsed.snap index 0deba1782..00c5588b5 100644 --- a/rust/kcl-lib/tests/tangent_to_3_point_arc/unparsed.snap +++ b/rust/kcl-lib/tests/tangent_to_3_point_arc/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing tangent_to_3_point_arc.kcl --- sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([100.0, 0.0], sketch001) +profile001 = startProfile(sketch001, at = [100.0, 0.0]) |> line(end = [0.0, 120.0]) |> arc(interiorAbsolute = [300.0, 100.0], endAbsolute = [200.0, -100.0], tag = $seg01) |> angledLine(angle = tangentToEnd(seg01), length = 100.0) diff --git a/rust/kcl-lib/tests/tangential_arc/ast.snap b/rust/kcl-lib/tests/tangential_arc/ast.snap index 262f44ded..01bbf6561 100644 --- a/rust/kcl-lib/tests/tangential_arc/ast.snap +++ b/rust/kcl-lib/tests/tangential_arc/ast.snap @@ -62,44 +62,47 @@ description: Result of parsing tangential_arc.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -109,7 +112,7 @@ description: Result of parsing tangential_arc.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -120,8 +123,9 @@ description: Result of parsing tangential_arc.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/tangential_arc/input.kcl b/rust/kcl-lib/tests/tangential_arc/input.kcl index 66b4c0090..0f701a5c3 100644 --- a/rust/kcl-lib/tests/tangential_arc/input.kcl +++ b/rust/kcl-lib/tests/tangential_arc/input.kcl @@ -1,5 +1,5 @@ boxSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> tangentialArc(radius = 5, angle = 90) |> line(end = [5, -15]) diff --git a/rust/kcl-lib/tests/tangential_arc/unparsed.snap b/rust/kcl-lib/tests/tangential_arc/unparsed.snap index f9cdd612a..b37e9248e 100644 --- a/rust/kcl-lib/tests/tangential_arc/unparsed.snap +++ b/rust/kcl-lib/tests/tangential_arc/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing tangential_arc.kcl --- boxSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0, 10]) |> tangentialArc(radius = 5, angle = 90) |> line(end = [5, -15]) diff --git a/rust/kcl-lib/tests/translate_after_fillet/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/translate_after_fillet/artifact_graph_flowchart.snap.md index e4b679728..0b50a3946 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/translate_after_fillet/artifact_graph_flowchart.snap.md @@ -6,18 +6,18 @@ flowchart LR 4[Solid2d] end subgraph path13 [Path] - 13["Path
[660, 747, 0]"] - 14["Segment
[755, 834, 0]"] - 15["Segment
[842, 921, 0]"] - 16["Segment
[929, 1008, 0]"] - 17["Segment
[1016, 1094, 0]"] - 18["Segment
[1102, 1180, 0]"] - 19["Segment
[1188, 1195, 0]"] + 13["Path
[660, 720, 0]"] + 14["Segment
[728, 807, 0]"] + 15["Segment
[815, 894, 0]"] + 16["Segment
[902, 981, 0]"] + 17["Segment
[989, 1067, 0]"] + 18["Segment
[1075, 1153, 0]"] + 19["Segment
[1161, 1168, 0]"] 20[Solid2d] end subgraph path41 [Path] - 41["Path
[1303, 1372, 0]"] - 42["Segment
[1303, 1372, 0]"] + 41["Path
[1276, 1345, 0]"] + 42["Segment
[1276, 1345, 0]"] 43[Solid2d] end 1["Plane
[320, 337, 0]"] @@ -29,7 +29,7 @@ flowchart LR 10["SweepEdge Adjacent"] 11["EdgeCut Fillet
[464, 530, 0]"] 12["EdgeCut Fillet
[464, 530, 0]"] - 21["Sweep Extrusion
[1203, 1243, 0]"] + 21["Sweep Extrusion
[1176, 1216, 0]"] 22[Wall] 23[Wall] 24[Wall] @@ -49,14 +49,14 @@ flowchart LR 38["SweepEdge Adjacent"] 39["SweepEdge Opposite"] 40["SweepEdge Adjacent"] - 44["Sweep Extrusion
[1380, 1408, 0]"] + 44["Sweep Extrusion
[1353, 1381, 0]"] 45[Wall] 46["Cap End"] 47["SweepEdge Opposite"] 48["SweepEdge Adjacent"] - 49["EdgeCut Fillet
[1416, 1475, 0]"] + 49["EdgeCut Fillet
[1389, 1448, 0]"] 50["StartSketchOnFace
[613, 652, 0]"] - 51["StartSketchOnFace
[1258, 1295, 0]"] + 51["StartSketchOnFace
[1231, 1268, 0]"] 1 --- 2 2 --- 3 2 ---- 5 diff --git a/rust/kcl-lib/tests/translate_after_fillet/ast.snap b/rust/kcl-lib/tests/translate_after_fillet/ast.snap index 0f803c13a..48c18d572 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/ast.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/ast.snap @@ -854,92 +854,95 @@ description: Result of parsing translate_after_fillet.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "boltHexDrive", + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexDrive", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "/", - "right": { - "commentStart": 0, - "end": 0, - "raw": "2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "operator": "/", + "right": { "commentStart": 0, "end": 0, - "name": "boltHexFlatLength", + "raw": "2", "start": 0, - "type": "Identifier" + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "/", - "right": { + { "commentStart": 0, "end": 0, - "raw": "2", + "left": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "boltHexFlatLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + }, + "operator": "/", + "right": { + "commentStart": 0, + "end": 0, + "raw": "2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 2.0, + "suffix": "None" + } + }, "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 2.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -949,7 +952,7 @@ description: Result of parsing translate_after_fillet.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -960,8 +963,9 @@ description: Result of parsing translate_after_fillet.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/translate_after_fillet/input.kcl b/rust/kcl-lib/tests/translate_after_fillet/input.kcl index cec01967a..ba0d25911 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/input.kcl +++ b/rust/kcl-lib/tests/translate_after_fillet/input.kcl @@ -15,10 +15,7 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = 'start') - |> startProfileAt([ - boltHexDrive / 2, - boltHexFlatLength / 2 - ], %) + |> startProfile(at = [boltHexDrive / 2, boltHexFlatLength / 2]) |> angledLine( angle = 270, length = boltHexFlatLength, diff --git a/rust/kcl-lib/tests/translate_after_fillet/ops.snap b/rust/kcl-lib/tests/translate_after_fillet/ops.snap index 88aa512fd..870a3dfcc 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/ops.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/ops.snap @@ -9,8 +9,8 @@ description: Operations executed translate_after_fillet.kcl "type": "FunctionCall", "name": "toRadians", "functionSourceRange": [ - 11497, - 11546, + 11503, + 11552, 1 ], "unlabeledArg": null, @@ -46,7 +46,7 @@ description: Operations executed translate_after_fillet.kcl "name": "bolt", "functionSourceRange": [ 264, - 1565, + 1538, 0 ], "unlabeledArg": null, diff --git a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap index d2c29f75b..0305bb9ef 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap @@ -19,10 +19,10 @@ export fn bolt() { // Define the sketch of the hex pattern on the screw head hexPatternSketch = startSketchOn(boltHead, face = START) - |> startProfileAt([ + |> startProfile(at = [ boltHexDrive / 2, boltHexFlatLength / 2 - ], %) + ]) |> angledLine(angle = 270, length = boltHexFlatLength) |> angledLine(angle = 210, length = boltHexFlatLength) |> angledLine(angle = 150, length = boltHexFlatLength) diff --git a/rust/kcl-lib/tests/union_cubes/ast.snap b/rust/kcl-lib/tests/union_cubes/ast.snap index c25d7956f..2d7ba3777 100644 --- a/rust/kcl-lib/tests/union_cubes/ast.snap +++ b/rust/kcl-lib/tests/union_cubes/ast.snap @@ -66,124 +66,127 @@ description: Result of parsing union_cubes.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { - "commentStart": 0, - "end": 0, - "name": "center", - "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" - }, - "operator": "-", - "right": { - "abs_path": false, + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { "commentStart": 0, "end": 0, - "name": { + "left": { "commentStart": 0, + "computed": false, "end": 0, - "name": "size", + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, "start": 0, - "type": "Identifier" + "type": "MemberExpression", + "type": "MemberExpression" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "commentStart": 0, - "computed": false, - "end": 0, - "object": { + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "center", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier", - "type": "Identifier" - }, - "property": { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" - } + "type": "Name", + "type": "Name" }, "start": 0, - "type": "MemberExpression", - "type": "MemberExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" }, - "operator": "-", - "right": { - "abs_path": false, + { "commentStart": 0, "end": 0, - "name": { + "left": { + "commentStart": 0, + "computed": false, + "end": 0, + "object": { + "commentStart": 0, + "end": 0, + "name": "center", + "start": 0, + "type": "Identifier", + "type": "Identifier" + }, + "property": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } + }, + "start": 0, + "type": "MemberExpression", + "type": "MemberExpression" + }, + "operator": "-", + "right": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "size", + "name": { + "commentStart": 0, + "end": 0, + "name": "size", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + "type": "BinaryExpression", + "type": "BinaryExpression" + } + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -193,7 +196,7 @@ description: Result of parsing union_cubes.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -204,8 +207,9 @@ description: Result of parsing union_cubes.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/union_cubes/input.kcl b/rust/kcl-lib/tests/union_cubes/input.kcl index e79ab9fbf..483681a95 100644 --- a/rust/kcl-lib/tests/union_cubes/input.kcl +++ b/rust/kcl-lib/tests/union_cubes/input.kcl @@ -1,6 +1,6 @@ fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/union_cubes/unparsed.snap b/rust/kcl-lib/tests/union_cubes/unparsed.snap index 2a68bd834..d32d14cec 100644 --- a/rust/kcl-lib/tests/union_cubes/unparsed.snap +++ b/rust/kcl-lib/tests/union_cubes/unparsed.snap @@ -4,7 +4,7 @@ description: Result of unparsing union_cubes.kcl --- fn cube(center, size) { return startSketchOn(XY) - |> startProfileAt([center[0] - size, center[1] - size], %) + |> startProfile(at = [center[0] - size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] - size]) |> line(endAbsolute = [center[0] + size, center[1] + size]) |> line(endAbsolute = [center[0] - size, center[1] + size]) diff --git a/rust/kcl-lib/tests/xz_plane/ast.snap b/rust/kcl-lib/tests/xz_plane/ast.snap index aa42c1930..30baf8f64 100644 --- a/rust/kcl-lib/tests/xz_plane/ast.snap +++ b/rust/kcl-lib/tests/xz_plane/ast.snap @@ -55,44 +55,47 @@ description: Result of parsing xz_plane.kcl { "arguments": [ { - "commentStart": 0, - "elements": [ - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "at", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "elements": [ + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + }, + { + "commentStart": 0, + "end": 0, + "raw": "0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } } - }, - { - "commentStart": 0, - "end": 0, - "raw": "0", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - } - ], - "end": 0, - "start": 0, - "type": "ArrayExpression", - "type": "ArrayExpression" - }, - { - "commentStart": 0, - "end": 0, - "start": 0, - "type": "PipeSubstitution", - "type": "PipeSubstitution" + ], + "end": 0, + "start": 0, + "type": "ArrayExpression", + "type": "ArrayExpression" + } } ], "callee": { @@ -102,7 +105,7 @@ description: Result of parsing xz_plane.kcl "name": { "commentStart": 0, "end": 0, - "name": "startProfileAt", + "name": "startProfile", "start": 0, "type": "Identifier" }, @@ -113,8 +116,9 @@ description: Result of parsing xz_plane.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": null }, { "arguments": [ diff --git a/rust/kcl-lib/tests/xz_plane/input.kcl b/rust/kcl-lib/tests/xz_plane/input.kcl index 6c33fde11..e22881807 100644 --- a/rust/kcl-lib/tests/xz_plane/input.kcl +++ b/rust/kcl-lib/tests/xz_plane/input.kcl @@ -1,5 +1,5 @@ part001 = startSketchOn('XZ') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close(%) diff --git a/rust/kcl-lib/tests/xz_plane/unparsed.snap b/rust/kcl-lib/tests/xz_plane/unparsed.snap index 75fa6fa24..b4c92eecf 100644 --- a/rust/kcl-lib/tests/xz_plane/unparsed.snap +++ b/rust/kcl-lib/tests/xz_plane/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing xz_plane.kcl --- part001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) |> close(%) diff --git a/rust/kcl-python-bindings/files/box_with_linter_errors.kcl b/rust/kcl-python-bindings/files/box_with_linter_errors.kcl index f08a7ff24..9a74cb693 100644 --- a/rust/kcl-python-bindings/files/box_with_linter_errors.kcl +++ b/rust/kcl-python-bindings/files/box_with_linter_errors.kcl @@ -5,7 +5,7 @@ const box_depth = 25 const box_height = 50 const box_sketch = startSketchOn('XY') - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> xLine(length = box_width, tag = $line1) |> yLine(length = box_depth, tag = $line2) |> xLine(endAbsolute = profileStartX(%), tag = $line3) diff --git a/rust/kcl-to-core/tests/kcl_to_core_test.rs b/rust/kcl-to-core/tests/kcl_to_core_test.rs index 7a1054a6f..a7c2fb502 100644 --- a/rust/kcl-to-core/tests/kcl_to_core_test.rs +++ b/rust/kcl-to-core/tests/kcl_to_core_test.rs @@ -5,7 +5,7 @@ async fn kcl_to_core_test() { let result = kcl_to_engine_core( r#" part001 = startSketchOn('XY') - |> startProfileAt([11.19, 28.35], %) + |> startProfile(at = [11.19, 28.35]) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) |> line(end = [-33.24, 14.55]) diff --git a/src/clientSideScene/sceneEntities.ts b/src/clientSideScene/sceneEntities.ts index 24eb457f4..08cb9bfc7 100644 --- a/src/clientSideScene/sceneEntities.ts +++ b/src/clientSideScene/sceneEntities.ts @@ -100,10 +100,9 @@ import { import type EditorManager from '@src/editor/manager' import type { KclManager } from '@src/lang/KclSingleton' import type CodeManager from '@src/lang/codeManager' -import { ARG_END, ARG_END_ABSOLUTE } from '@src/lang/constants' +import { ARG_END, ARG_AT, ARG_END_ABSOLUTE } from '@src/lang/constants' import { createArrayExpression, - createCallExpressionStdLib, createCallExpressionStdLibKw, createLabeledArg, createLiteral, @@ -473,7 +472,7 @@ export class SceneEntities { scale, theme: this.sceneInfra._theme, // default is 12, this makes the draft point pop a bit more, - // especially when snapping to the startProfileAt handle as it's it was the exact same size + // especially when snapping to the startProfile handle as it's it was the exact same size size: 16, }) draftPoint.layers.set(SKETCH_LAYER) @@ -1212,13 +1211,19 @@ export class SceneEntities { const tag = findUniqueName(_ast, 'rectangleSegmentA') const newDeclaration = createVariableDeclaration( varName, - createCallExpressionStdLib('startProfileAt', [ - createArrayExpression([ - createLiteral(roundOff(rectangleOrigin[0])), - createLiteral(roundOff(rectangleOrigin[1])), - ]), + createCallExpressionStdLibKw( + 'startProfile', createLocalName(varDec.node.id.name), - ]) + [ + createLabeledArg( + ARG_AT, + createArrayExpression([ + createLiteral(roundOff(rectangleOrigin[0])), + createLiteral(roundOff(rectangleOrigin[1])), + ]) + ), + ] + ) ) const insertIndex = getInsertIndex(sketchNodePaths, planeNodePath, 'end') @@ -1413,15 +1418,22 @@ export class SceneEntities { // first create just the variable declaration, as that's // all we want the user to see in the editor const tag = findUniqueName(_ast, 'rectangleSegmentA') + const newDeclaration = createVariableDeclaration( varName, - createCallExpressionStdLib('startProfileAt', [ - createArrayExpression([ - createLiteral(roundOff(rectangleOrigin[0])), - createLiteral(roundOff(rectangleOrigin[1])), - ]), + createCallExpressionStdLibKw( + 'startProfile', createLocalName(varDec.node.id.name), - ]) + [ + createLabeledArg( + ARG_AT, + createArrayExpression([ + createLiteral(roundOff(rectangleOrigin[0])), + createLiteral(roundOff(rectangleOrigin[1])), + ]) + ), + ] + ) ) const insertIndex = getInsertIndex(sketchNodePaths, planeNodePath, 'end') diff --git a/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx b/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx index 44845398c..a1d8f3092 100644 --- a/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx +++ b/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx @@ -18,13 +18,13 @@ describe('processMemory', () => { otherVar = myFn(5) theExtrude = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-2.4, myVar]) |> line(endAbsolute = [-0.76, otherVar]) |> extrude(length = 4) theSketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-3.35, 0.17]) |> line(endAbsolute = [0.98, 5.16]) |> line(endAbsolute = [2.15, 4.32]) diff --git a/src/lang/artifact.test.ts b/src/lang/artifact.test.ts index 692145e9a..39ed6f4af 100644 --- a/src/lang/artifact.test.ts +++ b/src/lang/artifact.test.ts @@ -11,7 +11,7 @@ describe('testing artifacts', () => { test('sketch artifacts', async () => { const code = ` const mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) // |> rx(45, %)` @@ -69,7 +69,7 @@ const mySketch001 = startSketchOn(XY) // Enable rotations #152 const code = ` const mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) // |> rx(45, %) @@ -148,7 +148,7 @@ const mySketch001 = startSketchOn(XY) // TODO #153 in order for getExtrudeWallTransform to work we need to query the engine for the location of a face. const code = ` const sk1 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-2.5, 0]) |> line(endAbsolute = [0, 10], tag = $p) |> line(endAbsolute = [2.5, 0]) @@ -158,7 +158,7 @@ const sk1 = startSketchOn(XY) const theExtrude = extrude(sk1, length = 2) // const theTransf = getExtrudeWallTransform('p', theExtrude) const sk2 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [-2.5, 0]) |> line(endAbsolute = [0, 3], tag = $o) |> line(endAbsolute = [2.5, 0]) diff --git a/src/lang/constants.ts b/src/lang/constants.ts index be12aed8f..64fd95449 100644 --- a/src/lang/constants.ts +++ b/src/lang/constants.ts @@ -15,3 +15,4 @@ export const ARG_END_ABSOLUTE_X = 'endAbsoluteX' export const ARG_END_ABSOLUTE_Y = 'endAbsoluteY' export const ARG_INTERSECT_TAG = 'intersectTag' export const ARG_INTERIOR_ABSOLUTE = 'interiorAbsolute' +export const ARG_AT = 'at' diff --git a/src/lang/executor.test.ts b/src/lang/executor.test.ts index afa991b70..c40027150 100644 --- a/src/lang/executor.test.ts +++ b/src/lang/executor.test.ts @@ -48,7 +48,7 @@ const newVar = myVar + 1` }) it('sketch declaration', async () => { let code = `const mySketch = startSketchOn(XY) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(endAbsolute = [0,2], tag = $myPath) |> line(endAbsolute = [2,3]) |> line(endAbsolute = [5,-1], tag = $rightPath) @@ -151,7 +151,7 @@ const newVar = myVar + 1` // Enable rotations #152 const code = [ 'const mySk1 = startSketchOn(XY)', - ' |> startProfileAt([0,0], %)', + ' |> startProfile(at = [0,0])', ' |> line(endAbsolute = [1,1])', ' |> line(endAbsolute = [0, 1], tag = $myPath)', ' |> line(endAbsolute = [1,1])', @@ -398,7 +398,7 @@ describe('testing math operators', () => { it('with unaryExpression in ArrayExpression in CallExpression, checking nothing funny happens when used in a sketch', async () => { const code = [ 'part001 = startSketchOn(XY)', - ' |> startProfileAt([0, 0], %)', + ' |> startProfile(at = [0, 0])', '|> line(end = [-2.21, -legLen(hypotenuse = 5, leg = min(3, 999))])', ].join('\n') const mem = await exe(code) @@ -411,7 +411,7 @@ describe('testing math operators', () => { const code = [ `const myVar = 3`, `const part001 = startSketchOn(XY)`, - ` |> startProfileAt([0, 0], %)`, + ` |> startProfile(at = [0, 0])`, ` |> line(end = [3, 4], tag = $seg01)`, ` |> line(end = [`, ` min(segLen(seg01), myVar),`, @@ -454,7 +454,7 @@ describe('Testing Errors', () => { it('should throw an error when a variable is not defined', async () => { const code = `const myVar = 5 const theExtrude = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [-2.4, 5]) |> line(end = myVarZ) |> line(end = [5,5]) diff --git a/src/lang/getNodePathFromSourceRange.test.ts b/src/lang/getNodePathFromSourceRange.test.ts index 3d73b6642..3f090329e 100644 --- a/src/lang/getNodePathFromSourceRange.test.ts +++ b/src/lang/getNodePathFromSourceRange.test.ts @@ -18,7 +18,7 @@ describe('testing getNodePathFromSourceRange', () => { const code = ` const myVar = 5 const sk3 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 2]) |> line(endAbsolute = [3, 4], tag = $yo) |> close() @@ -42,7 +42,7 @@ const sk3 = startSketchOn(XY) it('gets path right for function definition params', () => { const code = `fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) @@ -75,7 +75,7 @@ const b1 = cube([0,0], 10)` it('gets path right for deep within function definition body', () => { const code = `fn cube = (pos, scale) => { const sg = startSketchOn(XY) - |> startProfileAt(pos, %) + |> startProfile(at = pos) |> line(end = [0, scale]) |> line(end = [scale, 0]) |> line(end = [0, -scale]) diff --git a/src/lang/modifyAst.test.ts b/src/lang/modifyAst.test.ts index 931e95052..2c758caa0 100644 --- a/src/lang/modifyAst.test.ts +++ b/src/lang/modifyAst.test.ts @@ -243,7 +243,7 @@ describe('Testing addSketchTo', () => { ) const str = recast(result.modifiedAst) expect(str).toBe(`sketch001 = startSketchOn(YZ) - |> startProfileAt('default', %) + |> startProfile(at = 'default') |> line(end = 'default') `) }) @@ -269,7 +269,7 @@ function giveSketchFnCallTagTestHelper( describe('Testing giveSketchFnCallTag', () => { const code = `part001 = startSketchOn(XY) -|> startProfileAt([0, 0], %) +|> startProfile(at = [0, 0]) |> line(end = [-2.57, -0.13]) |> line(end = [0, 0.83]) |> line(end = [0.82, 0.34])` @@ -321,7 +321,7 @@ const abc = 3 const identifierGuy = 5 yo = 5 + 6 part001 = startSketchOn(XY) -|> startProfileAt([-1.2, 4.83], %) +|> startProfile(at = [-1.2, 4.83]) |> line(end = [2.8, 0]) |> angledLine(angle = 100 + 100, length = 3.09) |> angledLine(angle = abc, length = 3.09) @@ -404,7 +404,7 @@ yo2 = hmm([identifierGuy + 5])` describe('testing sketchOnExtrudedFace', () => { test('it should be able to extrude on regular segments', async () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) |> close() @@ -434,7 +434,7 @@ describe('testing sketchOnExtrudedFace', () => { const newCode = recast(modifiedAst) expect(newCode).toContain(`part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19], tag = $seg01) |> line(end = [8.62, -9.57]) |> close() @@ -443,7 +443,7 @@ sketch001 = startSketchOn(part001, face = seg01)`) }) test('it should be able to extrude on close segments', async () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) |> close() @@ -472,7 +472,7 @@ sketch001 = startSketchOn(part001, face = seg01)`) const newCode = recast(modifiedAst) expect(newCode).toContain(`part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) |> close(tag = $seg01) @@ -481,13 +481,13 @@ sketch001 = startSketchOn(part001, face = seg01)`) }) test('it should be able to extrude on start-end caps', async () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) |> close() |> extrude(length = 5 + 7)` const ast = assertParse(code) - const sketchSnippet = `startProfileAt([3.58, 2.06], %)` + const sketchSnippet = `startProfile(at = [3.58, 2.06])` const sketchRange = topLevelRange( code.indexOf(sketchSnippet), code.indexOf(sketchSnippet) + sketchSnippet.length @@ -511,7 +511,7 @@ sketch001 = startSketchOn(part001, face = seg01)`) const newCode = recast(modifiedAst) expect(newCode).toContain(`part001 = startSketchOn(-XZ) - |> startProfileAt([3.58, 2.06], %) + |> startProfile(at = [3.58, 2.06]) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) |> close() @@ -520,7 +520,7 @@ sketch001 = startSketchOn(part001, face = END)`) }) test('it should ensure that the new sketch is inserted after the extrude', async () => { const code = `sketch001 = startSketchOn(-XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) |> line(end = [3.75, 0.46]) @@ -562,7 +562,7 @@ sketch002 = startSketchOn(part001, face = seg01)`) describe('Testing deleteSegmentFromPipeExpression', () => { it('Should delete a segment withOUT any dependent segments', async () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([54.78, -95.91], %) + |> startProfile(at = [54.78, -95.91]) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.85], tag = $a) |> line(end = [306.21, 198.87])` @@ -584,7 +584,7 @@ describe('Testing deleteSegmentFromPipeExpression', () => { if (err(modifiedAst)) throw modifiedAst const newCode = recast(modifiedAst) expect(newCode).toBe(`part001 = startSketchOn(-XZ) - |> startProfileAt([54.78, -95.91], %) + |> startProfile(at = [54.78, -95.91]) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.87]) `) @@ -595,7 +595,7 @@ describe('Testing deleteSegmentFromPipeExpression', () => { replace1 = '', replace2 = '' ) => `part001 = startSketchOn(-XZ) - |> startProfileAt([54.78, -95.91], %) + |> startProfile(at = [54.78, -95.91]) |> line(end = [306.21, 198.82], tag = $b) ${!replace1 ? ` |> ${line}\n` : ''} |> angledLine(angle = -65, length = ${ !replace1 ? 'segLen(a)' : replace1 @@ -672,7 +672,7 @@ ${!replace1 ? ` |> ${line}\n` : ''} |> angledLine(angle = -65, length = ${ describe('Testing removeSingleConstraintInfo', () => { describe('with mostly object notation', () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3 + 0, 4 + 0]) |> /*0*/ angledLine(angle = 3 + 0, length = 3.14 + 0) |> line(endAbsolute = [6.14 + 0, 3.14 + 0]) @@ -780,7 +780,7 @@ describe('Testing removeSingleConstraintInfo', () => { }) describe('with array notation', () => { const code = `part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> /*0*/ angledLine(angle = 3.14 + 0, length = 3.14 + 0) |> /*1*/ angledLine(angle = 3 + 0, lengthX = 3.14 + 0) |> /*2*/ angledLine(angle = 30 + 0, lengthY = 3 + 0) @@ -852,7 +852,7 @@ describe('Testing deleteFromSelection', () => { { codeBefore: `myVar = 5 sketch003 = startSketchOn(XZ) - |> startProfileAt([3.82, 13.6], %) + |> startProfile(at = [3.82, 13.6]) |> line(end = [-2.94, 2.7]) |> line(end = [7.7, 0.16]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -868,7 +868,7 @@ sketch003 = startSketchOn(XZ) // 'delete extrude', // { // codeBefore: `sketch001 = startSketchOn(XZ) - // |> startProfileAt([3.29, 7.86], %) + // |> startProfile(at = [3.29, 7.86]) // |> line(end = [2.48, 2.44]) // |> line(end = [2.66, 1.17]) // |> line(end = [3.75, 0.46]) @@ -878,7 +878,7 @@ sketch003 = startSketchOn(XZ) // |> close() // const extrude001 = extrude(sketch001, length = 10)`, // codeAfter: `sketch001 = startSketchOn(XZ) - // |> startProfileAt([3.29, 7.86], %) + // |> startProfile(at = [3.29, 7.86]) // |> line(end = [2.48, 2.44]) // |> line(end = [2.66, 1.17]) // |> line(end = [3.75, 0.46]) @@ -895,7 +895,7 @@ sketch003 = startSketchOn(XZ) // { // codeBefore: `myVar = 5 // sketch001 = startSketchOn(XZ) - // |> startProfileAt([4.46, 5.12], %, $tag) + // |> startProfile(at = [4.46, 5.12], tag = $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) // |> line(end = [3.9, -7.6]) @@ -906,7 +906,7 @@ sketch003 = startSketchOn(XZ) // |> close() // const extrude001 = extrude(sketch001, length = 5) // sketch002 = startSketchOn(extrude001, face = seg01) - // |> startProfileAt([-12.55, 2.89], %) + // |> startProfile(at = [-12.55, 2.89]) // |> line(end = [3.02, 1.9]) // |> line(end = [1.82, -1.49], tag = $seg02) // |> angledLine(angle = -86, length = segLen(seg02)) @@ -916,7 +916,7 @@ sketch003 = startSketchOn(XZ) // |> close()`, // codeAfter: `myVar = 5 // sketch001 = startSketchOn(XZ) - // |> startProfileAt([4.46, 5.12], %, $tag) + // |> startProfile(at = [4.46, 5.12], tag = $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) // |> line(end = [3.9, -7.6]) @@ -931,7 +931,7 @@ sketch003 = startSketchOn(XZ) // yAxis = { x = 7, y = 8, z = 9 }, // zAxis = { x = 10, y = 11, z = 12 } // }) - // |> startProfileAt([-12.55, 2.89], %) + // |> startProfile(at = [-12.55, 2.89]) // |> line(end = [3.02, 1.9]) // |> line(end = [1.82, -1.49], tag = $seg02) // |> angledLine(angle = -86, length = segLen(seg02)) @@ -949,7 +949,7 @@ sketch003 = startSketchOn(XZ) // { // codeBefore: `myVar = 5 // sketch001 = startSketchOn(XZ) - // |> startProfileAt([4.46, 5.12], %, $tag) + // |> startProfile(at = [4.46, 5.12], tag = $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) // |> line(end = [3.9, -7.6]) @@ -960,7 +960,7 @@ sketch003 = startSketchOn(XZ) // |> close() // const extrude001 = extrude(sketch001, length = 5) // sketch002 = startSketchOn(extrude001, face = seg01) - // |> startProfileAt([-12.55, 2.89], %) + // |> startProfile(at = [-12.55, 2.89]) // |> line(end = [3.02, 1.9]) // |> line(end = [1.82, -1.49], tag = $seg02) // |> angledLine(angle = -86, length = segLen(seg02)) @@ -970,7 +970,7 @@ sketch003 = startSketchOn(XZ) // |> close()`, // codeAfter: `myVar = 5 // sketch001 = startSketchOn(XZ) - // |> startProfileAt([4.46, 5.12], %, $tag) + // |> startProfile(at = [4.46, 5.12], tag = $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) // |> line(end = [3.9, -7.6]) @@ -985,7 +985,7 @@ sketch003 = startSketchOn(XZ) // yAxis = { x = 7, y = 8, z = 9 }, // zAxis = { x = 10, y = 11, z = 12 } // }) - // |> startProfileAt([-12.55, 2.89], %) + // |> startProfile(at = [-12.55, 2.89]) // |> line(end = [3.02, 1.9]) // |> line(end = [1.82, -1.49], tag = $seg02) // |> angledLine(angle = -86, length = segLen(seg02)) @@ -994,7 +994,7 @@ sketch003 = startSketchOn(XZ) // |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) // |> close() // `, - // lineOfInterest: 'startProfileAt([4.46, 5.12], %, $tag)', + // lineOfInterest: 'startProfile(at = [4.46, 5.12], tag = $tag)', // type: 'cap', // }, // ], @@ -1041,7 +1041,7 @@ describe('Testing splitPipedProfile', () => { it('should split the pipe expression correctly', () => { const codeBefore = `// comment 1 part001 = startSketchOn(XZ) - |> startProfileAt([1, 2], %) + |> startProfile(at = [1, 2]) // comment 2 |> line([3, 4], %) |> line([5, 6], %) @@ -1052,7 +1052,7 @@ extrude001 = extrude(5, part001) const expectedCodeAfter = `// comment 1 sketch001 = startSketchOn(XZ) -part001 = startProfileAt([1, 2], sketch001) +part001 = startProfile(sketch001, at = [1, 2]) // comment 2 |> line([3, 4], %) |> line([5, 6], %) @@ -1081,7 +1081,7 @@ extrude001 = extrude(5, part001) }) it('should return error for already split pipe', () => { const codeBefore = `sketch001 = startSketchOn(XZ) -part001 = startProfileAt([1, 2], sketch001) +part001 = startProfile(sketch001, at = [1, 2]) |> line([3, 4], %) |> line([5, 6], %) |> close(%) @@ -1090,7 +1090,7 @@ extrude001 = extrude(5, part001) const ast = assertParse(codeBefore) - const codeOfInterest = `startProfileAt([1, 2], sketch001)` + const codeOfInterest = `startProfile(sketch001, at = [1, 2])` const range: [number, number, number] = [ codeBefore.indexOf(codeOfInterest), codeBefore.indexOf(codeOfInterest) + codeOfInterest.length, diff --git a/src/lang/modifyAst.ts b/src/lang/modifyAst.ts index 98d525a99..4aa1df21f 100644 --- a/src/lang/modifyAst.ts +++ b/src/lang/modifyAst.ts @@ -18,7 +18,6 @@ import { createLocalName, createObjectExpression, createPipeExpression, - createPipeSubstitution, createVariableDeclaration, findUniqueName, } from '@src/lang/create' @@ -92,6 +91,7 @@ import type { Selection } from '@src/lib/selections' import { err, reportRejection, trap } from '@src/lib/trap' import { isArray, isOverlap, roundOff } from '@src/lib/utils' import type { ExtrudeFacePlane } from '@src/machines/modelingMachine' +import { ARG_AT } from '@src/lang/constants' export function startSketchOnDefault( node: Node, @@ -150,13 +150,19 @@ export function insertNewStartProfileAt( const newExpression = createVariableDeclaration( findUniqueName(node, 'profile'), - createCallExpressionStdLib('startProfileAt', [ - createArrayExpression([ - createLiteral(roundOff(at[0])), - createLiteral(roundOff(at[1])), - ]), + createCallExpressionStdLibKw( + 'startProfile', createLocalName(varDec.node.id.name), - ]) + [ + createLabeledArg( + ARG_AT, + createArrayExpression([ + createLiteral(roundOff(at[0])), + createLiteral(roundOff(at[1])), + ]) + ), + ] + ) ) const insertIndex = getInsertIndex(sketchNodePaths, planeNodePath, insertType) @@ -191,9 +197,8 @@ export function addSketchTo( createLiteral(axis.toUpperCase()), [] ) - const startProfileAt = createCallExpressionStdLib('startProfileAt', [ - createLiteral('default'), - createPipeSubstitution(), + const startProfile = createCallExpressionStdLibKw('startProfile', null, [ + createLabeledArg(ARG_AT, createLiteral('default')), ]) const initialLineTo = createCallExpressionStdLibKw( 'line', @@ -201,7 +206,7 @@ export function addSketchTo( [createLabeledArg('end', createLiteral('default'))] ) - const pipeBody = [startSketchOn, startProfileAt, initialLineTo] + const pipeBody = [startSketchOn, startProfile, initialLineTo] const variableDeclaration = createVariableDeclaration( _name, @@ -1423,6 +1428,7 @@ export async function deleteFromSelection( extrudeNameToDelete = dec.id.name } if ( + // TODO: This is wrong, loft is now a CallExpressionKw. dec.init.type === 'CallExpression' && dec.init.callee.name.name === 'loft' && dec.init.arguments?.[0].type === 'ArrayExpression' && @@ -1441,11 +1447,14 @@ export async function deleteFromSelection( pathToNode = selection.codeRef.pathToNode if (varDec.node.type === 'VariableDeclarator') { extrudeNameToDelete = varDec.node.id.name - } else if (varDec.node.type === 'CallExpression') { - const callExp = getNodeFromPath( + } else if ( + varDec.node.type === 'CallExpression' || + varDec.node.type === 'CallExpressionKw' + ) { + const callExp = getNodeFromPath( astClone, pathToNode, - 'CallExpression' + ['CallExpression', 'CallExpressionKw'] ) if (err(callExp)) return callExp extrudeNameToDelete = callExp.node.callee.name.name @@ -1646,7 +1655,7 @@ export async function deleteFromSelection( pipeBody[0].type === 'CallExpressionKw') && doNotDeleteProfileIfItHasBeenExtruded && (pipeBody[0].callee.name.name === 'startSketchOn' || - pipeBody[0].callee.name.name === 'startProfileAt') + pipeBody[0].callee.name.name === 'startProfile') ) { // remove varDec const varDecIndex = varDec.shallowPath[1][0] as number @@ -1749,7 +1758,7 @@ export function updateSketchNodePathsWithInsertIndex({ * Split the following pipe expression into * ```ts * part001 = startSketchOn(XZ) - |> startProfileAt([1, 2], %) + |> startProfile(at = [1, 2]) |> line([3, 4], %) |> line([5, 6], %) |> close(%) @@ -1758,7 +1767,7 @@ extrude001 = extrude(5, part001) into ```ts sketch001 = startSketchOn(XZ) -part001 = startProfileAt([1, 2], sketch001) +part001 = startProfile(sketch001, at = [1, 2]) |> line([3, 4], %) |> line([5, 6], %) |> close(%) @@ -1796,7 +1805,7 @@ export function splitPipedProfile( if (!isCallExprWithName(firstCall, 'startSketchOn')) return new Error('First call is not startSketchOn') const secondCall = init.body[1] - if (!isCallExprWithName(secondCall, 'startProfileAt')) + if (!isCallExprWithName(secondCall, 'startProfile')) return new Error('Second call is not startProfileAt') const varName = varDec.node.declaration.id.name @@ -1821,14 +1830,14 @@ export function splitPipedProfile( if ( !( profileBrokenIntoItsOwnVar.declaration.init.body[0].type === - 'CallExpression' && + 'CallExpressionKw' && profileBrokenIntoItsOwnVar.declaration.init.body[0].callee.name.name === - 'startProfileAt' + 'startProfile' ) ) { return new Error('problem breaking pipe, expect startProfileAt to be first') } - profileBrokenIntoItsOwnVar.declaration.init.body[0].arguments[1] = + profileBrokenIntoItsOwnVar.declaration.init.body[0].unlabeled = createLocalName(newVarName) profileBrokenIntoItsOwnVar.declaration.id.name = varName profileBrokenIntoItsOwnVar.preComments = [] // we'll duplicate the comments since the new variable will have it to diff --git a/src/lang/modifyAst/addEdgeTreatment.test.ts b/src/lang/modifyAst/addEdgeTreatment.test.ts index b35103c06..7c86739dd 100644 --- a/src/lang/modifyAst/addEdgeTreatment.test.ts +++ b/src/lang/modifyAst/addEdgeTreatment.test.ts @@ -181,7 +181,7 @@ const runGetPathToExtrudeForSegmentSelectionTest = async ( describe('Testing getPathToExtrudeForSegmentSelection', () => { it('should return the correct paths for a valid selection and extrusion', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -198,7 +198,7 @@ extrude001 = extrude(sketch001, length = -15)` }, 5_000) it('should return the correct paths when extrusion occurs within the sketch pipe', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -215,21 +215,21 @@ extrude001 = extrude(sketch001, length = -15)` }, 5_000) it('should return the correct paths for a valid selection and extrusion in case of several extrusions and sketches', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-30, 30], %) + |> startProfile(at = [-30, 30]) |> line(end = [15, 0]) |> line(end = [0, -15]) |> line(end = [-15, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(XY) - |> startProfileAt([30, 30], %) + |> startProfile(at = [30, 30]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(XY) - |> startProfileAt([30, -30], %) + |> startProfile(at = [30, -30]) |> line(end = [25, 0]) |> line(end = [0, -25]) |> line(end = [-25, 0]) @@ -248,7 +248,7 @@ extrude003 = extrude(sketch003, length = -15)` }) it('should return the correct paths for a (piped) extrude based on the other body (face)', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-25, -25], %) + |> startProfile(at = [-25, -25]) |> yLine(length = 50) |> xLine(length = 50) |> yLine(length = -50) @@ -256,7 +256,7 @@ extrude003 = extrude(sketch003, length = -15)` |> close() |> extrude(length = 50) sketch002 = startSketchOn(sketch001, face = 'END') - |> startProfileAt([-15, -15], %) + |> startProfile(at = [-15, -15]) |> yLine(length = 30) |> xLine(length = 30) |> yLine(length = -30) @@ -273,7 +273,7 @@ sketch002 = startSketchOn(sketch001, face = 'END') }) it('should return the correct paths for a (non-piped) extrude based on the other body (face)', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-25, -25], %) + |> startProfile(at = [-25, -25]) |> yLine(length = 50) |> xLine(length = 50) |> yLine(length = -50) @@ -281,7 +281,7 @@ sketch002 = startSketchOn(sketch001, face = 'END') |> close() extrude001 = extrude(sketch001, length = 50) sketch002 = startSketchOn(extrude001, face = 'END') - |> startProfileAt([-15, -15], %) + |> startProfile(at = [-15, -15]) |> yLine(length = 30) |> xLine(length = 30) |> yLine(length = -30) @@ -298,21 +298,21 @@ extrude002 = extrude(sketch002, length = 30)` }) it('should not return any path for missing extrusion', async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-30, 30], %) + |> startProfile(at = [-30, 30]) |> line(end = [15, 0]) |> line(end = [0, -15]) |> line(end = [-15, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch002 = startSketchOn(XY) - |> startProfileAt([30, 30], %) + |> startProfile(at = [30, 30]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(XY) - |> startProfileAt([30, -30], %) + |> startProfile(at = [30, -30]) |> line(end = [25, 0]) |> line(end = [0, -25]) |> line(end = [-25, 0]) @@ -458,7 +458,7 @@ Object.values(EdgeTreatmentType).forEach( describe(`Testing modifyAstCloneWithEdgeTreatmentAndTag with ${edgeTreatmentType}s`, () => { it(`should add a ${edgeTreatmentType} to a specific segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -467,7 +467,7 @@ Object.values(EdgeTreatmentType).forEach( extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [0, -20])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) |> line(end = [-20, 0]) @@ -485,7 +485,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} to the sketch pipe`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -494,7 +494,7 @@ extrude001 = extrude(sketch001, length = -15) |> extrude(length = -15)` const segmentSnippets = ['line(end = [0, -20])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) |> line(end = [-20, 0]) @@ -512,7 +512,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} to an already tagged segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) |> line(end = [-20, 0]) @@ -521,7 +521,7 @@ extrude001 = extrude(sketch001, length = -15) extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [0, -20], tag = $seg01)'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) |> line(end = [-20, 0]) @@ -539,7 +539,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} with existing tag on other segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -548,7 +548,7 @@ extrude001 = extrude(sketch001, length = -15) extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [-20, 0])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -566,7 +566,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} with existing fillet on other segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -576,7 +576,7 @@ extrude001 = extrude(sketch001, length = -15) |> fillet( radius = 5, tags = [seg01] )` const segmentSnippets = ['line(end = [-20, 0])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -595,7 +595,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} with existing chamfer on other segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -605,7 +605,7 @@ extrude001 = extrude(sketch001, length = -15) |> chamfer(length = 5, tags = [seg01])` const segmentSnippets = ['line(end = [-20, 0])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -624,7 +624,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add a ${edgeTreatmentType} to two segments of a single extrusion`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -633,7 +633,7 @@ extrude001 = extrude(sketch001, length = -15) extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [20, 0])', 'line(end = [-20, 0])'] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -651,7 +651,7 @@ extrude001 = extrude(sketch001, length = -15) }) it(`should add ${edgeTreatmentType}s to two bodies`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -659,7 +659,7 @@ extrude001 = extrude(sketch001, length = -15) |> close() extrude001 = extrude(sketch001, length = -15) sketch002 = startSketchOn(XY) - |> startProfileAt([30, 10], %) + |> startProfile(at = [30, 10]) |> line(end = [15, 0]) |> line(end = [0, -15]) |> line(end = [-15, 0]) @@ -672,7 +672,7 @@ extrude002 = extrude(sketch002, length = -25)` // <--- body 2 'line(end = [0, -15])', ] const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -681,7 +681,7 @@ extrude002 = extrude(sketch002, length = -25)` // <--- body 2 extrude001 = extrude(sketch001, length = -15) |> ${edgeTreatmentType}(${parameterName} = 3, tags = [seg01, seg02]) sketch002 = startSketchOn(XY) - |> startProfileAt([30, 10], %) + |> startProfile(at = [30, 10]) |> line(end = [15, 0]) |> line(end = [0, -15], tag = $seg03) |> line(end = [-15, 0]) @@ -702,7 +702,7 @@ extrude002 = extrude(sketch002, length = -25) // simple cases it(`should delete a piped ${edgeTreatmentType} from a single segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -712,7 +712,7 @@ extrude001 = extrude(sketch001, length = -15) |> ${edgeTreatmentType}(${parameterName} = 3, tags = [seg01])` const edgeTreatmentSnippet = `${edgeTreatmentType}(${parameterName} = 3, tags = [seg01])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -728,7 +728,7 @@ extrude001 = extrude(sketch001, length = -15)` }) it(`should delete a non-piped ${edgeTreatmentType} from a single segment`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -738,7 +738,7 @@ extrude001 = extrude(sketch001, length = -15) fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [seg01])` const edgeTreatmentSnippet = `fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [seg01])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -755,7 +755,7 @@ extrude001 = extrude(sketch001, length = -15)` // getOppositeEdge and getNextAdjacentEdge cases it(`should delete a piped ${edgeTreatmentType} tagged with getOppositeEdge`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -765,7 +765,7 @@ extrude001 = extrude(sketch001, length = -15) fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [getOppositeEdge(seg01)])` const edgeTreatmentSnippet = `fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [getOppositeEdge(seg01)])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -781,7 +781,7 @@ extrude001 = extrude(sketch001, length = -15)` }) it(`should delete a non-piped ${edgeTreatmentType} tagged with getNextAdjacentEdge`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -791,7 +791,7 @@ extrude001 = extrude(sketch001, length = -15) fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [getNextAdjacentEdge(seg01)])` const edgeTreatmentSnippet = `fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 3, tags = [getNextAdjacentEdge(seg01)])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg01) @@ -808,7 +808,7 @@ extrude001 = extrude(sketch001, length = -15)` // cases with several edge treatments it(`should delete a piped ${edgeTreatmentType} from a body with multiple treatments`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -821,7 +821,7 @@ fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 6, tags = [seg02 chamfer001 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg01)])` const edgeTreatmentSnippet = `${edgeTreatmentType}(${parameterName} = 3, tags = [seg01])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -840,7 +840,7 @@ chamfer001 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg01)])` }) it(`should delete a non-piped ${edgeTreatmentType} from a body with multiple treatments`, async () => { const code = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -853,7 +853,7 @@ fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 6, tags = [seg02 chamfer001 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg01)])` const edgeTreatmentSnippet = `fillet001 = ${edgeTreatmentType}(extrude001, ${parameterName} = 6, tags = [seg02])` const expectedCode = `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) |> line(end = [-20, 0], tag = $seg02) @@ -876,7 +876,7 @@ chamfer001 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg01)])` describe('Testing isTagUsedInEdgeTreatment', () => { const code = `sketch001 = startSketchOn(XZ) - |> startProfileAt([7.72, 4.13], %) + |> startProfile(at = [7.72, 4.13]) |> line(end = [7.11, 3.48], tag = $seg01) |> line(end = [-3.29, -13.85]) |> line(end = [-6.37, 3.88], tag = $seg02) @@ -980,7 +980,7 @@ describe('Testing button states', () => { } const codeWithBody: string = ` sketch001 = startSketchOn(XY) - |> startProfileAt([-20, -5], %) + |> startProfile(at = [-20, -5]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) @@ -990,7 +990,7 @@ describe('Testing button states', () => { ` const codeWithoutBodies: string = ` sketch001 = startSketchOn(XY) - |> startProfileAt([-20, -5], %) + |> startProfile(at = [-20, -5]) |> line(end = [0, 10]) |> line(end = [10, 0]) |> line(end = [0, -10]) diff --git a/src/lang/queryAst.test.ts b/src/lang/queryAst.test.ts index edf63fd06..f6d0716f2 100644 --- a/src/lang/queryAst.test.ts +++ b/src/lang/queryAst.test.ts @@ -45,7 +45,7 @@ arrExpShouldNotBeIncluded = [1, 2, 3] objExpShouldNotBeIncluded = { a: 1, b: 2, c: 3 } part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> yLine(endAbsolute = 1) |> xLine(length = 3.84) // selection-range-7ish-before-this @@ -76,7 +76,7 @@ variableBelowShouldNotBeIncluded = 3 describe('testing argIsNotIdentifier', () => { const code = `part001 = startSketchOn(XY) -|> startProfileAt([-1.2, 4.83], %) +|> startProfile(at = [-1.2, 4.83]) |> line(end = [2.8, 0]) |> angledLine(angle = 100 + 100, length = 3.09) |> angledLine(angle = abc, length = 3.09) @@ -236,7 +236,7 @@ yo2 = hmm([identifierGuy + 5])` describe('testing getNodePathFromSourceRange', () => { const code = `part001 = startSketchOn(XY) - |> startProfileAt([0.39, -0.05], %) + |> startProfile(at = [0.39, -0.05]) |> line(end = [0.94, 2.61]) |> line(end = [-0.21, -1.4])` it('finds the second line when cursor is put at the end', () => { @@ -380,7 +380,7 @@ describe('testing hasExtrudeSketch', () => { it('find sketch', async () => { const exampleCode = `length001 = 2 part001 = startSketchOn(XY) - |> startProfileAt([-1.41, 3.46], %) + |> startProfile(at = [-1.41, 3.46]) |> line(end = [19.49, 1.16], tag = $seg01) |> angledLine(angle = -35, length = length001) |> line(end = [-3.22, -7.36]) @@ -400,7 +400,7 @@ part001 = startSketchOn(XY) it('find solid', async () => { const exampleCode = `length001 = 2 part001 = startSketchOn(XY) - |> startProfileAt([-1.41, 3.46], %) + |> startProfile(at = [-1.41, 3.46]) |> line(end = [19.49, 1.16], tag = $seg01) |> angledLine(angle = -35, length = length001) |> line(end = [-3.22, -7.36]) @@ -436,7 +436,7 @@ part001 = startSketchOn(XY) describe('Testing findUsesOfTagInPipe', () => { const exampleCode = `part001 = startSketchOn(-XZ) -|> startProfileAt([68.12, 156.65], %) +|> startProfile(at = [68.12, 156.65]) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.85], tag = $seg01) |> angledLine(angle = -65, length = segLen(seg01)) @@ -475,7 +475,7 @@ describe('Testing findUsesOfTagInPipe', () => { describe('Testing hasSketchPipeBeenExtruded', () => { const exampleCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) |> line(end = [3.75, 0.46]) @@ -489,13 +489,13 @@ describe('Testing hasSketchPipeBeenExtruded', () => { |> close() extrude001 = extrude(sketch001, length = 10) sketch002 = startSketchOn(extrude001, face = seg01) - |> startProfileAt([-12.94, 6.6], %) + |> startProfile(at = [-12.94, 6.6]) |> line(end = [2.45, -0.2]) |> line(end = [-2, -1.25]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(extrude001, face = 'END') - |> startProfileAt([8.14, 2.8], %) + |> startProfile(at = [8.14, 2.8]) |> line(end = [-1.24, 4.39]) |> line(end = [3.79, 1.91]) |> line(end = [1.77, -2.95]) @@ -559,14 +559,14 @@ sketch003 = startSketchOn(extrude001, face = 'END') describe('Testing doesSceneHaveSweepableSketch', () => { it('finds sketch001 pipe to be extruded', async () => { const exampleCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) |> line(end = [-17.67, 0.85]) |> close() extrude001 = extrude(sketch001, length = 10) sketch002 = startSketchOn(extrude001, face = $seg01) - |> startProfileAt([-12.94, 6.6], %) + |> startProfile(at = [-12.94, 6.6]) |> line(end = [2.45, -0.2]) |> line(end = [-2, -1.25]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -589,7 +589,7 @@ sketch002 = startSketchOn(plane001) }) it('should recognize that sketch001 has been extruded', async () => { const exampleCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) |> line(end = [-17.67, 0.85]) @@ -644,7 +644,7 @@ describe('Testing traverse and pathToNode', () => { ])('testing %s', async (testName, literalOfInterest) => { const code = `myVar = 5 sketch001 = startSketchOn(XZ) - |> startProfileAt([3.29, 7.86], %) + |> startProfile(at = [3.29, 7.86]) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) |> line(end = [-17.67, 0.85]) @@ -686,7 +686,7 @@ myNestedVar = [ describe('Testing specific sketch getNodeFromPath workflow', () => { it('should parse the code', () => { const openSketch = `sketch001 = startSketchOn(XZ) -|> startProfileAt([0.02, 0.22], %) +|> startProfile(at = [0.02, 0.22]) |> xLine(length = 0.39) |> line([0.02, -0.17], %) |> yLine(length = -0.15) @@ -700,7 +700,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { }) it('should find the location to add new lineTo', () => { const openSketch = `sketch001 = startSketchOn(XZ) -|> startProfileAt([0.02, 0.22], %) +|> startProfile(at = [0.02, 0.22]) |> xLine(length = 0.39) |> line([0.02, -0.17], %) |> yLine(length = -0.15) @@ -710,7 +710,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { |> line([-0.08, 0.05], %)` const ast = assertParse(openSketch) - const sketchSnippet = `startProfileAt([0.02, 0.22], %)` + const sketchSnippet = `startProfile(at = [0.02, 0.22])` const sketchRange = topLevelRange( openSketch.indexOf(sketchSnippet), openSketch.indexOf(sketchSnippet) + sketchSnippet.length @@ -740,7 +740,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { if (err(modifiedAst)) throw modifiedAst const recasted = recast(modifiedAst) const expectedCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0.02, 0.22], %) + |> startProfile(at = [0.02, 0.22]) |> xLine(length = 0.39) |> line([0.02, -0.17], %) |> yLine(length = -0.15) @@ -754,7 +754,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { }) it('it should find the location to add close', () => { const openSketch = `sketch001 = startSketchOn(XZ) -|> startProfileAt([0.02, 0.22], %) +|> startProfile(at = [0.02, 0.22]) |> xLine(length = 0.39) |> line([0.02, -0.17], %) |> yLine(length = -0.15) @@ -765,7 +765,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { |> lineTo([profileStartX(%), profileStartY(%)], %) ` const ast = assertParse(openSketch) - const sketchSnippet = `startProfileAt([0.02, 0.22], %)` + const sketchSnippet = `startProfile(at = [0.02, 0.22])` const sketchRange = topLevelRange( openSketch.indexOf(sketchSnippet), openSketch.indexOf(sketchSnippet) + sketchSnippet.length @@ -780,7 +780,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { if (err(modifiedAst)) throw modifiedAst const recasted = recast(modifiedAst) const expectedCode = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0.02, 0.22], %) + |> startProfile(at = [0.02, 0.22]) |> xLine(length = 0.39) |> line([0.02, -0.17], %) |> yLine(length = -0.15) diff --git a/src/lang/queryAst.ts b/src/lang/queryAst.ts index 083c7706f..c70b883c1 100644 --- a/src/lang/queryAst.ts +++ b/src/lang/queryAst.ts @@ -816,7 +816,7 @@ export function doesSceneHaveSweepableSketch(ast: Node, count = 1) { if ( (pipe.type === 'CallExpressionKw' || pipe.type === 'CallExpression') && - pipe.callee.name.name === 'startProfileAt' + pipe.callee.name.name === 'startProfile' ) { hasStartProfileAt = true } @@ -964,7 +964,7 @@ export function doesSketchPipeNeedSplitting( if (!firstPipe || !secondPipe) return false if ( isCallExprWithName(firstPipe, 'startSketchOn') && - isCallExprWithName(secondPipe, 'startProfileAt') + isCallExprWithName(secondPipe, 'startProfile') ) return true return false diff --git a/src/lang/queryAst/getSafeInsertIndex.test.ts b/src/lang/queryAst/getSafeInsertIndex.test.ts index 3dd4c093f..b7f6af92f 100644 --- a/src/lang/queryAst/getSafeInsertIndex.test.ts +++ b/src/lang/queryAst/getSafeInsertIndex.test.ts @@ -16,7 +16,7 @@ z = x + y`) }) it(`expression with no identifiers in longer program`, () => { const baseProgram = assertParse(`x = 5 + 2 - profile001 = startProfileAt([0.07, 0], sketch001) + profile001 = startProfile(sketch001, at = [0.07, 0]) |> angledLine(angle = 0, length = x, tag = $a) |> angledLine(angle = segAng(a) + 90, length = 5) |> angledLine(angle = segAng(a), length = -segLen(a)) @@ -41,7 +41,7 @@ z = x + y`) }) it(`expression with a tag declarator add to end`, () => { const baseProgram = assertParse(`x = 5 + 2 - profile001 = startProfileAt([0.07, 0], sketch001) + profile001 = startProfile(sketch001, at = [0.07, 0]) |> angledLine(angle = 0, length = x, tag = $a) |> angledLine(angle = segAng(a) + 90, length = 5) |> angledLine(angle = segAng(a), length = -segLen(a)) @@ -52,7 +52,7 @@ z = x + y`) }) it(`expression with a tag declarator and variable in the middle`, () => { const baseProgram = assertParse(`x = 5 + 2 - profile001 = startProfileAt([0.07, 0], sketch001) + profile001 = startProfile(sketch001, at = [0.07, 0]) |> angledLine(angle = 0, length = x, tag = $a) |> angledLine(angle = segAng(a) + 90, length = 5) |> angledLine(angle = segAng(a), length = -segLen(a)) diff --git a/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts b/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts index 1db2a8575..de8e54a6f 100644 --- a/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts +++ b/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts @@ -32,14 +32,14 @@ describe(`getTagDeclaratorsInProgram`, () => { it(`finds a single tag declarators in a small program`, () => { const tagDeclarators = getTagDeclaratorsInProgram( assertParse(`sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([0, 0], sketch001) +profile001 = startProfile(sketch001, at = [0, 0]) |> angledLine(angle = 0, length = 11, tag = $a)`) ) - expect(tagDeclarators).toEqual([tagDeclaratorWithIndex('a', 123, 125, 1)]) + expect(tagDeclarators).toEqual([tagDeclaratorWithIndex('a', 126, 128, 1)]) }) it(`finds multiple tag declarators in a small program`, () => { const program = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([0.07, 0], sketch001) +profile001 = startProfile(sketch001, at = [0.07, 0]) |> angledLine(angle = 0, length = 11, tag = $a) |> angledLine(angle = segAng(a) + 90, length = 11.17, tag = $b) |> angledLine(angle = segAng(a), length = -segLen(a), tag = $c) @@ -47,14 +47,14 @@ profile001 = startProfileAt([0.07, 0], sketch001) |> close()` const tagDeclarators = getTagDeclaratorsInProgram(assertParse(program)) expect(tagDeclarators).toEqual([ - tagDeclaratorWithIndex('a', 126, 128, 1), - tagDeclaratorWithIndex('b', 192, 194, 1), - tagDeclaratorWithIndex('c', 258, 260, 1), + tagDeclaratorWithIndex('a', 129, 131, 1), + tagDeclaratorWithIndex('b', 195, 197, 1), + tagDeclaratorWithIndex('c', 261, 263, 1), ]) }) it(`finds tag declarators at different indices`, () => { const program = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([0.07, 0], sketch001) +profile001 = startProfile(sketch001, at = [0.07, 0]) |> angledLine(angle = 0, length = 11, tag = $a) profile002 = angledLine(profile001, angle = segAng(a) + 90, length = 11.17, tag = $b) |> angledLine(angle = segAng(a), length = -segLen(a), tag = $c) @@ -62,9 +62,9 @@ profile002 = angledLine(profile001, angle = segAng(a) + 90, length = 11.17, tag |> close()` const tagDeclarators = getTagDeclaratorsInProgram(assertParse(program)) expect(tagDeclarators).toEqual([ - tagDeclaratorWithIndex('a', 126, 128, 1), - tagDeclaratorWithIndex('b', 212, 214, 2), - tagDeclaratorWithIndex('c', 278, 280, 2), + tagDeclaratorWithIndex('a', 129, 131, 1), + tagDeclaratorWithIndex('b', 215, 217, 2), + tagDeclaratorWithIndex('c', 281, 283, 2), ]) }) }) diff --git a/src/lang/recast.test.ts b/src/lang/recast.test.ts index d5b4b73e7..916e8937a 100644 --- a/src/lang/recast.test.ts +++ b/src/lang/recast.test.ts @@ -79,7 +79,7 @@ log(5, myVar) }) it('recast sketch declaration', () => { let code = `mySketch = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [0, 1], tag = $myPath) |> line(endAbsolute = [1, 1]) |> line(endAbsolute = [1, 0], tag = $rightPath) @@ -93,7 +93,7 @@ log(5, myVar) it('sketch piped into callExpression', () => { const code = [ 'mySk1 = startSketchOn(XY)', - ' |> startProfileAt([0, 0], %)', + ' |> startProfile(at = [0, 0])', ' |> line(endAbsolute = [1, 1])', ' |> line(endAbsolute = [0, 1], tag = $myTag)', ' |> line(endAbsolute = [1, 1])', @@ -239,7 +239,7 @@ key = 'c' it('comments in a pipe expression', () => { const code = [ 'mySk1 = startSketchOn(XY)', - ' |> startProfileAt([0, 0], %)', + ' |> startProfile(at = [0, 0])', ' |> line(endAbsolute = [1, 1])', ' |> line(endAbsolute = [0, 1], tag = $myTag)', ' |> line(endAbsolute = [1, 1])', @@ -256,7 +256,7 @@ key = 'c' /* comment at start */ mySk1 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 1]) // comment here |> line(endAbsolute = [0, 1], tag = $myTag) @@ -280,7 +280,7 @@ one more for good measure expect(recasted).toBe(`/* comment at start */ mySk1 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 1]) // comment here |> line(endAbsolute = [0, 1], tag = $myTag) @@ -321,7 +321,7 @@ describe('testing call Expressions in BinaryExpressions and UnaryExpressions', ( it('with unaryExpression in sketch situation', () => { const code = [ 'part001 = startSketchOn(XY)', - ' |> startProfileAt([0, 0])', + ' |> startProfile(at = [0, 0])', ' |> line(end = [\n -2.21,\n -legLen(hypotenuse = 5, leg = min(3, 999))\n ])', ].join('\n') const { ast } = code2ast(code) @@ -334,7 +334,7 @@ describe('testing call Expressions in BinaryExpressions and UnaryExpressions', ( describe('it recasts wrapped object expressions in pipe bodies with correct indentation', () => { it('with a single line', () => { const code = `part001 = startSketchOn(XY) - |> startProfileAt([-0.01, -0.08], %) + |> startProfile(at = [-0.01, -0.08]) |> line(end = [0.62, 4.15], tag = $seg01) |> line(end = [2.77, -1.24]) |> angledLineThatIntersects(angle = 201, offset = -1.35, intersectTag = $seg01) diff --git a/src/lang/std/sketch.test.ts b/src/lang/std/sketch.test.ts index a8b28a80c..4810ce854 100644 --- a/src/lang/std/sketch.test.ts +++ b/src/lang/std/sketch.test.ts @@ -108,7 +108,7 @@ describe('testing changeSketchArguments', () => { test('changeSketchArguments', async () => { // Enable rotations #152 const genCode = (line: string) => `mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> ${line} |> line(endAbsolute = [0.46, -5.82]) // |> rx(45, %) @@ -146,7 +146,7 @@ describe('testing addNewSketchLn', () => { // Enable rotations #152 const code = ` mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82])` @@ -175,7 +175,7 @@ mySketch001 = startSketchOn(XY) // Enable rotations #152 let expectedCode = `mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) @@ -198,7 +198,7 @@ mySketch001 = startSketchOn(XY) if (err(modifiedAst2)) return modifiedAst2 expectedCode = `mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) @@ -213,7 +213,7 @@ describe('testing addTagForSketchOnFace', () => { const originalLine = 'line(endAbsolute = [-1.59, -1.54])' // Enable rotations #152 const genCode = (line: string) => `mySketch001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) // |> rx(45, %) |> ${line} |> line(endAbsolute = [0.46, -5.82]) @@ -273,7 +273,7 @@ describe('testing addTagForSketchOnFace', () => { chamferTestCases.forEach(({ originalChamfer, expectedChamfer, desc }) => { it(`can break up chamfers in order to add tags - ${desc}`, async () => { const genCode = (insertCode: string) => `sketch001 = startSketchOn(XZ) - |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] + |> startProfile(at = [75.8, 317.2]) // [$startCapTag, $EndCapTag] |> angledLine(angle = 0, length = 268.43, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) - 90, length = 217.26, tag = $seg01) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001)) @@ -318,7 +318,7 @@ ${insertCode} describe('testing getConstraintInfo', () => { describe('object notation', () => { const code = `const part001 = startSketchOn(-XZ) - |> startProfileAt([0,0], %) + |> startProfile(at = [0,0]) |> line(end = [3, 4]) |> angledLine(angle = 3.14, length = 3.14) |> line(endAbsolute = [6.14, 3.14]) @@ -684,7 +684,7 @@ describe('testing getConstraintInfo', () => { }) describe('array notation', () => { const code = `const part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3, 4]) |> angledLine(angle = 3.14, length = 3.14) |> line(endAbsolute = [6.14, 3.14]) @@ -845,7 +845,7 @@ describe('testing getConstraintInfo', () => { }) describe('constrained', () => { const code = `const part001 = startSketchOn(-XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [3 + 0, 4 + 0]) |> angledLine(angle = 3.14 + 0, length = 3.14 + 0 ) |> line(endAbsolute = [6.14 + 0, 3.14 + 0]) diff --git a/src/lang/std/sketch.ts b/src/lang/std/sketch.ts index 693dd567f..0a17ece89 100644 --- a/src/lang/std/sketch.ts +++ b/src/lang/std/sketch.ts @@ -5,6 +5,7 @@ import type { Node } from '@rust/kcl-lib/bindings/Node' import { ARG_ANGLE, ARG_ANGLE_END, + ARG_AT, ARG_ANGLE_START, ARG_CIRCLE_CENTER, ARG_RADIUS, @@ -37,9 +38,7 @@ import { import type { ToolTip } from '@src/lang/langHelpers' import { toolTips } from '@src/lang/langHelpers' import { - mutateArrExp, mutateKwArg, - mutateObjExpProp, removeKwArgs, splitPathAtPipeExpression, } from '@src/lang/modifyAst' @@ -2956,7 +2955,7 @@ export const updateStartProfileAtArgs: SketchLineHelper['updateArgs'] = ({ if (input.type !== 'straight-segment') return STRAIGHT_SEGMENT_ERR const { to } = input const _node = { ...node } - const nodeMeta = getNodeFromPath(_node, pathToNode) + const nodeMeta = getNodeFromPath(_node, pathToNode) if (err(nodeMeta)) { console.error(nodeMeta) return { @@ -2989,8 +2988,7 @@ export const updateStartProfileAtArgs: SketchLineHelper['updateArgs'] = ({ createLiteral(roundOff(to[1])), ]) - mutateArrExp(callExpression.arguments?.[0], toArrExp) || - mutateObjExpProp(callExpression.arguments?.[0], toArrExp, 'to') + mutateKwArg(ARG_AT, callExpression, toArrExp) return { modifiedAst: _node, pathToNode, diff --git a/src/lang/std/sketchConstraints.test.ts b/src/lang/std/sketchConstraints.test.ts index e8af339fa..92178e14c 100644 --- a/src/lang/std/sketchConstraints.test.ts +++ b/src/lang/std/sketchConstraints.test.ts @@ -69,7 +69,7 @@ async function testingSwapSketchFnCall({ describe('testing swapping out sketch calls with xLine/xLineTo', () => { const bigExampleArr = [ `part001 = startSketchOn(XY)`, - ` |> startProfileAt([0, 0], %)`, + ` |> startProfile(at = [0, 0])`, ` |> line(endAbsolute = [1, 1], tag = $abc1)`, ` |> line(end = [-2.04, -0.7], tag = $abc2)`, ` |> angledLine(angle = 157, length = 1.69, tag = $abc3)`, @@ -264,7 +264,7 @@ describe('testing swapping out sketch calls with xLine/xLineTo while keeping var `angledLineToXx = -1.86`, `angledLineToYy = -0.76`, `part001 = startSketchOn(XY)`, - ` |> startProfileAt([0, 0], %)`, + ` |> startProfile(at = [0, 0])`, // ` |> rx(90, %)`, ` |> line(endAbsolute = [1, 1])`, ` |> line(end = [lineX, 2.13])`, @@ -358,7 +358,7 @@ describe('testing swapping out sketch calls with xLine/xLineTo while keeping var describe('testing getSketchSegmentIndexFromSourceRange', () => { const code = ` part001 = startSketchOn(XY) - |> startProfileAt([0, 0.04], %) // segment-in-start + |> startProfile(at = [0, 0.04]) // segment-in-start |> line(end = [0, 0.4]) |> xLine(length = 3.48) |> line(end = [2.14, 1.35]) // normal-segment diff --git a/src/lang/std/sketchConstraints.ts b/src/lang/std/sketchConstraints.ts index f80d3155e..ae19e2155 100644 --- a/src/lang/std/sketchConstraints.ts +++ b/src/lang/std/sketchConstraints.ts @@ -95,7 +95,7 @@ export function isSketchVariablesLinked( to check or it finds a match. that way it can find fn calls that are linked to each other through variables eg: const part001 = startSketchOn(XY) - |> startProfileAt([0, 0],%) + |> startProfile(at=[0, 0]) |> xLine(endAbsolute = 1.69) |> line(end = [myVar, 0.38]) // ❗️ <- cursor in this fn call (the primary) |> line(end = [0.41, baz]) diff --git a/src/lang/std/sketchcombos.test.ts b/src/lang/std/sketchcombos.test.ts index a9bacba5b..c45a21b16 100644 --- a/src/lang/std/sketchcombos.test.ts +++ b/src/lang/std/sketchcombos.test.ts @@ -179,14 +179,14 @@ function makeSelections( describe('testing transformAstForSketchLines for equal length constraint', () => { describe(`should always reorder selections to have the base selection first`, () => { const inputScript = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 5]) |> line(end = [-2, 5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close()` const expectedModifiedScript = `sketch001 = startSketchOn(XZ) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [5, 5], tag = $seg01) |> angledLine(angle = 112, length = segLen(seg01)) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -267,7 +267,7 @@ myVar3 = 6 myAng = 40 myAng2 = 134 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [1, 3.82]) // ln-should-get-tag |> line(endAbsolute = [2, 4]) // ln-lineTo-free should become angledLine |> angledLine(angle = 45, endAbsoluteX = 2.5) // ln-angledLineToX-free should become angledLine @@ -299,7 +299,7 @@ myVar3 = 6 myAng = 40 myAng2 = 134 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [1, 3.82], tag = $seg01) // ln-should-get-tag |> angledLine(angle = 10, length = segLen(seg01)) // ln-lineTo-free should become angledLine |> angledLine(angle = 45, length = segLen(seg01)) // ln-angledLineToX-free should become angledLine @@ -376,7 +376,7 @@ describe('testing transformAstForSketchLines for vertical and horizontal constra myVar2 = 12 myVar3 = -10 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 1]) |> line(end = [-6.28, 1.4]) // select for horizontal constraint 1 |> line(end = [-1.07, myVar]) // select for vertical constraint 1 @@ -404,7 +404,7 @@ part001 = startSketchOn(XY) myVar2 = 12 myVar3 = -10 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 1]) |> xLine(length = -6.28) // select for horizontal constraint 1 |> line(end = [-1.07, myVar]) // select for vertical constraint 1 @@ -464,7 +464,7 @@ part001 = startSketchOn(XY) myVar2 = 12 myVar3 = -10 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [1, 1]) |> line(end = [-6.28, 1.4]) // select for horizontal constraint 1 |> yLine(length = myVar) // select for vertical constraint 1 @@ -525,7 +525,7 @@ describe('testing transformAstForSketchLines for vertical and horizontal distanc describe('testing setHorzDistance for line', () => { const inputScript = `myVar = 1 part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(end = [0.31, 1.67]) // base selection |> line(end = [0.45, 1.46]) |> line(end = [0.45, 1.46]) // free @@ -631,7 +631,7 @@ halfHeight = totalHeight / 2 halfArmAngle = armAngle / 2 part001 = startSketchOn(XY) - |> startProfileAt([-0.01, -0.05], %) + |> startProfile(at = [-0.01, -0.05]) |> line(end = [0.01, 0.94 + 0]) // partial |> xLine(length = 3.03) // partial |> angledLine({ diff --git a/src/lang/std/sketchcombos.ts b/src/lang/std/sketchcombos.ts index 1d1f09ec9..0d8d71772 100644 --- a/src/lang/std/sketchcombos.ts +++ b/src/lang/std/sketchcombos.ts @@ -1702,6 +1702,9 @@ function getTransformMapPathKw( } return false } + if (name === 'startProfile') { + return false + } const tooltip = fnNameToTooltip(allLabels(sketchFnExp), name) if (err(tooltip)) { return false diff --git a/src/lang/std/std.test.ts b/src/lang/std/std.test.ts index 6d40d3985..ad586c776 100644 --- a/src/lang/std/std.test.ts +++ b/src/lang/std/std.test.ts @@ -9,7 +9,7 @@ beforeAll(async () => { describe('testing angledLineThatIntersects', () => { it('angledLineThatIntersects should intersect with another line', async () => { const code = (offset: string) => `part001 = startSketchOn(XY) - |> startProfileAt([0, 0], %) + |> startProfile(at = [0, 0]) |> line(endAbsolute = [2, 2], tag = $yo) |> line(endAbsolute = [3, 1]) |> angledLineThatIntersects( diff --git a/src/lib/promptToEdit.ts b/src/lib/promptToEdit.ts index 455f9c9f8..2455a7fda 100644 --- a/src/lib/promptToEdit.ts +++ b/src/lib/promptToEdit.ts @@ -78,7 +78,7 @@ export async function submitPromptToEditToQueue({ if (artifact?.type === 'cap') { prompts.push({ prompt: `The users main selection is the end cap of a general-sweep (that is an extrusion, revolve, sweep or loft). -The source range most likely refers to "startProfileAt" simply because this is the start of the profile that was swept. +The source range most likely refers to "startProfile" simply because this is the start of the profile that was swept. If you need to operate on this cap, for example for sketching on the face, you can use the special string ${ artifact.subType === 'end' ? 'END' : 'START' } i.e. \`startSketchOn(someSweepVariable, face = ${ diff --git a/src/lib/rectangleTool.test.ts b/src/lib/rectangleTool.test.ts index 16db752b3..176d0e32b 100644 --- a/src/lib/rectangleTool.test.ts +++ b/src/lib/rectangleTool.test.ts @@ -19,7 +19,7 @@ describe('library rectangleTool helper functions', () => { test('should update AST and source code', async () => { // Base source code that will be edited in place const sourceCode = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([120.37, 162.76], %) +profile001 = startProfile(at = [120.37, 162.76]) |> angledLine(angle = 0, length = 0, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 0, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) @@ -31,7 +31,7 @@ profile001 = startProfileAt([120.37, 162.76], %) let ast = structuredClone(_ast) // Find some nodes and paths to reference - const sketchSnippet = `startProfileAt([120.37, 162.76], %)` + const sketchSnippet = `startProfile(at = [120.37, 162.76])` const start = sourceCode.indexOf(sketchSnippet) expect(start).toBeGreaterThanOrEqual(0) const sketchRange = topLevelRange(start, start + sketchSnippet.length) @@ -69,7 +69,7 @@ profile001 = startProfileAt([120.37, 162.76], %) // ast is edited in place from the updateCenterRectangleSketch const expectedSourceCode = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([80, 120], %) +profile001 = startProfile(at = [80, 120]) |> angledLine(angle = 0, length = 80, tag = $rectangleSegmentA001) |> angledLine(angle = segAng(rectangleSegmentA001) + 90, length = 120, tag = $rectangleSegmentB001) |> angledLine(angle = segAng(rectangleSegmentA001), length = -segLen(rectangleSegmentA001), tag = $rectangleSegmentC001) diff --git a/src/lib/rectangleTool.ts b/src/lib/rectangleTool.ts index f83174252..2064e8295 100644 --- a/src/lib/rectangleTool.ts +++ b/src/lib/rectangleTool.ts @@ -1,6 +1,7 @@ import type { Node } from '@rust/kcl-lib/bindings/Node' import { ARG_ANGLE, + ARG_AT, ARG_END_ABSOLUTE, ARG_LENGTH, ARG_TAG, @@ -21,7 +22,6 @@ import { mutateKwArgOnly } from '@src/lang/modifyAst' import { findKwArg, isArrayExpression, - isCallExpression, isCallExpressionKw, } from '@src/lang/util' import type { CallExpressionKw, Expr, PipeExpression } from '@src/lang/wasm' @@ -43,10 +43,10 @@ function angledLine( } /** - * It does not create the startSketchOn and it does not create the startProfileAt. + * It does not create the startSketchOn and it does not create the startProfile. * Returns AST expressions for this KCL code: * const yo = startSketchOn(XY) - * |> startProfileAt([0, 0], %) + * |> startProfile(at = [0, 0]) * |> angledLine(angle = 0, length = 0, tag = $a) * |> angledLine(angle = segAng(a) - 90, length = 0, tag = $b) * |> angledLine(angle = segAng(a), length = -segLen(a), tag = $c) @@ -149,17 +149,20 @@ export function updateCenterRectangleSketch( { let callExpression = pipeExpression.body[0] - if (!isCallExpression(callExpression)) { + if (!isCallExpressionKw(callExpression)) { return new Error(`Expected call expression, got ${callExpression.type}`) } - const arrayExpression = callExpression.arguments[0] + const arrayExpression = findKwArg(ARG_AT, callExpression) if (!isArrayExpression(arrayExpression)) { - return new Error(`Expected array expression, got ${arrayExpression.type}`) + return new Error( + `Expected array expression, got ${arrayExpression?.type}` + ) } - callExpression.arguments[0] = createArrayExpression([ + const at = createArrayExpression([ createLiteral(roundOff(startX)), createLiteral(roundOff(startY)), ]) + mutateKwArgOnly(ARG_AT, callExpression, at) } const twoX = deltaX * 2 diff --git a/src/lib/selections.test.ts b/src/lib/selections.test.ts index 41cdc82a2..d43614bb7 100644 --- a/src/lib/selections.test.ts +++ b/src/lib/selections.test.ts @@ -19,7 +19,7 @@ beforeAll(async () => { describe('testing source range to artifact conversion', () => { const MY_CODE = `sketch001 = startSketchOn(XZ) -profile001 = startProfileAt([105.55, 105.55], sketch001) +profile001 = startProfile(sketch001,at=[105.55, 105.55]) |> xLine(332.55, %, $seg01) |> yLine(-310.12, %, $seg02) |> xLine(-373.65, %) @@ -28,7 +28,7 @@ profile001 = startProfileAt([105.55, 105.55], sketch001) extrude001 = extrude(profile001, length = 500) sketch002 = startSketchOn(extrude001, seg01) -profile002 = startProfileAt([-321.34, 361.76], sketch002) +profile002 = startProfile(sketch002,at=[-321.34, 361.76]) |> line(end = [109.03, -61.79]) |> line(end = [-124.48, -132.65]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) @@ -40,7 +40,7 @@ profile006 = circle(sketch005, radius = 25.89 ) sketch004 = startSketchOn(extrude001, seg02) -profile005 = startProfileAt([36.1, 174.49], sketch004) +profile005 = startProfile(sketch004,at=[36.1, 174.49]) |> angledLine(angle = 0, length = 22.33, tag = $rectangleSegmentA003) |> angledLine( angle = segAng(rectangleSegmentA003) - 90, @@ -53,7 +53,7 @@ profile005 = startProfileAt([36.1, 174.49], sketch004) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() sketch003 = startSketchOn(extrude001, seg02) -profile003 = startProfileAt([-115.59, 439.4], sketch003) +profile003 = startProfile(sketch003,at=[-115.59, 439.4]) |> angledLine(angle = 0, length = 130.08, tag = $rectangleSegmentA002) |> angledLine( angle = segAng(rectangleSegmentA002) - 90, @@ -1170,7 +1170,7 @@ profile004 = circle(sketch003, [ 'path selection for a sketch on face', { - snippet: 'profile002 = startProfileAt([-321.34, 361.76], sketch002)', + snippet: 'profile002 = startProfile(sketch002,at=[-321.34, 361.76])', artifactDetails: { type: 'solid2d', range: [398, 398, 0], diff --git a/src/machines/modelingMachine.ts b/src/machines/modelingMachine.ts index fc36f9fb1..3329da9bd 100644 --- a/src/machines/modelingMachine.ts +++ b/src/machines/modelingMachine.ts @@ -4693,7 +4693,7 @@ export function isEditingExistingSketch({ sketchDetails: SketchDetails | null }): boolean { // should check that the variable declaration is a pipeExpression - // and that the pipeExpression contains a "startProfileAt" callExpression + // and that the pipeExpression contains a "startProfile" callExpression if (!sketchDetails?.sketchEntryNodePath) return false const variableDeclaration = getNodeFromPath( kclManager.ast, @@ -4709,7 +4709,7 @@ export function isEditingExistingSketch({ if ( (maybePipeExpression.type === 'CallExpression' || maybePipeExpression.type === 'CallExpressionKw') && - (maybePipeExpression.callee.name.name === 'startProfileAt' || + (maybePipeExpression.callee.name.name === 'startProfile' || maybePipeExpression.callee.name.name === 'circle' || maybePipeExpression.callee.name.name === 'circleThreePoint') ) @@ -4717,8 +4717,8 @@ export function isEditingExistingSketch({ if (maybePipeExpression.type !== 'PipeExpression') return false const hasStartProfileAt = maybePipeExpression.body.some( (item) => - item.type === 'CallExpression' && - item.callee.name.name === 'startProfileAt' + item.type === 'CallExpressionKw' && + item.callee.name.name === 'startProfile' ) const hasCircle = maybePipeExpression.body.some( diff --git a/src/test-utils.test.ts b/src/test-utils.test.ts index 245ee24f5..65bd523aa 100644 --- a/src/test-utils.test.ts +++ b/src/test-utils.test.ts @@ -3,7 +3,7 @@ import { normaliseKclNumbers } from '@e2e/playwright/test-utils' test('normaliseKclNumbers', () => { expect( normaliseKclNumbers(`sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -11,7 +11,7 @@ test('normaliseKclNumbers', () => { |> close() const extrude001 = extrude(sketch001, length = -15)`) ).toBe(`sketch001 = startSketchOn(XY) - |> startProfileAt([-12.34, 12.34], %) + |> startProfile(at = [-12.34, 12.34]) |> line(end = [12.34, 0]) |> line(end = [0, -12.34]) |> line(end = [-12.34, 0]) @@ -21,7 +21,7 @@ const extrude001 = extrude(sketch001, length = -12.34)`) expect( normaliseKclNumbers( `sketch001 = startSketchOn(XY) - |> startProfileAt([-10, 10], %) + |> startProfile(at = [-10, 10]) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) @@ -31,7 +31,7 @@ const extrude001 = extrude(sketch001, length = -15)`, false ) ).toBe(`sketch001 = startSketchOn(XY) - |> startProfileAt([-12.34, 12.34], %) + |> startProfile(at = [-12.34, 12.34]) |> line(end = [12.34, 12.34]) |> line(end = [12.34, -12.34]) |> line(end = [-12.34, 12.34])