diff --git a/Makefile b/Makefile index 23f9d0a99..75fe383be 100644 --- a/Makefile +++ b/Makefile @@ -53,6 +53,7 @@ format: install ## Format the code .PHONY: lint lint: install ## Lint the code + yarn tsc yarn lint ############################################################################### diff --git a/docs/kcl/abs.md b/docs/kcl/abs.md index f251b0804..3adfaa722 100644 --- a/docs/kcl/abs.md +++ b/docs/kcl/abs.md @@ -33,7 +33,7 @@ abs(num: number): number ```js myAngle = -120 -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [8, 0]) |> angledLine({ angle = abs(myAngle), length = 5 }, %) diff --git a/docs/kcl/acos.md b/docs/kcl/acos.md index ecf8e5928..3f680df0b 100644 --- a/docs/kcl/acos.md +++ b/docs/kcl/acos.md @@ -31,7 +31,7 @@ acos(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = toDegrees(acos(0.5)), diff --git a/docs/kcl/angleToMatchLengthX.md b/docs/kcl/angleToMatchLengthX.md index 18cd901dc..84d6e1309 100644 --- a/docs/kcl/angleToMatchLengthX.md +++ b/docs/kcl/angleToMatchLengthX.md @@ -33,7 +33,7 @@ angleToMatchLengthX( ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [2, 5], tag = $seg01) |> angledLineToX([-angleToMatchLengthX(seg01, 7, %), 10], %) diff --git a/docs/kcl/angleToMatchLengthY.md b/docs/kcl/angleToMatchLengthY.md index 0eafc8e37..01c562068 100644 --- a/docs/kcl/angleToMatchLengthY.md +++ b/docs/kcl/angleToMatchLengthY.md @@ -33,7 +33,7 @@ angleToMatchLengthY( ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [1, 2], tag = $seg01) |> angledLine({ diff --git a/docs/kcl/appearance.md b/docs/kcl/appearance.md index cbee8ffa2..91bf94f28 100644 --- a/docs/kcl/appearance.md +++ b/docs/kcl/appearance.md @@ -36,7 +36,7 @@ appearance( ```js // Add color to an extruded solid. -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [10, 0]) |> line(endAbsolute = [0, 10]) @@ -52,7 +52,7 @@ example = extrude(exampleSketch, length = 5) ```js // Add color to a revolved solid. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> circle(center = [15, 0], radius = 5) |> revolve(angle = 360, axis = 'y') |> appearance(color = '#ff0000', metalness = 90, roughness = 90) @@ -63,7 +63,7 @@ sketch001 = startSketchOn('XY') ```js // Add color to different solids. fn cube(center) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([center[0] - 10, center[1] - 10], %) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) @@ -95,7 +95,7 @@ appearance( ```js // 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') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -112,7 +112,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) ```js // 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') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -129,7 +129,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) ```js // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. // This example shows _before_ the pattern. -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) @@ -146,7 +146,7 @@ example = extrude(exampleSketch, length = 1) ```js // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. // This example shows _after_ the pattern. -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) @@ -162,7 +162,7 @@ example = extrude(exampleSketch, length = 1) ```js // Color the result of a 2D pattern that was extruded. -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([.5, 25], %) |> line(end = [0, 5]) |> line(end = [-1, 0]) @@ -185,7 +185,7 @@ example = extrude(exampleSketch, length = 1) // Color the result of a sweep. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -193,10 +193,10 @@ sweepPath = startSketchOn('XZ') |> tangentialArc({ offset = -90, radius = 5 }, %) |> line(end = [0, 7]) -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) diff --git a/docs/kcl/asin.md b/docs/kcl/asin.md index 060fa3daa..9e15b2c93 100644 --- a/docs/kcl/asin.md +++ b/docs/kcl/asin.md @@ -31,7 +31,7 @@ asin(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = toDegrees(asin(0.5)), diff --git a/docs/kcl/atan.md b/docs/kcl/atan.md index 19e42d2fb..1cd02a1ac 100644 --- a/docs/kcl/atan.md +++ b/docs/kcl/atan.md @@ -31,7 +31,7 @@ atan(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = toDegrees(atan(1.25)), diff --git a/docs/kcl/atan2.md b/docs/kcl/atan2.md index ef38f9c70..c389a48ba 100644 --- a/docs/kcl/atan2.md +++ b/docs/kcl/atan2.md @@ -35,7 +35,7 @@ atan2( ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = toDegrees(atan2(1.25, 2)), diff --git a/docs/kcl/ceil.md b/docs/kcl/ceil.md index 46783007c..75fa09657 100644 --- a/docs/kcl/ceil.md +++ b/docs/kcl/ceil.md @@ -31,7 +31,7 @@ ceil(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [12, 10]) |> line(end = [ceil(7.02986), 0]) diff --git a/docs/kcl/chamfer.md b/docs/kcl/chamfer.md index 0cb2a354b..c3fb0359f 100644 --- a/docs/kcl/chamfer.md +++ b/docs/kcl/chamfer.md @@ -41,7 +41,7 @@ length = 10 thickness = 1 chamferLength = 2 -mountingPlateSketch = startSketchOn("XY") +mountingPlateSketch = startSketchOn(XY) |> startProfileAt([-width / 2, -length / 2], %) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) @@ -65,7 +65,7 @@ mountingPlate = extrude(mountingPlateSketch, length = thickness) ```js // Sketch on the face of a chamfer. fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) diff --git a/docs/kcl/circle.md b/docs/kcl/circle.md index 77c279450..24b5def9f 100644 --- a/docs/kcl/circle.md +++ b/docs/kcl/circle.md @@ -35,7 +35,7 @@ circle( ### Examples ```js -exampleSketch = startSketchOn("-XZ") +exampleSketch = startSketchOn(-XZ) |> circle(center = [0, 0], radius = 10) example = extrude(exampleSketch, length = 5) @@ -44,7 +44,7 @@ example = extrude(exampleSketch, length = 5) ![Rendered example of circle 0]() ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([-15, 0], %) |> line(end = [30, 0]) |> line(end = [0, 30]) diff --git a/docs/kcl/circleThreePoint.md b/docs/kcl/circleThreePoint.md index e6b0cd4cb..ab081f634 100644 --- a/docs/kcl/circleThreePoint.md +++ b/docs/kcl/circleThreePoint.md @@ -37,7 +37,7 @@ circleThreePoint( ### Examples ```js -exampleSketch = startSketchOn("XY") +exampleSketch = startSketchOn(XY) |> circleThreePoint(p1 = [10, 10], p2 = [20, 8], p3 = [15, 5]) |> extrude(length = 5) ``` diff --git a/docs/kcl/e.md b/docs/kcl/e.md index 95e92aab8..60939801c 100644 --- a/docs/kcl/e.md +++ b/docs/kcl/e.md @@ -28,7 +28,7 @@ e(): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 30, length = 2 * e() ^ 2 }, %) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/extrude.md b/docs/kcl/extrude.md index 196be8477..101e35975 100644 --- a/docs/kcl/extrude.md +++ b/docs/kcl/extrude.md @@ -35,7 +35,7 @@ extrude( ### Examples ```js -example = startSketchOn('XZ') +example = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> arc({ @@ -58,7 +58,7 @@ example = startSketchOn('XZ') ![Rendered example of extrude 0]() ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([-10, 0], %) |> arc({ angleStart = 120, diff --git a/docs/kcl/fillet.md b/docs/kcl/fillet.md index fe39d172d..ccc49958e 100644 --- a/docs/kcl/fillet.md +++ b/docs/kcl/fillet.md @@ -42,7 +42,7 @@ length = 10 thickness = 1 filletRadius = 2 -mountingPlateSketch = startSketchOn("XY") +mountingPlateSketch = startSketchOn(XY) |> startProfileAt([-width / 2, -length / 2], %) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) @@ -69,7 +69,7 @@ length = 10 thickness = 1 filletRadius = 1 -mountingPlateSketch = startSketchOn("XY") +mountingPlateSketch = startSketchOn(XY) |> startProfileAt([-width / 2, -length / 2], %) |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) diff --git a/docs/kcl/floor.md b/docs/kcl/floor.md index 656b97d03..ba23ae654 100644 --- a/docs/kcl/floor.md +++ b/docs/kcl/floor.md @@ -31,7 +31,7 @@ floor(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [12, 10]) |> line(end = [floor(7.02986), 0]) diff --git a/docs/kcl/getCommonEdge.md b/docs/kcl/getCommonEdge.md index ae809f46d..421e2b384 100644 --- a/docs/kcl/getCommonEdge.md +++ b/docs/kcl/getCommonEdge.md @@ -31,7 +31,7 @@ getCommonEdge(faces: [TagIdentifier]): Uuid scale = 20 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, scale]) |> line(end = [scale, 0]) diff --git a/docs/kcl/getNextAdjacentEdge.md b/docs/kcl/getNextAdjacentEdge.md index 73594ff28..5ac612cff 100644 --- a/docs/kcl/getNextAdjacentEdge.md +++ b/docs/kcl/getNextAdjacentEdge.md @@ -27,7 +27,7 @@ getNextAdjacentEdge(tag: TagIdentifier): Uuid ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLine({ angle = 60, length = 10 }, %) diff --git a/docs/kcl/getOppositeEdge.md b/docs/kcl/getOppositeEdge.md index 8e35078bf..8583c336c 100644 --- a/docs/kcl/getOppositeEdge.md +++ b/docs/kcl/getOppositeEdge.md @@ -27,7 +27,7 @@ getOppositeEdge(tag: TagIdentifier): Uuid ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLine({ angle = 60, length = 10 }, %) diff --git a/docs/kcl/getPreviousAdjacentEdge.md b/docs/kcl/getPreviousAdjacentEdge.md index c4b4abcaf..dbf4d70c0 100644 --- a/docs/kcl/getPreviousAdjacentEdge.md +++ b/docs/kcl/getPreviousAdjacentEdge.md @@ -27,7 +27,7 @@ getPreviousAdjacentEdge(tag: TagIdentifier): Uuid ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLine({ angle = 60, length = 10 }, %) diff --git a/docs/kcl/helix.md b/docs/kcl/helix.md index 1c297b610..5cb989d04 100644 --- a/docs/kcl/helix.md +++ b/docs/kcl/helix.md @@ -50,7 +50,7 @@ helixPath = helix( ) // Create a spring by sweeping around the helix path. -springSketch = startSketchOn('YZ') +springSketch = startSketchOn(YZ) |> circle(center = [0, 0], radius = 0.5) |> sweep(path = helixPath) ``` @@ -59,7 +59,7 @@ springSketch = startSketchOn('YZ') ```js // Create a helix around an edge. -helper001 = startSketchOn('XZ') +helper001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $edge001) @@ -73,7 +73,7 @@ helixPath = helix( ) // Create a spring by sweeping around the helix path. -springSketch = startSketchOn('XY') +springSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 0.5) |> sweep(path = helixPath) ``` @@ -97,7 +97,7 @@ helixPath = helix( ) // Create a spring by sweeping around the helix path. -springSketch = startSketchOn('XY') +springSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 1) |> sweep(path = helixPath) ``` diff --git a/docs/kcl/helixRevolutions.md b/docs/kcl/helixRevolutions.md index 34e5786f2..1b9c679a3 100644 --- a/docs/kcl/helixRevolutions.md +++ b/docs/kcl/helixRevolutions.md @@ -31,7 +31,7 @@ helixRevolutions( ### Examples ```js -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> circle(center = [5, 5], radius = 10) |> extrude(length = 10) |> helixRevolutions({ diff --git a/docs/kcl/hollow.md b/docs/kcl/hollow.md index 9e81c9cd3..69b960e10 100644 --- a/docs/kcl/hollow.md +++ b/docs/kcl/hollow.md @@ -32,7 +32,7 @@ hollow( ```js // Hollow a basic sketch. -firstSketch = startSketchOn('XY') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -46,7 +46,7 @@ firstSketch = startSketchOn('XY') ```js // Hollow a basic sketch. -firstSketch = startSketchOn('-XZ') +firstSketch = startSketchOn(-XZ) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -61,7 +61,7 @@ firstSketch = startSketchOn('-XZ') ```js // Hollow a sketch on face object. size = 100 -case = startSketchOn('-XZ') +case = startSketchOn(-XZ) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) diff --git a/docs/kcl/import.md b/docs/kcl/import.md index 078275dce..2a6f8eb1a 100644 --- a/docs/kcl/import.md +++ b/docs/kcl/import.md @@ -69,7 +69,7 @@ model = import("tests/inputs/cube.step") ```js import height, buildSketch from "common.kcl" -plane = 'XZ' +plane = XZ margin = 2 s1 = buildSketch(plane, [0, 0]) s2 = buildSketch(plane, [0, height() + margin]) diff --git a/docs/kcl/int.md b/docs/kcl/int.md index 01248d6e0..600b2a456 100644 --- a/docs/kcl/int.md +++ b/docs/kcl/int.md @@ -36,7 +36,7 @@ int(num: number): number n = int(ceil(5 / 2)) assertEqual(n, 3, 0.0001, "5/2 = 2.5, rounded up makes 3") // Draw n cylinders. -startSketchOn('XZ') +startSketchOn(XZ) |> circle(center = [0, 0], radius = 2) |> extrude(length = 5) |> patternTransform( diff --git a/docs/kcl/intersect.md b/docs/kcl/intersect.md index 3c198b53b..7dde3f162 100644 --- a/docs/kcl/intersect.md +++ b/docs/kcl/intersect.md @@ -30,7 +30,7 @@ intersect(solids: [Solid]): [Solid] ```js fn cube(center) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([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/lastSegX.md b/docs/kcl/lastSegX.md index d30960801..6c07d6a66 100644 --- a/docs/kcl/lastSegX.md +++ b/docs/kcl/lastSegX.md @@ -27,7 +27,7 @@ lastSegX(sketch: Sketch): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [5, 0]) |> line(end = [20, 5]) diff --git a/docs/kcl/lastSegY.md b/docs/kcl/lastSegY.md index d4662a349..b03537a08 100644 --- a/docs/kcl/lastSegY.md +++ b/docs/kcl/lastSegY.md @@ -27,7 +27,7 @@ lastSegY(sketch: Sketch): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [5, 0]) |> line(end = [20, 5]) diff --git a/docs/kcl/ln.md b/docs/kcl/ln.md index fc7fef0c3..dea61a80f 100644 --- a/docs/kcl/ln.md +++ b/docs/kcl/ln.md @@ -31,7 +31,7 @@ ln(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [ln(100), 15]) |> line(end = [5, -6]) diff --git a/docs/kcl/loft.md b/docs/kcl/loft.md index aef6d1aae..f48a36757 100644 --- a/docs/kcl/loft.md +++ b/docs/kcl/loft.md @@ -42,7 +42,7 @@ loft( ```js // Loft a square and a triangle. -squareSketch = startSketchOn('XY') +squareSketch = startSketchOn(XY) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -50,7 +50,7 @@ squareSketch = startSketchOn('XY') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -triangleSketch = startSketchOn(offsetPlane('XY', offset = 75)) +triangleSketch = startSketchOn(offsetPlane(XY, offset = 75)) |> startProfileAt([0, 125], %) |> line(end = [-15, -30]) |> line(end = [30, 0]) @@ -64,7 +64,7 @@ loft([squareSketch, triangleSketch]) ```js // Loft a square, a circle, and another circle. -squareSketch = startSketchOn('XY') +squareSketch = startSketchOn(XY) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -72,10 +72,10 @@ squareSketch = startSketchOn('XY') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch0 = startSketchOn(offsetPlane('XY', offset = 75)) +circleSketch0 = startSketchOn(offsetPlane(XY, offset = 75)) |> circle(center = [0, 100], radius = 50) -circleSketch1 = startSketchOn(offsetPlane('XY', offset = 150)) +circleSketch1 = startSketchOn(offsetPlane(XY, offset = 150)) |> circle(center = [0, 100], radius = 20) loft([ @@ -89,7 +89,7 @@ loft([ ```js // Loft a square, a circle, and another circle with options. -squareSketch = startSketchOn('XY') +squareSketch = startSketchOn(XY) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -97,10 +97,10 @@ squareSketch = startSketchOn('XY') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch0 = startSketchOn(offsetPlane('XY', offset = 75)) +circleSketch0 = startSketchOn(offsetPlane(XY, offset = 75)) |> circle(center = [0, 100], radius = 50) -circleSketch1 = startSketchOn(offsetPlane('XY', offset = 150)) +circleSketch1 = startSketchOn(offsetPlane(XY, offset = 150)) |> circle(center = [0, 100], radius = 20) loft( diff --git a/docs/kcl/log.md b/docs/kcl/log.md index 8dd6696fa..6f0d9599e 100644 --- a/docs/kcl/log.md +++ b/docs/kcl/log.md @@ -35,7 +35,7 @@ log( ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [log(100, 5), 0]) |> line(end = [5, 8]) diff --git a/docs/kcl/log10.md b/docs/kcl/log10.md index eeb51ae13..c45649bd4 100644 --- a/docs/kcl/log10.md +++ b/docs/kcl/log10.md @@ -31,7 +31,7 @@ log10(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [log10(100), 0]) |> line(end = [5, 8]) diff --git a/docs/kcl/log2.md b/docs/kcl/log2.md index a674ca812..302510721 100644 --- a/docs/kcl/log2.md +++ b/docs/kcl/log2.md @@ -31,7 +31,7 @@ log2(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [log2(100), 0]) |> line(end = [5, 8]) diff --git a/docs/kcl/map.md b/docs/kcl/map.md index 805ce5d87..354ce9ecd 100644 --- a/docs/kcl/map.md +++ b/docs/kcl/map.md @@ -33,7 +33,7 @@ map( ```js r = 10 // radius fn drawCircle(id) { - return startSketchOn("XY") + return startSketchOn(XY) |> circle(center = [id * 2 * r, 0], radius = r) } @@ -49,7 +49,7 @@ circles = map([1..3], drawCircle) r = 10 // radius // Call `map`, using an anonymous function instead of a named one. circles = map([1..3], fn(id) { - return startSketchOn("XY") + return startSketchOn(XY) |> circle(center = [id * 2 * r, 0], radius = r) }) ``` diff --git a/docs/kcl/max.md b/docs/kcl/max.md index 46d377d0d..c9e55d2e4 100644 --- a/docs/kcl/max.md +++ b/docs/kcl/max.md @@ -31,7 +31,7 @@ max(args: [number]): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 70, diff --git a/docs/kcl/min.md b/docs/kcl/min.md index 135791c3d..00c0595b4 100644 --- a/docs/kcl/min.md +++ b/docs/kcl/min.md @@ -31,7 +31,7 @@ min(args: [number]): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 70, diff --git a/docs/kcl/mirror2d.md b/docs/kcl/mirror2d.md index bb0993acd..3fef6b747 100644 --- a/docs/kcl/mirror2d.md +++ b/docs/kcl/mirror2d.md @@ -34,7 +34,7 @@ mirror2d( ```js // Mirror an un-closed sketch across the Y axis. -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 10], %) |> line(end = [15, 0]) |> line(end = [-7, -3]) @@ -53,7 +53,7 @@ example = extrude(sketch001, length = 10) ```js // Mirror a un-closed sketch across the Y axis. -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 8.5], %) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) @@ -66,11 +66,11 @@ example = extrude(sketch001, length = 10) ```js // Mirror a un-closed sketch across an edge. -helper001 = startSketchOn('XZ') +helper001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $edge001) -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 8.5], %) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) @@ -83,7 +83,7 @@ sketch001 = startSketchOn('XZ') ```js // Mirror an un-closed sketch across a custom axis. -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 8.5], %) |> line(end = [20, -8.5]) |> line(end = [-20, -8.5]) diff --git a/docs/kcl/offsetPlane.md b/docs/kcl/offsetPlane.md index 71726197f..1ddf56f52 100644 --- a/docs/kcl/offsetPlane.md +++ b/docs/kcl/offsetPlane.md @@ -32,7 +32,7 @@ offsetPlane( ```js // Loft a square and a circle on the `XY` plane using offset. -squareSketch = startSketchOn('XY') +squareSketch = startSketchOn(XY) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -40,7 +40,7 @@ squareSketch = startSketchOn('XY') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch = startSketchOn(offsetPlane('XY', offset = 150)) +circleSketch = startSketchOn(offsetPlane(XY, offset = 150)) |> circle(center = [0, 100], radius = 50) loft([squareSketch, circleSketch]) @@ -50,7 +50,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `XZ` plane using offset. -squareSketch = startSketchOn('XZ') +squareSketch = startSketchOn(XZ) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -58,7 +58,7 @@ squareSketch = startSketchOn('XZ') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch = startSketchOn(offsetPlane('XZ', offset = 150)) +circleSketch = startSketchOn(offsetPlane(XZ, offset = 150)) |> circle(center = [0, 100], radius = 50) loft([squareSketch, circleSketch]) @@ -68,7 +68,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `YZ` plane using offset. -squareSketch = startSketchOn('YZ') +squareSketch = startSketchOn(YZ) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -76,7 +76,7 @@ squareSketch = startSketchOn('YZ') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch = startSketchOn(offsetPlane('YZ', offset = 150)) +circleSketch = startSketchOn(offsetPlane(YZ, offset = 150)) |> circle(center = [0, 100], radius = 50) loft([squareSketch, circleSketch]) @@ -86,7 +86,7 @@ loft([squareSketch, circleSketch]) ```js // Loft a square and a circle on the `-XZ` plane using offset. -squareSketch = startSketchOn('-XZ') +squareSketch = startSketchOn(-XZ) |> startProfileAt([-100, 200], %) |> line(end = [200, 0]) |> line(end = [0, -200]) @@ -94,7 +94,7 @@ squareSketch = startSketchOn('-XZ') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -circleSketch = startSketchOn(offsetPlane('-XZ', offset = -150)) +circleSketch = startSketchOn(offsetPlane(-XZ, offset = -150)) |> circle(center = [0, 100], radius = 50) loft([squareSketch, circleSketch]) @@ -104,12 +104,12 @@ loft([squareSketch, circleSketch]) ```js // A circle on the XY plane -startSketchOn("XY") +startSketchOn(XY) |> startProfileAt([0, 0], %) |> circle(radius = 10, center = [0, 0]) // Triangle on the plane 4 units above -startSketchOn(offsetPlane("XY", offset = 4)) +startSketchOn(offsetPlane(XY, offset = 4)) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> line(end = [0, 10]) diff --git a/docs/kcl/patternCircular2d.md b/docs/kcl/patternCircular2d.md index b3ccf5f96..76acda360 100644 --- a/docs/kcl/patternCircular2d.md +++ b/docs/kcl/patternCircular2d.md @@ -39,7 +39,7 @@ patternCircular2d( ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([.5, 25], %) |> line(end = [0, 5]) |> line(end = [-1, 0]) diff --git a/docs/kcl/patternCircular3d.md b/docs/kcl/patternCircular3d.md index 54f003d65..d41313876 100644 --- a/docs/kcl/patternCircular3d.md +++ b/docs/kcl/patternCircular3d.md @@ -41,7 +41,7 @@ patternCircular3d( ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) example = extrude(exampleSketch, length = -5) diff --git a/docs/kcl/patternLinear2d.md b/docs/kcl/patternLinear2d.md index b68d2f321..19211a473 100644 --- a/docs/kcl/patternLinear2d.md +++ b/docs/kcl/patternLinear2d.md @@ -37,7 +37,7 @@ patternLinear2d( ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) |> patternLinear2d(axis = [1, 0], instances = 7, distance = 4) diff --git a/docs/kcl/patternLinear3d.md b/docs/kcl/patternLinear3d.md index f1624067c..20616cd9a 100644 --- a/docs/kcl/patternLinear3d.md +++ b/docs/kcl/patternLinear3d.md @@ -37,7 +37,7 @@ patternLinear3d( ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) @@ -53,7 +53,7 @@ example = extrude(exampleSketch, length = 1) ```js // Pattern a whole sketch on face. size = 100 -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) @@ -84,7 +84,7 @@ patternLinear3d( ```js // Pattern an object on a face. size = 100 -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) diff --git a/docs/kcl/patternTransform.md b/docs/kcl/patternTransform.md index 52247b267..63bcc344b 100644 --- a/docs/kcl/patternTransform.md +++ b/docs/kcl/patternTransform.md @@ -67,7 +67,7 @@ fn transform(id) { } // Sketch 4 cylinders. -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 2) |> extrude(length = 5) |> patternTransform(instances = 4, transform = transform) @@ -83,7 +83,7 @@ fn transform(id) { return { translate = [4 * (1 + id), 0, 0] } } -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 2) |> extrude(length = 5) |> patternTransform(instances = 4, transform = transform) @@ -101,7 +101,7 @@ fn cube(length, center) { p2 = [l + x, l + y] p3 = [l + x, -l + y] - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt(p0, %) |> line(endAbsolute = p1) |> line(endAbsolute = p2) @@ -139,7 +139,7 @@ fn cube(length, center) { p2 = [l + x, l + y] p3 = [l + x, -l + y] - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt(p0, %) |> line(endAbsolute = p1) |> line(endAbsolute = p2) @@ -182,7 +182,7 @@ fn transform(replicaId) { } // Each layer is just a pretty thin cylinder. fn layer() { - return startSketchOn("XY") + return startSketchOn(XY) // or some other plane idk |> circle(center = [0, 0], radius = 1, tag = $tag1) |> extrude(length = h) @@ -203,7 +203,7 @@ fn transform(i) { { rotation = { angle = 45 * i } } ] } -startSketchOn('XY') +startSketchOn(XY) |> startProfileAt([0, 0], %) |> polygon({ radius = 10, diff --git a/docs/kcl/patternTransform2d.md b/docs/kcl/patternTransform2d.md index fdcbba6c0..5f76b8141 100644 --- a/docs/kcl/patternTransform2d.md +++ b/docs/kcl/patternTransform2d.md @@ -41,7 +41,7 @@ fn transform(id) { } // Sketch 4 circles. -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 2) |> patternTransform2d(instances = 4, transform = transform) ``` diff --git a/docs/kcl/pi.md b/docs/kcl/pi.md index 186baadf6..9f96bbd79 100644 --- a/docs/kcl/pi.md +++ b/docs/kcl/pi.md @@ -30,7 +30,7 @@ pi(): number ```js circumference = 70 -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> circle(center = [0, 0], radius = circumference / (2 * pi())) example = extrude(exampleSketch, length = 5) diff --git a/docs/kcl/polar.md b/docs/kcl/polar.md index 12b12b163..c3faa7e46 100644 --- a/docs/kcl/polar.md +++ b/docs/kcl/polar.md @@ -27,7 +27,7 @@ polar(data: PolarCoordsData): [number] ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = polar({ angle = 30, length = 5 }), tag = $thing) |> line(end = [0, 5]) diff --git a/docs/kcl/polygon.md b/docs/kcl/polygon.md index dbb6e5973..b05fc198b 100644 --- a/docs/kcl/polygon.md +++ b/docs/kcl/polygon.md @@ -34,7 +34,7 @@ polygon( ```js // Create a regular hexagon inscribed in a circle of radius 10 -hex = startSketchOn('XY') +hex = startSketchOn(XY) |> polygon({ radius = 10, numSides = 6, @@ -49,7 +49,7 @@ example = extrude(hex, length = 5) ```js // Create a square circumscribed around a circle of radius 5 -square = startSketchOn('XY') +square = startSketchOn(XY) |> polygon({ radius = 5.0, numSides = 4, diff --git a/docs/kcl/pow.md b/docs/kcl/pow.md index ac73e02c0..434fd7bdc 100644 --- a/docs/kcl/pow.md +++ b/docs/kcl/pow.md @@ -35,7 +35,7 @@ pow( ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 50, length = pow(5, 2) }, %) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/reduce.md b/docs/kcl/reduce.md index 617882fe1..7a371710f 100644 --- a/docs/kcl/reduce.md +++ b/docs/kcl/reduce.md @@ -82,7 +82,7 @@ fn decagon(radius) { stepAngle = 1 / 10 * TAU // Start the decagon sketch at this point. - startOfDecagonSketch = startSketchOn('XY') + startOfDecagonSketch = startSketchOn(XY) |> startProfileAt([cos(0) * radius, sin(0) * radius], %) // Use a `reduce` to draw the remaining decagon sides. diff --git a/docs/kcl/revolve.md b/docs/kcl/revolve.md index 9a3c2ae1c..914993c77 100644 --- a/docs/kcl/revolve.md +++ b/docs/kcl/revolve.md @@ -43,7 +43,7 @@ revolve( ### Examples ```js -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -60,7 +60,7 @@ part001 = startSketchOn('XY') ```js // A donut shape. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> circle(center = [15, 0], radius = 5) |> revolve(angle = 360, axis = 'y') ``` @@ -68,7 +68,7 @@ sketch001 = startSketchOn('XY') ![Rendered example of revolve 1]() ```js -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -84,7 +84,7 @@ part001 = startSketchOn('XY') ![Rendered example of revolve 2]() ```js -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -108,7 +108,7 @@ part002 = startSketchOn(part001, 'end') ![Rendered example of revolve 3]() ```js -box = startSketchOn('XY') +box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> line(end = [20, 0]) @@ -124,7 +124,7 @@ sketch001 = startSketchOn(box, "END") ![Rendered example of revolve 4]() ```js -box = startSketchOn('XY') +box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> line(end = [20, 0]) @@ -140,7 +140,7 @@ sketch001 = startSketchOn(box, "END") ![Rendered example of revolve 5]() ```js -box = startSketchOn('XY') +box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> line(end = [20, 0]) @@ -156,7 +156,7 @@ sketch001 = startSketchOn(box, "END") ![Rendered example of revolve 6]() ```js -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> startProfileAt([10, 0], %) |> line(end = [5, -5]) |> line(end = [5, 5]) @@ -180,7 +180,7 @@ part001 = revolve( // Revolve two sketches around the same axis. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) profile001 = startProfileAt([4, 8], sketch001) |> xLine(length = 3) |> yLine(length = -3) @@ -204,14 +204,14 @@ revolve([profile001, profile002], axis = "X") // Revolve around a path that has not been extruded. -profile001 = startSketchOn('XY') +profile001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) |> line(end = [0, -20]) |> close(%) -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> circle(center = [-10, 10], radius = 4) |> revolve(angle = 90, axis = revolveAxis) ``` @@ -222,12 +222,12 @@ sketch001 = startSketchOn('XY') // Revolve around a path that has not been extruded or closed. -profile001 = startSketchOn('XY') +profile001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20], tag = $revolveAxis) |> line(end = [20, 0]) -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> circle(center = [-10, 10], radius = 4) |> revolve(angle = 90, axis = revolveAxis) ``` diff --git a/docs/kcl/rotate.md b/docs/kcl/rotate.md index d0560c137..bd74dea02 100644 --- a/docs/kcl/rotate.md +++ b/docs/kcl/rotate.md @@ -58,7 +58,7 @@ rotate( // Rotate a pipe with roll, pitch, and yaw. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -67,10 +67,10 @@ sweepPath = startSketchOn('XZ') |> line(end = [0, 7]) // Create a hole for the pipe. -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) @@ -83,7 +83,7 @@ sweepSketch = startSketchOn('XY') // Rotate a pipe about an axis with an angle. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -92,10 +92,10 @@ sweepPath = startSketchOn('XZ') |> line(end = [0, 7]) // Create a hole for the pipe. -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) @@ -120,7 +120,7 @@ cube // Sweep two sketches along the same path. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) rectangleSketch = startProfileAt([-200, 23.86], sketch001) |> angledLine([0, 73.47], %, $rectangleSegmentA001) |> angledLine([ @@ -136,7 +136,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) -sketch002 = startSketchOn('YZ') +sketch002 = startSketchOn(YZ) sweepPath = startProfileAt([0, 0], sketch002) |> yLine(length = 231.81) |> tangentialArc({ radius = 80, offset = -90 }, %) @@ -152,7 +152,7 @@ rotate(parts, axis = [0, 0, 1.0], angle = 90) ```js // Translate and rotate a sketch to create a loft. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) fn square() { return startProfileAt([-10, 10], sketch001) diff --git a/docs/kcl/round.md b/docs/kcl/round.md index dc6d22e76..d1b03e5d3 100644 --- a/docs/kcl/round.md +++ b/docs/kcl/round.md @@ -31,7 +31,7 @@ round(num: number): number ### Examples ```js -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [12, 10]) |> line(end = [round(7.02986), 0]) diff --git a/docs/kcl/scale.md b/docs/kcl/scale.md index 7bafb55e2..ea13d8d8b 100644 --- a/docs/kcl/scale.md +++ b/docs/kcl/scale.md @@ -38,7 +38,7 @@ scale( // Scale a pipe. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -47,10 +47,10 @@ sweepPath = startSketchOn('XZ') |> line(end = [0, 7]) // Create a hole for the pipe. -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) @@ -75,7 +75,7 @@ cube // Sweep two sketches along the same path. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) rectangleSketch = startProfileAt([-200, 23.86], sketch001) |> angledLine([0, 73.47], %, $rectangleSegmentA001) |> angledLine([ @@ -91,7 +91,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) -sketch002 = startSketchOn('YZ') +sketch002 = startSketchOn(YZ) sweepPath = startProfileAt([0, 0], sketch002) |> yLine(length = 231.81) |> tangentialArc({ radius = 80, offset = -90 }, %) diff --git a/docs/kcl/segAng.md b/docs/kcl/segAng.md index a5d22fa1c..e247468c0 100644 --- a/docs/kcl/segAng.md +++ b/docs/kcl/segAng.md @@ -27,7 +27,7 @@ segAng(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> line(end = [5, 10], tag = $seg01) diff --git a/docs/kcl/segEnd.md b/docs/kcl/segEnd.md index 31f68b100..a9f0925a8 100644 --- a/docs/kcl/segEnd.md +++ b/docs/kcl/segEnd.md @@ -28,7 +28,7 @@ segEnd(tag: TagIdentifier): [number] ```js w = 15 -cube = startSketchOn('XY') +cube = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [w, 0], tag = $line1) |> line(end = [0, w], tag = $line2) @@ -38,7 +38,7 @@ cube = startSketchOn('XY') |> extrude(length = 5) fn cylinder(radius, tag) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([0, 0], %) |> circle(radius = radius, center = segEnd(tag)) |> extrude(length = radius) diff --git a/docs/kcl/segEndX.md b/docs/kcl/segEndX.md index 5c3f84de4..01f623a77 100644 --- a/docs/kcl/segEndX.md +++ b/docs/kcl/segEndX.md @@ -27,7 +27,7 @@ segEndX(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [20, 0], tag = $thing) |> line(end = [0, 5]) diff --git a/docs/kcl/segEndY.md b/docs/kcl/segEndY.md index e41147a87..01788f8f0 100644 --- a/docs/kcl/segEndY.md +++ b/docs/kcl/segEndY.md @@ -27,7 +27,7 @@ segEndY(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [20, 0]) |> line(end = [0, 3], tag = $thing) diff --git a/docs/kcl/segLen.md b/docs/kcl/segLen.md index f53137206..9e5653f66 100644 --- a/docs/kcl/segLen.md +++ b/docs/kcl/segLen.md @@ -27,7 +27,7 @@ segLen(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 60, length = 10 }, %, $thing) |> tangentialArc({ offset = -120, radius = 5 }, %) diff --git a/docs/kcl/segStart.md b/docs/kcl/segStart.md index 870f78fa2..73a4b7f04 100644 --- a/docs/kcl/segStart.md +++ b/docs/kcl/segStart.md @@ -28,7 +28,7 @@ segStart(tag: TagIdentifier): [number] ```js w = 15 -cube = startSketchOn('XY') +cube = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [w, 0], tag = $line1) |> line(end = [0, w], tag = $line2) @@ -38,7 +38,7 @@ cube = startSketchOn('XY') |> extrude(length = 5) fn cylinder(radius, tag) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([0, 0], %) |> circle(radius = radius, center = segStart(tag)) |> extrude(length = radius) diff --git a/docs/kcl/segStartX.md b/docs/kcl/segStartX.md index 7caa429e1..b897155c4 100644 --- a/docs/kcl/segStartX.md +++ b/docs/kcl/segStartX.md @@ -27,7 +27,7 @@ segStartX(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [20, 0], tag = $thing) |> line(end = [0, 5]) diff --git a/docs/kcl/segStartY.md b/docs/kcl/segStartY.md index c4b062934..4e2d7d664 100644 --- a/docs/kcl/segStartY.md +++ b/docs/kcl/segStartY.md @@ -27,7 +27,7 @@ segStartY(tag: TagIdentifier): number ### Examples ```js -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [20, 0]) |> line(end = [0, 3], tag = $thing) diff --git a/docs/kcl/shell.md b/docs/kcl/shell.md index 1de197be4..bac00e26b 100644 --- a/docs/kcl/shell.md +++ b/docs/kcl/shell.md @@ -34,7 +34,7 @@ shell( ```js // Remove the end face for the extrusion. -firstSketch = startSketchOn('XY') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -50,7 +50,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) ```js // Remove the start face for the extrusion. -firstSketch = startSketchOn('-XZ') +firstSketch = startSketchOn(-XZ) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -66,7 +66,7 @@ shell(firstSketch, faces = ['start'], thickness = 0.25) ```js // Remove a tagged face and the end face for the extrusion. -firstSketch = startSketchOn('XY') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -82,7 +82,7 @@ shell(firstSketch, faces = [myTag], thickness = 0.25) ```js // Remove multiple faces at once. -firstSketch = startSketchOn('XY') +firstSketch = startSketchOn(XY) |> startProfileAt([-12, 12], %) |> line(end = [24, 0]) |> line(end = [0, -24]) @@ -99,7 +99,7 @@ shell(firstSketch, faces = [myTag, 'end'], thickness = 0.25) ```js // Shell a sketch on face. size = 100 -case = startSketchOn('-XZ') +case = startSketchOn(-XZ) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) @@ -124,7 +124,7 @@ shell(case, faces = ['start'], thickness = 5) ```js // Shell a sketch on face object on the end face. size = 100 -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) @@ -152,7 +152,7 @@ shell(thing1, faces = ['end'], thickness = 5) size = 100 -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([-size, -size], %) |> line(end = [2 * size, 0]) |> line(end = [0, 2 * size]) diff --git a/docs/kcl/sqrt.md b/docs/kcl/sqrt.md index 41730dfa7..db5a43d4d 100644 --- a/docs/kcl/sqrt.md +++ b/docs/kcl/sqrt.md @@ -31,7 +31,7 @@ sqrt(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 50, length = sqrt(2500) }, %) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/std.json b/docs/kcl/std.json index 0f79bcb30..2f97ef265 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 |> 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)" ] }, { @@ -80,7 +80,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(acos(0.5)),\n length = 10\n }, %)\n |> line(end = [5, 0])\n |> line(endAbsolute = [12, 0])\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(acos(0.5)),\n length = 10\n }, %)\n |> line(end = [5, 0])\n |> line(endAbsolute = [12, 0])\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -1796,7 +1796,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [2, 5], tag = $seg01)\n |> angledLineToX([-angleToMatchLengthX(seg01, 7, %), 10], %)\n |> close()\n\nextrusion = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [2, 5], tag = $seg01)\n |> angledLineToX([-angleToMatchLengthX(seg01, 7, %), 10], %)\n |> close()\n\nextrusion = extrude(sketch001, length = 5)" ] }, { @@ -3512,7 +3512,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [1, 2], tag = $seg01)\n |> angledLine({\n angle = angleToMatchLengthY(seg01, 15, %),\n length = 5\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrusion = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [1, 2], tag = $seg01)\n |> angledLine({\n angle = angleToMatchLengthY(seg01, 15, %),\n length = 5\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrusion = extrude(sketch001, length = 5)" ] }, { @@ -41304,15 +41304,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 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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -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 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 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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -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)" ] }, { @@ -51323,7 +51323,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(asin(0.5)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(asin(0.5)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -51748,7 +51748,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(atan(1.25)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(atan(1.25)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -51803,7 +51803,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "sketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(atan2(1.25, 2)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" + "sketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = toDegrees(atan2(1.25, 2)),\n length = 20\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nextrude001 = extrude(sketch001, length = 5)" ] }, { @@ -56820,7 +56820,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 |> 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)" ] }, { @@ -64987,8 +64987,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, 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 |> 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, 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)" ] }, { @@ -73061,8 +73061,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"-XZ\")\n |> circle(center = [0, 0], radius = 10)\n\nexample = extrude(exampleSketch, length = 5)", - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([-15, 0], %)\n |> line(end = [30, 0])\n |> line(end = [0, 30])\n |> line(end = [-30, 0])\n |> close()\n |> hole(circle(center = [0, 15], radius = 5), %)\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(-XZ)\n |> circle(center = [0, 0], radius = 10)\n\nexample = extrude(exampleSketch, length = 5)", + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([-15, 0], %)\n |> line(end = [30, 0])\n |> line(end = [0, 30])\n |> line(end = [-30, 0])\n |> close()\n |> hole(circle(center = [0, 15], radius = 5), %)\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -77993,7 +77993,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XY\")\n |> circleThreePoint(p1 = [10, 10], p2 = [20, 8], p3 = [15, 5])\n |> extrude(length = 5)" + "exampleSketch = startSketchOn(XY)\n |> circleThreePoint(p1 = [10, 10], p2 = [20, 8], p3 = [15, 5])\n |> extrude(length = 5)" ] }, { @@ -82977,7 +82977,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 |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 30, length = 2 * e() ^ 2 }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -90985,8 +90985,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "example = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> arc({\n angleStart = 120,\n angleEnd = 0,\n radius = 5\n }, %)\n |> line(end = [5, 0])\n |> line(end = [0, 10])\n |> bezierCurve({\n control1 = [-10, 0],\n control2 = [2, 10],\n to = [-5, 10]\n }, %)\n |> line(end = [-5, -2])\n |> close()\n |> extrude(length = 10)", - "exampleSketch = startSketchOn('XZ')\n |> startProfileAt([-10, 0], %)\n |> arc({\n angleStart = 120,\n angleEnd = -60,\n radius = 5\n }, %)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve({\n control1 = [-3, 0],\n control2 = [2, 10],\n to = [-5, 10]\n }, %)\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" + "example = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> arc({\n angleStart = 120,\n angleEnd = 0,\n radius = 5\n }, %)\n |> line(end = [5, 0])\n |> line(end = [0, 10])\n |> bezierCurve({\n control1 = [-10, 0],\n control2 = [2, 10],\n to = [-5, 10]\n }, %)\n |> line(end = [-5, -2])\n |> close()\n |> extrude(length = 10)", + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([-10, 0], %)\n |> arc({\n angleStart = 120,\n angleEnd = -60,\n radius = 5\n }, %)\n |> line(end = [10, 0])\n |> line(end = [5, 0])\n |> bezierCurve({\n control1 = [-3, 0],\n control2 = [2, 10],\n to = [-5, 10]\n }, %)\n |> line(end = [-4, 10])\n |> line(end = [-5, -2])\n |> close()\n\nexample = extrude(exampleSketch, length = 10)" ] }, { @@ -100768,8 +100768,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 |> 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 )" ] }, { @@ -100811,7 +100811,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 |> 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)" ] }, { @@ -100895,7 +100895,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 |> 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])" ] }, { @@ -100942,7 +100942,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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getNextAdjacentEdge(referenceEdge)])" + "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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getNextAdjacentEdge(referenceEdge)])" ] }, { @@ -100989,7 +100989,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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getOppositeEdge(referenceEdge)])" + "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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getOppositeEdge(referenceEdge)])" ] }, { @@ -101036,7 +101036,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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getPreviousAdjacentEdge(referenceEdge)])" + "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 }, %, $referenceEdge)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)\n |> fillet(radius = 3, tags = [getPreviousAdjacentEdge(referenceEdge)])" ] }, { @@ -101531,9 +101531,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Create a helix around the Z axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\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 = 0.5)\n |> sweep(path = helixPath)", - "// Create a helix around an edge.\nhelper001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 10], tag = $edge001)\n\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\n length = 10,\n radius = 5,\n axis = edge001,\n)\n\n// Create a spring by sweeping around the helix path.\nspringSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 0.5)\n |> sweep(path = helixPath)", - "// Create a helix around a custom axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\n length = 10,\n radius = 5,\n axis = {\n custom = {\n axis = [0, 0, 1.0],\n origin = [0, 0.25, 0]\n }\n },\n)\n\n// Create a spring by sweeping around the helix path.\nspringSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1)\n |> sweep(path = helixPath)" + "// Create a helix around the Z axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\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 = 0.5)\n |> sweep(path = helixPath)", + "// Create a helix around an edge.\nhelper001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 10], tag = $edge001)\n\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\n length = 10,\n radius = 5,\n axis = edge001,\n)\n\n// Create a spring by sweeping around the helix path.\nspringSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 0.5)\n |> sweep(path = helixPath)", + "// Create a helix around a custom axis.\nhelixPath = helix(\n angleStart = 0,\n ccw = true,\n revolutions = 5,\n length = 10,\n radius = 5,\n axis = {\n custom = {\n axis = [0, 0, 1.0],\n origin = [0, 0.25, 0]\n }\n },\n)\n\n// Create a spring by sweeping around the helix path.\nspringSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1)\n |> sweep(path = helixPath)" ] }, { @@ -104907,7 +104907,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "part001 = startSketchOn('XY')\n |> circle(center = [5, 5], radius = 10)\n |> extrude(length = 10)\n |> helixRevolutions({\n angleStart = 0,\n ccw = true,\n revolutions = 16\n }, %)" + "part001 = startSketchOn(XY)\n |> circle(center = [5, 5], radius = 10)\n |> extrude(length = 10)\n |> helixRevolutions({\n angleStart = 0,\n ccw = true,\n revolutions = 16\n }, %)" ] }, { @@ -113179,9 +113179,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(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(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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, 'end')\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nhollow(0.5, case)" + "// 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(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(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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, 'end')\n |> circle(center = [size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nhollow(0.5, case)" ] }, { @@ -113562,7 +113562,7 @@ "model = import(\"tests/inputs/cube.gltf\")", "model = import(\"tests/inputs/cube.sldprt\")", "model = import(\"tests/inputs/cube.step\")", - "import height, buildSketch from \"common.kcl\"\n\nplane = 'XZ'\nmargin = 2\ns1 = buildSketch(plane, [0, 0])\ns2 = buildSketch(plane, [0, height() + margin])" + "import height, buildSketch from \"common.kcl\"\n\nplane = XZ\nmargin = 2\ns1 = buildSketch(plane, [0, 0])\ns2 = buildSketch(plane, [0, height() + margin])" ] }, { @@ -113632,7 +113632,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "n = int(ceil(5 / 2))\nassertEqual(n, 3, 0.0001, \"5/2 = 2.5, rounded up makes 3\")\n// Draw n cylinders.\nstartSketchOn('XZ')\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 5)\n |> patternTransform(\n instances = n,\n transform = fn(id) {\n return { translate = [4 * id, 0, 0] }\n },\n )" + "n = int(ceil(5 / 2))\nassertEqual(n, 3, 0.0001, \"5/2 = 2.5, rounded up makes 3\")\n// Draw n cylinders.\nstartSketchOn(XZ)\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 5)\n |> patternTransform(\n instances = n,\n transform = fn(id) {\n return { translate = [4 * id, 0, 0] }\n },\n )" ] }, { @@ -116843,7 +116843,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "fn 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\npart001 = cube([0, 0])\npart002 = cube([8, 8])\n\nintersectedPart = intersect([part001, part002])" + "fn 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\npart001 = cube([0, 0])\npart002 = cube([8, 8])\n\nintersectedPart = intersect([part001, part002])" ] }, { @@ -118527,7 +118527,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 |> 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)" ] }, { @@ -120211,7 +120211,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 |> 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)" ] }, { @@ -128550,7 +128550,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 |> 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)" ] }, { @@ -141412,9 +141412,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 |> 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)" ] }, { @@ -141469,7 +141469,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 |> 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)" ] }, { @@ -141511,7 +141511,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 |> 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)" ] }, { @@ -141553,7 +141553,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 |> 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)" ] }, { @@ -148936,8 +148936,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "r = 10 // radius\nfn drawCircle(id) {\n return startSketchOn(\"XY\")\n |> circle(center = [id * 2 * r, 0], radius = r)\n}\n\n// Call `drawCircle`, passing in each element of the array.\n// The outputs from each `drawCircle` form a new array,\n// which is the return value from `map`.\ncircles = map([1..3], drawCircle)", - "r = 10 // radius\n// Call `map`, using an anonymous function instead of a named one.\ncircles = map([1..3], fn(id) {\n return startSketchOn(\"XY\")\n |> circle(center = [id * 2 * r, 0], radius = r)\n})" + "r = 10 // radius\nfn drawCircle(id) {\n return startSketchOn(XY)\n |> circle(center = [id * 2 * r, 0], radius = r)\n}\n\n// Call `drawCircle`, passing in each element of the array.\n// The outputs from each `drawCircle` form a new array,\n// which is the return value from `map`.\ncircles = map([1..3], drawCircle)", + "r = 10 // radius\n// Call `map`, using an anonymous function instead of a named one.\ncircles = map([1..3], fn(id) {\n return startSketchOn(XY)\n |> circle(center = [id * 2 * r, 0], radius = r)\n})" ] }, { @@ -148982,7 +148982,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 70,\n length = max(15, 31, 4, 13, 22)\n }, %)\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 70,\n length = max(15, 31, 4, 13, 22)\n }, %)\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -149027,7 +149027,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 70,\n length = min(15, 31, 4, 13, 22)\n }, %)\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 70,\n length = min(15, 31, 4, 13, 22)\n }, %)\n |> line(end = [20, 0])\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -152496,10 +152496,10 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Mirror an un-closed sketch across the Y axis.\nsketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 10], %)\n |> line(end = [15, 0])\n |> line(end = [-7, -3])\n |> line(end = [9, -1])\n |> line(end = [-8, -5])\n |> line(end = [9, -3])\n |> line(end = [-8, -3])\n |> line(end = [9, -1])\n |> line(end = [-19, -0])\n |> mirror2d({ axis = 'Y' }, %)\n\nexample = extrude(sketch001, length = 10)", - "// Mirror a un-closed sketch across the Y axis.\nsketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({ axis = 'Y' }, %)\n\nexample = extrude(sketch001, length = 10)", - "// Mirror a un-closed sketch across an edge.\nhelper001 = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 10], tag = $edge001)\n\nsketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({ axis = edge001 }, %)\n\n// example = extrude(sketch001, length = 10)", - "// Mirror an un-closed sketch across a custom axis.\nsketch001 = startSketchOn('XZ')\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({\n axis = {\n custom = {\n axis = [0.0, 1.0],\n origin = [0.0, 0.0]\n }\n }\n }, %)\n\nexample = extrude(sketch001, length = 10)" + "// Mirror an un-closed sketch across the Y axis.\nsketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 10], %)\n |> line(end = [15, 0])\n |> line(end = [-7, -3])\n |> line(end = [9, -1])\n |> line(end = [-8, -5])\n |> line(end = [9, -3])\n |> line(end = [-8, -3])\n |> line(end = [9, -1])\n |> line(end = [-19, -0])\n |> mirror2d({ axis = 'Y' }, %)\n\nexample = extrude(sketch001, length = 10)", + "// Mirror a un-closed sketch across the Y axis.\nsketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({ axis = 'Y' }, %)\n\nexample = extrude(sketch001, length = 10)", + "// Mirror a un-closed sketch across an edge.\nhelper001 = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 10], tag = $edge001)\n\nsketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({ axis = edge001 }, %)\n\n// example = extrude(sketch001, length = 10)", + "// Mirror an un-closed sketch across a custom axis.\nsketch001 = startSketchOn(XZ)\n |> startProfileAt([0, 8.5], %)\n |> line(end = [20, -8.5])\n |> line(end = [-20, -8.5])\n |> mirror2d({\n axis = {\n custom = {\n axis = [0.0, 1.0],\n origin = [0.0, 0.0]\n }\n }\n }, %)\n\nexample = extrude(sketch001, length = 10)" ] }, { @@ -152932,11 +152932,11 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Loft a square and a circle on the `XY` plane using offset.\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\ncircleSketch = startSketchOn(offsetPlane('XY', offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", - "// Loft a square and a circle on the `XZ` plane using offset.\nsquareSketch = startSketchOn('XZ')\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\ncircleSketch = startSketchOn(offsetPlane('XZ', offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", - "// Loft a square and a circle on the `YZ` plane using offset.\nsquareSketch = startSketchOn('YZ')\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\ncircleSketch = startSketchOn(offsetPlane('YZ', offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", - "// Loft a square and a circle on the `-XZ` plane using offset.\nsquareSketch = startSketchOn('-XZ')\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\ncircleSketch = startSketchOn(offsetPlane('-XZ', offset = -150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", - "// A circle on the XY plane\nstartSketchOn(\"XY\")\n |> startProfileAt([0, 0], %)\n |> circle(radius = 10, center = [0, 0])\n\n// Triangle on the plane 4 units above\nstartSketchOn(offsetPlane(\"XY\", offset = 4))\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> close()" + "// Loft a square and a circle on the `XY` plane using offset.\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\ncircleSketch = startSketchOn(offsetPlane(XY, offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", + "// Loft a square and a circle on the `XZ` plane using offset.\nsquareSketch = startSketchOn(XZ)\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\ncircleSketch = startSketchOn(offsetPlane(XZ, offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", + "// Loft a square and a circle on the `YZ` plane using offset.\nsquareSketch = startSketchOn(YZ)\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\ncircleSketch = startSketchOn(offsetPlane(YZ, offset = 150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", + "// Loft a square and a circle on the `-XZ` plane using offset.\nsquareSketch = startSketchOn(-XZ)\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\ncircleSketch = startSketchOn(offsetPlane(-XZ, offset = -150))\n |> circle(center = [0, 100], radius = 50)\n\nloft([squareSketch, circleSketch])", + "// A circle on the XY plane\nstartSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> circle(radius = 10, center = [0, 0])\n\n// Triangle on the plane 4 units above\nstartSketchOn(offsetPlane(XY, offset = 4))\n |> startProfileAt([0, 0], %)\n |> line(end = [10, 0])\n |> line(end = [0, 10])\n |> close()" ] }, { @@ -164136,7 +164136,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 |> 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)" ] }, { @@ -176938,7 +176938,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn('XZ')\n |> circle(center = [0, 0], radius = 1)\n\nexample = extrude(exampleSketch, length = -5)\n |> patternCircular3d(\n axis = [1, -1, 0],\n center = [10, -20, 0],\n instances = 11,\n arcDegrees = 360,\n rotateDuplicates = true,\n )" + "exampleSketch = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = 1)\n\nexample = extrude(exampleSketch, length = -5)\n |> patternCircular3d(\n axis = [1, -1, 0],\n center = [10, -20, 0],\n instances = 11,\n arcDegrees = 360,\n rotateDuplicates = true,\n )" ] }, { @@ -186542,7 +186542,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn('XZ')\n |> circle(center = [0, 0], radius = 1)\n |> patternLinear2d(axis = [1, 0], instances = 7, distance = 4)\n\nexample = extrude(exampleSketch, length = 1)" + "exampleSketch = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = 1)\n |> patternLinear2d(axis = [1, 0], instances = 7, distance = 4)\n\nexample = extrude(exampleSketch, length = 1)" ] }, { @@ -196146,9 +196146,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 |> tangentialArcTo([-size, size], %)\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, '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 |> 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 |> tangentialArcTo([-size, size], %)\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close(%)\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, '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)" ] }, { @@ -204149,12 +204149,12 @@ "unpublished": false, "deprecated": false, "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)", - "// 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))\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)" + "// 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)", + "// 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))\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)" ] }, { @@ -212155,7 +212155,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Each instance will be shifted along the X axis.\nfn transform(id) {\n return { translate = [4 * id, 0] }\n}\n\n// Sketch 4 circles.\nsketch001 = startSketchOn('XZ')\n |> circle(center = [0, 0], radius = 2)\n |> patternTransform2d(instances = 4, transform = transform)" + "// Each instance will be shifted along the X axis.\nfn transform(id) {\n return { translate = [4 * id, 0] }\n}\n\n// Sketch 4 circles.\nsketch001 = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = 2)\n |> patternTransform2d(instances = 4, transform = transform)" ] }, { @@ -212183,7 +212183,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "circumference = 70\n\nexampleSketch = startSketchOn(\"XZ\")\n |> circle(center = [0, 0], radius = circumference / (2 * pi()))\n\nexample = extrude(exampleSketch, length = 5)" + "circumference = 70\n\nexampleSketch = startSketchOn(XZ)\n |> circle(center = [0, 0], radius = circumference / (2 * pi()))\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -212617,7 +212617,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = polar({ angle = 30, length = 5 }), 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 |> startProfileAt([0, 0], %)\n |> line(end = polar({ angle = 30, length = 5 }), 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)" ] }, { @@ -217535,8 +217535,8 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Create a regular hexagon inscribed in a circle of radius 10\nhex = startSketchOn('XY')\n |> polygon({\n radius = 10,\n numSides = 6,\n center = [0, 0],\n inscribed = true\n }, %)\n\nexample = extrude(hex, length = 5)", - "// Create a square circumscribed around a circle of radius 5\nsquare = startSketchOn('XY')\n |> polygon({\n radius = 5.0,\n numSides = 4,\n center = [10, 10],\n inscribed = false\n }, %)\nexample = extrude(square, length = 5)" + "// Create a regular hexagon inscribed in a circle of radius 10\nhex = startSketchOn(XY)\n |> polygon({\n radius = 10,\n numSides = 6,\n center = [0, 0],\n inscribed = true\n }, %)\n\nexample = extrude(hex, length = 5)", + "// Create a square circumscribed around a circle of radius 5\nsquare = startSketchOn(XY)\n |> polygon({\n radius = 5.0,\n numSides = 4,\n center = [10, 10],\n inscribed = false\n }, %)\nexample = extrude(square, length = 5)" ] }, { @@ -222882,7 +222882,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 |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 50, length = pow(5, 2) }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -246619,7 +246619,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 `assertEqual` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassertEqual(sum([1, 2, 3]), 6, 0.00001, \"1 + 2 + 3 summed is 6\")", "// 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 `assertEqual` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassertEqual(sum, 6, 0.00001, \"1 + 2 + 3 summed is 6\")", - "// Declare a function that sketches a decagon.\nfn decagon(radius) {\n // Each side of the decagon is turned this many degrees 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 degrees 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()" ] }, { @@ -258340,17 +258340,17 @@ "unpublished": false, "deprecated": false, "examples": [ - "part001 = 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 |> revolve(axis = 'y') // default angle is 360", - "// A donut shape.\nsketch001 = startSketchOn('XY')\n |> circle(center = [15, 0], radius = 5)\n |> revolve(angle = 360, axis = 'y')", - "part001 = 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 |> revolve(axis = 'y', angle = 180)", - "part001 = 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 |> revolve(axis = 'y', angle = 180)\n\npart002 = startSketchOn(part001, 'end')\n |> startProfileAt([4.5, -5], %)\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n |> extrude(length = 5)", - "box = startSketchOn('XY')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20])\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = -90, axis = 'y')", - "box = startSketchOn('XY')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20], tag = $revolveAxis)\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = 90, axis = getOppositeEdge(revolveAxis))", - "box = startSketchOn('XY')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20], tag = $revolveAxis)\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = 90, axis = getOppositeEdge(revolveAxis), tolerance = 0.0001)", - "sketch001 = startSketchOn('XY')\n |> startProfileAt([10, 0], %)\n |> line(end = [5, -5])\n |> line(end = [5, 5])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\npart001 = revolve(\n sketch001,\n axis = {\n custom = {\n axis = [0.0, 1.0],\n origin = [0.0, 0.0]\n }\n },\n)", - "// Revolve two sketches around the same axis.\n\n\nsketch001 = startSketchOn('XY')\nprofile001 = startProfileAt([4, 8], sketch001)\n |> xLine(length = 3)\n |> yLine(length = -3)\n |> xLine(length = -3)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nprofile002 = startProfileAt([-5, 8], sketch001)\n |> xLine(length = 3)\n |> yLine(length = -3)\n |> xLine(length = -3)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nrevolve([profile001, profile002], axis = \"X\")", - "// Revolve around a path that has not been extruded.\n\n\nprofile001 = startSketchOn('XY')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20], tag = $revolveAxis)\n |> line(end = [20, 0])\n |> line(end = [0, -20])\n |> close(%)\n\nsketch001 = startSketchOn('XY')\n |> circle(center = [-10, 10], radius = 4)\n |> revolve(angle = 90, axis = revolveAxis)", - "// Revolve around a path that has not been extruded or closed.\n\n\nprofile001 = startSketchOn('XY')\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20], tag = $revolveAxis)\n |> line(end = [20, 0])\n\nsketch001 = startSketchOn('XY')\n |> circle(center = [-10, 10], radius = 4)\n |> revolve(angle = 90, axis = revolveAxis)" + "part001 = 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 |> revolve(axis = 'y') // default angle is 360", + "// A donut shape.\nsketch001 = startSketchOn(XY)\n |> circle(center = [15, 0], radius = 5)\n |> revolve(angle = 360, axis = 'y')", + "part001 = 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 |> revolve(axis = 'y', angle = 180)", + "part001 = 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 |> revolve(axis = 'y', angle = 180)\n\npart002 = startSketchOn(part001, 'end')\n |> startProfileAt([4.5, -5], %)\n |> line(end = [0, 5])\n |> line(end = [5, 0])\n |> line(end = [0, -5])\n |> close()\n |> extrude(length = 5)", + "box = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20])\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = -90, axis = 'y')", + "box = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20], tag = $revolveAxis)\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = 90, axis = getOppositeEdge(revolveAxis))", + "box = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20])\n |> line(end = [20, 0])\n |> line(end = [0, -20], tag = $revolveAxis)\n |> close()\n |> extrude(length = 20)\n\nsketch001 = startSketchOn(box, \"END\")\n |> circle(center = [10, 10], radius = 4)\n |> revolve(angle = 90, axis = getOppositeEdge(revolveAxis), tolerance = 0.0001)", + "sketch001 = startSketchOn(XY)\n |> startProfileAt([10, 0], %)\n |> line(end = [5, -5])\n |> line(end = [5, 5])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\npart001 = revolve(\n sketch001,\n axis = {\n custom = {\n axis = [0.0, 1.0],\n origin = [0.0, 0.0]\n }\n },\n)", + "// Revolve two sketches around the same axis.\n\n\nsketch001 = startSketchOn(XY)\nprofile001 = startProfileAt([4, 8], sketch001)\n |> xLine(length = 3)\n |> yLine(length = -3)\n |> xLine(length = -3)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nprofile002 = startProfileAt([-5, 8], sketch001)\n |> xLine(length = 3)\n |> yLine(length = -3)\n |> xLine(length = -3)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\nrevolve([profile001, profile002], axis = \"X\")", + "// Revolve around a path that has not been extruded.\n\n\nprofile001 = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20], tag = $revolveAxis)\n |> line(end = [20, 0])\n |> line(end = [0, -20])\n |> close(%)\n\nsketch001 = startSketchOn(XY)\n |> circle(center = [-10, 10], radius = 4)\n |> revolve(angle = 90, axis = revolveAxis)", + "// Revolve around a path that has not been extruded or closed.\n\n\nprofile001 = startSketchOn(XY)\n |> startProfileAt([0, 0], %)\n |> line(end = [0, 20], tag = $revolveAxis)\n |> line(end = [20, 0])\n\nsketch001 = startSketchOn(XY)\n |> circle(center = [-10, 10], radius = 4)\n |> revolve(angle = 90, axis = revolveAxis)" ] }, { @@ -271286,11 +271286,11 @@ "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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> rotate(roll = 10, pitch = 10, yaw = 90)", - "// Rotate a pipe about an axis with an angle.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn('XZ')\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> rotate(axis = [0, 0, 1.0], angle = 90)", + "// Rotate 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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> rotate(roll = 10, pitch = 10, yaw = 90)", + "// Rotate a pipe about an axis with an angle.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> rotate(axis = [0, 0, 1.0], angle = 90)", "// Rotate an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> rotate(axis = [0, 0, 1.0], angle = 90)", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn('XY')\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn('YZ')\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Rotate the sweeps.\nrotate(parts, axis = [0, 0, 1.0], angle = 90)", - "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn('XY')\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Rotate the sweeps.\nrotate(parts, axis = [0, 0, 1.0], angle = 90)", + "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" ] }, { @@ -271332,7 +271332,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 |> 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)" ] }, { @@ -277877,9 +277877,9 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Scale a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn('XZ')\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> scale(scale = [1.0, 1.0, 2.5])", + "// Scale a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> scale(scale = [1.0, 1.0, 2.5])", "// Scale an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> scale(scale = [1.0, 1.0, 2.5])", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn('XY')\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn('YZ')\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(parts, scale = [1.0, 1.0, 0.5])" + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Scale the sweep.\nscale(parts, scale = [1.0, 1.0, 0.5])" ] }, { @@ -277927,7 +277927,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([segAng(seg01), 10], %)\n |> line(end = [-10, 0])\n |> angledLine([segAng(seg01), -15], %)\n |> close()\n\nexample = extrude(exampleSketch, length = 4)" + "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([segAng(seg01), 10], %)\n |> line(end = [-10, 0])\n |> angledLine([segAng(seg01), -15], %)\n |> close()\n\nexample = extrude(exampleSketch, length = 4)" ] }, { @@ -277980,7 +277980,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 |> 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)" ] }, { @@ -278028,7 +278028,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 |> 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)" ] }, { @@ -278076,7 +278076,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 |> 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)" ] }, { @@ -278124,7 +278124,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 60, length = 10 }, %, $thing)\n |> tangentialArc({ offset = -120, radius = 5 }, %)\n |> angledLine({ angle = -60, length = segLen(thing) }, %)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 60, length = 10 }, %, $thing)\n |> tangentialArc({ offset = -120, radius = 5 }, %)\n |> angledLine({ angle = -60, length = segLen(thing) }, %)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -278177,7 +278177,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 |> 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)" ] }, { @@ -278225,7 +278225,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 |> 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)" ] }, { @@ -278273,7 +278273,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 |> 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)" ] }, { @@ -284714,13 +284714,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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> 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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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 |> tangentialArcTo([-size, size], %)\n |> close()\n |> extrude(length = 65)\n\nthing1 = startSketchOn(case, 'end')\n |> circle(center = [-size / 2, -size / 2], radius = 25)\n |> extrude(length = 50)\n\nthing2 = startSketchOn(case, '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)" ] }, { @@ -284762,7 +284762,7 @@ "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 |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 50, length = sqrt(2500) }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -299941,7 +299941,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "fn 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\npart001 = cube([0, 0])\npart002 = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 10)\n\nsubtractedPart = subtract([part001], tools = [part002])" + "fn 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\npart001 = cube([0, 0])\npart002 = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> extrude(length = 10)\n\nsubtractedPart = subtract([part001], tools = [part002])" ] }, { @@ -311369,9 +311369,9 @@ "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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)", - "// 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([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn('YZ')\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nsweep([rectangleSketch, circleSketch], path = sweepPath)" + "// 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({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)", + "// 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([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nsweep([rectangleSketch, circleSketch], path = sweepPath)" ] }, { @@ -311419,11 +311419,11 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Horizontal pill.\npillSketch = startSketchOn('XZ')\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0])\n |> tangentialArcToRelative([0, 10], %, $arc1)\n |> angledLine({\n angle = tangentToEnd(arc1),\n length = 20\n }, %)\n |> tangentialArcToRelative([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 |> tangentialArcTo([10, 20], %, $arc1)\n |> angledLine({\n angle = tangentToEnd(arc1),\n length = 20\n }, %)\n |> tangentialArcToRelative([-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({\n angle = tangentToEnd(seg1),\n length = 10\n }, %)\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 |> arcTo({ end = [10, 10], interior = [5, 1] }, %, $arc1)\n |> angledLine([tangentToEnd(arc1), 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([tangentToEnd(circ), 10], %)\n |> line(end = [-15, 0])\n |> close()" + "// Horizontal pill.\npillSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> line(end = [20, 0])\n |> tangentialArcToRelative([0, 10], %, $arc1)\n |> angledLine({\n angle = tangentToEnd(arc1),\n length = 20\n }, %)\n |> tangentialArcToRelative([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 |> tangentialArcTo([10, 20], %, $arc1)\n |> angledLine({\n angle = tangentToEnd(arc1),\n length = 20\n }, %)\n |> tangentialArcToRelative([-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({\n angle = tangentToEnd(seg1),\n length = 10\n }, %)\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 |> arcTo({ end = [10, 10], interior = [5, 1] }, %, $arc1)\n |> angledLine([tangentToEnd(arc1), 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([tangentToEnd(circ), 10], %)\n |> line(end = [-15, 0])\n |> close()" ] }, { @@ -326295,7 +326295,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 |> startProfileAt([0, 0], %)\n |> angledLine({ angle = 50, length = 10 * tau() }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -326337,7 +326337,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 50,\n length = 70 * cos(toDegrees(pi() / 4))\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 50,\n length = 70 * cos(toDegrees(pi() / 4))\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -326379,7 +326379,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "exampleSketch = startSketchOn(\"XZ\")\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 50,\n length = 70 * cos(toRadians(45))\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" + "exampleSketch = startSketchOn(XZ)\n |> startProfileAt([0, 0], %)\n |> angledLine({\n angle = 50,\n length = 70 * cos(toRadians(45))\n }, %)\n |> yLine(endAbsolute = 0)\n |> close()\n\nexample = extrude(exampleSketch, length = 5)" ] }, { @@ -332924,11 +332924,11 @@ "unpublished": false, "deprecated": false, "examples": [ - "// Move a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn('XZ')\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn('XY')\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> translate(translate = [1.0, 1.0, 2.5])", + "// Move a pipe.\n\n// Create a path for the sweep.\nsweepPath = startSketchOn(XZ)\n |> startProfileAt([0.05, 0.05], %)\n |> line(end = [0, 7])\n |> tangentialArc({ offset = 90, radius = 5 }, %)\n |> line(end = [-3, 0])\n |> tangentialArc({ offset = -90, radius = 5 }, %)\n |> line(end = [0, 7])\n\n// Create a hole for the pipe.\npipeHole = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 1.5)\n\nsweepSketch = startSketchOn(XY)\n |> circle(center = [0, 0], radius = 2)\n |> hole(pipeHole, %)\n |> sweep(path = sweepPath)\n |> translate(translate = [1.0, 1.0, 2.5])", "// Move an imported model.\n\n\nimport \"tests/inputs/cube.sldprt\" as cube\n\ncube\n |> translate(translate = [1.0, 1.0, 2.5])", - "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn('XY')\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn('YZ')\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Move the sweeps.\ntranslate(parts, translate = [1.0, 1.0, 2.5])", + "// Sweep two sketches along the same path.\n\n\nsketch001 = startSketchOn(XY)\nrectangleSketch = startProfileAt([-200, 23.86], sketch001)\n |> angledLine([0, 73.47], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 50.61\n ], %)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n\ncircleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63)\n\nsketch002 = startSketchOn(YZ)\nsweepPath = startProfileAt([0, 0], sketch002)\n |> yLine(length = 231.81)\n |> tangentialArc({ radius = 80, offset = -90 }, %)\n |> xLine(length = 384.93)\n\nparts = sweep([rectangleSketch, circleSketch], path = sweepPath)\n\n// Move the sweeps.\ntranslate(parts, translate = [1.0, 1.0, 2.5])", "// Move a sketch.\n\n\nfn square(length) {\n l = length / 2\n p0 = [-l, -l]\n p1 = [-l, l]\n p2 = [l, l]\n p3 = [l, -l]\n\n return startSketchOn(XY)\n |> startProfileAt(p0, %)\n |> line(endAbsolute = p1)\n |> line(endAbsolute = p2)\n |> line(endAbsolute = p3)\n |> close()\n}\n\nsquare(10)\n |> translate(translate = [5, 5, 0])\n |> extrude(length = 10)", - "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn('XY')\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" + "// Translate and rotate a sketch to create a loft.\nsketch001 = startSketchOn(XY)\n\nfn square() {\n return startProfileAt([-10, 10], sketch001)\n |> xLine(length = 20)\n |> yLine(length = -20)\n |> xLine(length = -20)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\n}\n\nprofile001 = square()\n\nprofile002 = square()\n |> translate(translate = [0, 0, 20])\n |> rotate(axis = [0, 0, 1.0], angle = 45)\n\nloft([profile001, profile002])" ] }, { @@ -336139,7 +336139,7 @@ "unpublished": false, "deprecated": true, "examples": [ - "fn 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\npart001 = cube([0, 0])\npart002 = cube([20, 10])\n\nunionedPart = union([part001, part002])" + "fn 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\npart001 = cube([0, 0])\npart002 = cube([20, 10])\n\nunionedPart = union([part001, part002])" ] }, { diff --git a/docs/kcl/subtract.md b/docs/kcl/subtract.md index 32e864e4f..7b83aaf99 100644 --- a/docs/kcl/subtract.md +++ b/docs/kcl/subtract.md @@ -34,7 +34,7 @@ subtract( ```js fn cube(center) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([center[0] - 10, center[1] - 10], %) |> line(endAbsolute = [center[0] + 10, center[1] - 10]) |> line(endAbsolute = [center[0] + 10, center[1] + 10]) @@ -44,7 +44,7 @@ fn cube(center) { } part001 = cube([0, 0]) -part002 = startSketchOn('XY') +part002 = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> extrude(length = 10) diff --git a/docs/kcl/sweep.md b/docs/kcl/sweep.md index 97cef72ae..fd6edc3e4 100644 --- a/docs/kcl/sweep.md +++ b/docs/kcl/sweep.md @@ -44,7 +44,7 @@ sweep( // Create a pipe using a sweep. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -53,10 +53,10 @@ sweepPath = startSketchOn('XZ') |> line(end = [0, 7]) // Create a hole for the pipe. -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) @@ -78,7 +78,7 @@ helixPath = helix( ) // Create a spring by sweeping around the helix path. -springSketch = startSketchOn('YZ') +springSketch = startSketchOn(YZ) |> circle(center = [0, 0], radius = 1) |> sweep(path = helixPath) ``` @@ -89,7 +89,7 @@ springSketch = startSketchOn('YZ') // Sweep two sketches along the same path. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) rectangleSketch = startProfileAt([-200, 23.86], sketch001) |> angledLine([0, 73.47], %, $rectangleSegmentA001) |> angledLine([ @@ -105,7 +105,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) -sketch002 = startSketchOn('YZ') +sketch002 = startSketchOn(YZ) sweepPath = startProfileAt([0, 0], sketch002) |> yLine(length = 231.81) |> tangentialArc({ radius = 80, offset = -90 }, %) diff --git a/docs/kcl/tangentToEnd.md b/docs/kcl/tangentToEnd.md index 1175a5b80..5171881ab 100644 --- a/docs/kcl/tangentToEnd.md +++ b/docs/kcl/tangentToEnd.md @@ -28,7 +28,7 @@ tangentToEnd(tag: TagIdentifier): number ```js // Horizontal pill. -pillSketch = startSketchOn('XZ') +pillSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [20, 0]) |> tangentialArcToRelative([0, 10], %, $arc1) @@ -46,7 +46,7 @@ pillExtrude = extrude(pillSketch, length = 10) ```js // Vertical pill. Use absolute coordinate for arc. -pillSketch = startSketchOn('XZ') +pillSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> tangentialArcTo([10, 20], %, $arc1) @@ -63,7 +63,7 @@ pillExtrude = extrude(pillSketch, length = 10) ![Rendered example of tangentToEnd 1]() ```js -rectangleSketch = startSketchOn('XZ') +rectangleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0], tag = $seg1) |> angledLine({ @@ -80,7 +80,7 @@ rectangleExtrude = extrude(rectangleSketch, length = 10) ![Rendered example of tangentToEnd 2]() ```js -bottom = startSketchOn("XY") +bottom = startSketchOn(XY) |> startProfileAt([0, 0], %) |> arcTo({ end = [10, 10], interior = [5, 1] }, %, $arc1) |> angledLine([tangentToEnd(arc1), 20], %) @@ -90,10 +90,10 @@ bottom = startSketchOn("XY") ![Rendered example of tangentToEnd 3]() ```js -circSketch = startSketchOn("XY") +circSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 3, tag = $circ) -triangleSketch = startSketchOn("XY") +triangleSketch = startSketchOn(XY) |> startProfileAt([-5, 0], %) |> angledLine([tangentToEnd(circ), 10], %) |> line(end = [-15, 0]) diff --git a/docs/kcl/tau.md b/docs/kcl/tau.md index d61dc76fa..0080e0edd 100644 --- a/docs/kcl/tau.md +++ b/docs/kcl/tau.md @@ -28,7 +28,7 @@ tau(): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 50, length = 10 * tau() }, %) |> yLine(endAbsolute = 0) diff --git a/docs/kcl/toDegrees.md b/docs/kcl/toDegrees.md index ec80fdc30..a14fd13b6 100644 --- a/docs/kcl/toDegrees.md +++ b/docs/kcl/toDegrees.md @@ -31,7 +31,7 @@ toDegrees(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 50, diff --git a/docs/kcl/toRadians.md b/docs/kcl/toRadians.md index f99e4fbb4..44de6b8c0 100644 --- a/docs/kcl/toRadians.md +++ b/docs/kcl/toRadians.md @@ -31,7 +31,7 @@ toRadians(num: number): number ### Examples ```js -exampleSketch = startSketchOn("XZ") +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine({ angle = 50, diff --git a/docs/kcl/translate.md b/docs/kcl/translate.md index 3a986de2c..7fbb197a8 100644 --- a/docs/kcl/translate.md +++ b/docs/kcl/translate.md @@ -36,7 +36,7 @@ translate( // Move a pipe. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -45,10 +45,10 @@ sweepPath = startSketchOn('XZ') |> line(end = [0, 7]) // Create a hole for the pipe. -pipeHole = startSketchOn('XY') +pipeHole = startSketchOn(XY) |> circle(center = [0, 0], radius = 1.5) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> circle(center = [0, 0], radius = 2) |> hole(pipeHole, %) |> sweep(path = sweepPath) @@ -73,7 +73,7 @@ cube // Sweep two sketches along the same path. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) rectangleSketch = startProfileAt([-200, 23.86], sketch001) |> angledLine([0, 73.47], %, $rectangleSegmentA001) |> angledLine([ @@ -89,7 +89,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) -sketch002 = startSketchOn('YZ') +sketch002 = startSketchOn(YZ) sweepPath = startProfileAt([0, 0], sketch002) |> yLine(length = 231.81) |> tangentialArc({ radius = 80, offset = -90 }, %) @@ -131,7 +131,7 @@ square(10) ```js // Translate and rotate a sketch to create a loft. -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) fn square() { return startProfileAt([-10, 10], sketch001) diff --git a/docs/kcl/union.md b/docs/kcl/union.md index d9e9337b7..6f841d90b 100644 --- a/docs/kcl/union.md +++ b/docs/kcl/union.md @@ -30,7 +30,7 @@ union(solids: [Solid]): [Solid] ```js fn cube(center) { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([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/e2e/playwright/basic-sketch.spec.ts b/e2e/playwright/basic-sketch.spec.ts index f558fa88e..fd79e64cb 100644 --- a/e2e/playwright/basic-sketch.spec.ts +++ b/e2e/playwright/basic-sketch.spec.ts @@ -5,6 +5,7 @@ import { TEST_COLORS, commonPoints, PERSIST_MODELING_CONTEXT, + orRunWhenFullSuiteEnabled, } from './test-utils' import { HomePageFixture } from './fixtures/homePageFixture' @@ -46,7 +47,7 @@ async function doBasicSketch( await page.mouse.click(700, 200) if (openPanes.includes('code')) { - await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')`) + await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ)`) } await u.closeDebugPanel() @@ -56,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 = startProfileAt(${commonPoints.startAt}, sketch001)` ) } await page.waitForTimeout(500) @@ -65,14 +66,14 @@ 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 = startProfileAt(${commonPoints.startAt}, sketch001) |> xLine(length = ${commonPoints.num1})`) } await page.waitForTimeout(500) await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20) if (openPanes.includes('code')) { await expect(u.codeLocator) - .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ + .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -154,7 +155,7 @@ async function doBasicSketch( test.describe('Basic sketch', { tag: ['@skipWin'] }, () => { test('code pane open at start', async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await doBasicSketch(page, homePage, ['code']) }) diff --git a/e2e/playwright/code-pane-and-errors.spec.ts b/e2e/playwright/code-pane-and-errors.spec.ts index 91fcd8210..ffef789f3 100644 --- a/e2e/playwright/code-pane-and-errors.spec.ts +++ b/e2e/playwright/code-pane-and-errors.spec.ts @@ -1,6 +1,9 @@ import { test, expect } from './zoo-test' - -import { getUtils, executorInputPath } from './test-utils' +import { + orRunWhenFullSuiteEnabled, + getUtils, + executorInputPath, +} from './test-utils' import { join } from 'path' import { bracket } from 'lib/exampleKcl' import { TEST_CODE_LONG_WITH_ERROR_OUT_OF_VIEW } from './storageStates' @@ -19,7 +22,7 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `// Extruded Triangle - sketch001 = startSketchOn('XZ') + sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> line(end = [-5, 10]) @@ -51,7 +54,7 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { homePage, editor, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) // Load the app with the working starter code @@ -125,7 +128,7 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { homePage, context, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) // Load the app with the working starter code await context.addInitScript((code) => { localStorage.setItem('persistCode', code) diff --git a/e2e/playwright/command-bar-tests.spec.ts b/e2e/playwright/command-bar-tests.spec.ts index 34ffee1c7..41deb75c4 100644 --- a/e2e/playwright/command-bar-tests.spec.ts +++ b/e2e/playwright/command-bar-tests.spec.ts @@ -1,6 +1,10 @@ import { test, expect } from './zoo-test' import * as fsp from 'fs/promises' -import { executorInputPath, getUtils } from './test-utils' +import { + executorInputPath, + getUtils, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { KCL_DEFAULT_LENGTH } from 'lib/constants' import path, { join } from 'path' @@ -12,7 +16,7 @@ test.describe('Command bar tests', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -48,11 +52,11 @@ test.describe('Command bar tests', { tag: ['@skipWin'] }, () => { // TODO: fix this test after the electron migration test('Fillet from command bar', async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-5, -5], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -235,7 +239,7 @@ test.describe('Command bar tests', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `distance = sqrt(20) - sketch001 = startSketchOn('XZ') + sketch001 = startSketchOn(XZ) |> startProfileAt([-6.95, 10.98], %) |> line(end = [25.1, 0.41]) |> line(end = [0.73, -20.93]) diff --git a/e2e/playwright/copilot-ghost-test.spec.ts b/e2e/playwright/copilot-ghost-test.spec.ts index 70531ed12..c7f552258 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) |> 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)` ) 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) |> 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)` ) // 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) |> 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) ` ) 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) |> 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)` ) 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) |> 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)` ) }) @@ -123,7 +123,7 @@ test.describe('Copilot ghost text', () => { await page.waitForTimeout(500) await expect(page.locator('.cm-ghostText').first()).not.toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) // Escape to exit the tool. @@ -139,7 +139,7 @@ test.describe('Copilot ghost text', () => { await page.waitForTimeout(500) await expect(page.locator('.cm-ghostText').first()).not.toBeVisible() await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) // Escape again to exit sketch mode. @@ -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) |> 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)` ) 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) |> 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)` ) // 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) |> 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) ` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) }) @@ -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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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) |> 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)` ) 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 317a225a3..59ff83605 100644 --- a/e2e/playwright/debug-pane.spec.ts +++ b/e2e/playwright/debug-pane.spec.ts @@ -18,7 +18,7 @@ test.describe('Debug pane', () => { context, homePage, }) => { - const code = `sketch001 = startSketchOn('XZ') + const code = `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [1, 1]) ` diff --git a/e2e/playwright/editor-tests.spec.ts b/e2e/playwright/editor-tests.spec.ts index ed0293e36..5365095b2 100644 --- a/e2e/playwright/editor-tests.spec.ts +++ b/e2e/playwright/editor-tests.spec.ts @@ -2,10 +2,10 @@ import { test, expect } from './zoo-test' import fsp from 'fs/promises' import { uuidv4 } from 'lib/utils' import { - darkModeBgColor, - darkModePlaneColorXZ, executorInputPath, getUtils, + orRunWhenFullSuiteEnabled, + TEST_COLORS, } from './test-utils' import { join } from 'path' @@ -21,7 +21,7 @@ test.describe('Editor tests', { tag: ['@skipWin'] }, () => { await expect(page.locator('.cm-lint-marker-error')).not.toBeVisible() await u.codeLocator.click() - await page.keyboard.type(`sketch001 = startSketchOn('XY') + await page.keyboard.type(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -69,7 +69,7 @@ sketch001 = startSketchOn('XY') await u.waitForPageLoad() await u.codeLocator.click() - await page.keyboard.type(`sketch001 = startSketchOn('XY') + await page.keyboard.type(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -118,7 +118,7 @@ sketch001 = startSketchOn('XY') await u.waitForPageLoad() await u.codeLocator.click() - await page.keyboard.type(`sketch001 = startSketchOn('XY') + await page.keyboard.type(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -173,7 +173,7 @@ sketch001 = startSketchOn('XY') await expect(page.locator('.cm-lint-marker-error')).not.toBeVisible() await u.codeLocator.click() - await page.keyboard.type(`sketch001 = startSketchOn('XY') + await page.keyboard.type(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -206,7 +206,7 @@ sketch001 = startSketchOn('XY') await expect(page.locator('.cm-lint-marker-error')).not.toBeVisible() await u.codeLocator.click() - await page.keyboard.type(`sketch_001 = startSketchOn('XY') + await page.keyboard.type(`sketch_001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -254,7 +254,7 @@ sketch_001 = startSketchOn('XY') }) test('fold gutters work', async ({ page, homePage }) => { - const fullCode = `sketch001 = startSketchOn('XY') + const fullCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -263,7 +263,7 @@ sketch_001 = startSketchOn('XY') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -301,7 +301,7 @@ sketch_001 = startSketchOn('XY') await foldGutterFoldLine.click() await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XY')… ` + `sketch001 = startSketchOn(XY)… ` ) await expect(page.locator('.cm-content')).not.toHaveText(fullCode) await expect(foldGutterFoldLine).not.toBeVisible() @@ -332,7 +332,7 @@ sketch_001 = startSketchOn('XY') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -379,7 +379,7 @@ sketch_001 = startSketchOn('XY') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -406,7 +406,7 @@ sketch_001 = startSketchOn('XY') await page.keyboard.press('Alt+Shift+KeyF') await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XY') + .toHaveText(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -422,7 +422,7 @@ sketch_001 = startSketchOn('XY') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch_001 = startSketchOn('XY') + `sketch_001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -459,7 +459,7 @@ sketch_001 = startSketchOn('XY') await u.closeDebugPanel() await expect(page.locator('.cm-content')) - .toHaveText(`sketch_001 = startSketchOn('XY') + .toHaveText(`sketch_001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -532,7 +532,7 @@ sketch_001 = startSketchOn('XY') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) @@ -647,7 +647,7 @@ sketch_001 = startSketchOn('XY') page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await page.addInitScript(async () => { localStorage.setItem( @@ -658,7 +658,7 @@ sketch_001 = startSketchOn('XY') dia = 4 fn squareHole = (l, w) => { - squareHoleSketch = startSketchOn('XY') + squareHoleSketch = startSketchOn(XY) |> startProfileAt([-width / 2, -length / 2], %) |> line(endAbsolute = [width / 2, -length / 2]) |> line(endAbsolute = [width / 2, length / 2]) @@ -698,7 +698,7 @@ sketch_001 = startSketchOn('XY') await page.keyboard.press('ArrowDown') await page.keyboard.press('ArrowDown') await page.keyboard.press('Enter') - await page.keyboard.type(`extrusion = startSketchOn('XY') + await page.keyboard.type(`extrusion = startSketchOn(XY) |> circle(center: [0, 0], radius: dia/2) |> hole(squareHole(length, width, height), %) |> extrude(length = height)`) @@ -721,7 +721,7 @@ sketch_001 = startSketchOn('XY') await context.addInitScript(async () => { localStorage.setItem( 'persistCode', - `box = startSketchOn('XY') + `box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -780,7 +780,7 @@ sketch_001 = startSketchOn('XY') }).toPass() // this makes sure we can accept a completion with click await page.getByText('startSketchOn').click() - await page.keyboard.type("'XZ'") + await page.keyboard.type('XZ') await page.keyboard.press('Tab') await page.keyboard.press('Enter') await page.keyboard.type(' |> startProfi') @@ -856,7 +856,7 @@ sketch001 = startSketchOn('XZ') await page.keyboard.press('ArrowDown') await page.keyboard.press('Tab') await page.waitForTimeout(500) - await page.keyboard.type("'XZ'") + await page.keyboard.type('XZ') await page.keyboard.press('Tab') await page.keyboard.press('Enter') await page.keyboard.type(' |> startProfi') @@ -915,7 +915,7 @@ sketch001 = startSketchOn('XZ') await context.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) @@ -967,7 +967,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]) |> tangentialArcTo([24.95, -5.38], %) |> close()extrude001 = extrude(sketch001, length = 5)` + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) |> close()extrude001 = extrude(sketch001, length = 5)` ) // Now hit undo @@ -977,7 +977,7 @@ sketch001 = startSketchOn('XZ') await page.waitForTimeout(100) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) @@ -992,7 +992,7 @@ sketch001 = startSketchOn('XZ') await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -10.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -0.38], %) @@ -1083,7 +1083,7 @@ sketch001 = startSketchOn('XZ') // expect the code to have changed await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([2.71, -2.71], %) |> line(end = [15.4, -2.78]) |> tangentialArcTo([27.6, -3.05], %) @@ -1097,7 +1097,7 @@ sketch001 = startSketchOn('XZ') await page.keyboard.up('Control') await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([2.71, -2.71], %) |> line(end = [15.4, -2.78]) |> tangentialArcTo([24.95, -0.38], %) @@ -1110,7 +1110,7 @@ sketch001 = startSketchOn('XZ') await page.keyboard.up('Control') await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([2.71, -2.71], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -0.38], %) @@ -1125,7 +1125,7 @@ sketch001 = startSketchOn('XZ') await page.waitForTimeout(100) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -10.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -0.38], %) @@ -1138,7 +1138,7 @@ sketch001 = startSketchOn('XZ') `Can use the import stdlib function on a local OBJ file`, { tag: '@electron' }, async ({ page, context }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await context.folderSetupFn(async (dir) => { const bracketDir = join(dir, 'cube') await fsp.mkdir(bracketDir, { recursive: true }) @@ -1175,7 +1175,8 @@ sketch001 = startSketchOn('XZ') await u.waitForPageLoad() await expect .poll( - async () => locationToHavColor(notTheOrigin, darkModePlaneColorXZ), + async () => + locationToHavColor(notTheOrigin, TEST_COLORS.DARK_MODE_PLANE_XZ), { timeout: 5000, message: 'XZ plane color is visible', @@ -1196,16 +1197,23 @@ sketch001 = startSketchOn('XZ') await test.step(`Verify that we see the imported geometry and no errors`, async () => { await expect(errorIndicators).toHaveCount(0) await expect - .poll(async () => locationToHavColor(origin, darkModePlaneColorXZ), { - timeout: 3000, - message: 'Plane color should not be visible', - }) + .poll( + async () => + locationToHavColor(origin, TEST_COLORS.DARK_MODE_PLANE_XZ), + { + timeout: 3000, + message: 'Plane color should not be visible', + } + ) .toBeGreaterThan(15) await expect - .poll(async () => locationToHavColor(origin, darkModeBgColor), { - timeout: 3000, - message: 'Background color should not be visible', - }) + .poll( + async () => locationToHavColor(origin, TEST_COLORS.DARK_MODE_BKGD), + { + timeout: 3000, + message: 'Background color should not be visible', + } + ) .toBeGreaterThan(15) }) } diff --git a/e2e/playwright/feature-tree-pane.spec.ts b/e2e/playwright/feature-tree-pane.spec.ts index c04269508..54e4ed0b6 100644 --- a/e2e/playwright/feature-tree-pane.spec.ts +++ b/e2e/playwright/feature-tree-pane.spec.ts @@ -6,7 +6,7 @@ const FEATURE_TREE_EXAMPLE_CODE = `export fn timesFive(x) { return 5 * x } export fn triangle() { - return startSketchOn('XZ') + return startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = 10) |> line(end = [-10, -5]) @@ -15,7 +15,7 @@ export fn triangle() { } length001 = timesFive(1) * 5 -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([20, 10], %) |> line(end = [10, 10]) |> angledLine([-45, length001], %) @@ -24,7 +24,7 @@ sketch001 = startSketchOn('XZ') revolve001 = revolve(sketch001, axis = "X") triangle() |> extrude(length = 30) -plane001 = offsetPlane('XY', offset = 10) +plane001 = offsetPlane(XY, offset = 10) sketch002 = startSketchOn(plane001) |> startProfileAt([-20, 0], %) |> line(end = [5, -15]) @@ -35,7 +35,7 @@ sketch002 = startSketchOn(plane001) extrude001 = extrude(sketch002, length = 10) ` -const FEATURE_TREE_SKETCH_CODE = `sketch001 = startSketchOn('XZ') +const FEATURE_TREE_SKETCH_CODE = `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLine([0, 4], %, $rectangleSegmentA001) |> angledLine([ @@ -54,7 +54,7 @@ sketch002 = startSketchOn(extrude001, rectangleSegmentB001) center = [-1, 2], radius = .5 ) -plane001 = offsetPlane('XZ', offset = -5) +plane001 = offsetPlane(XZ, offset = -5) sketch003 = startSketchOn(plane001) |> circle(center = [0, 0], radius = 5) ` @@ -116,7 +116,7 @@ test.describe('Feature Tree pane', () => { await testViewSource({ operationName: 'Offset Plane', operationIndex: 0, - expectedActiveLine: "plane001 = offsetPlane('XY', offset = 10)", + expectedActiveLine: 'plane001 = offsetPlane(XY, offset = 10)', }) await testViewSource({ operationName: 'Extrude', @@ -174,7 +174,7 @@ test.describe('Feature Tree pane', () => { await editor.expectState({ highlightedCode: '', diagnostics: [], - activeLines: ["sketch001 = startSketchOn('XZ')"], + activeLines: ['sketch001 = startSketchOn(XZ)'], }) await toolbar.exitSketchBtn.click() }) @@ -227,12 +227,12 @@ test.describe('Feature Tree pane', () => { page, }) => { const initialInput = '23' - const initialCode = `sketch001 = startSketchOn('XZ') + const initialCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 5) renamedExtrude = extrude(sketch001, length = ${initialInput})` const newConstantName = 'distance001' const expectedCode = `${newConstantName} = 23 - sketch001 = startSketchOn('XZ') + sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 5) renamedExtrude = extrude(sketch001, length = ${newConstantName})` @@ -316,8 +316,7 @@ test.describe('Feature Tree pane', () => { toolbar, cmdBar, }) => { - const testCode = (value: string) => - `p = offsetPlane('XY', offset = ${value})` + const testCode = (value: string) => `p = offsetPlane(XY, offset = ${value})` const initialInput = '10' const initialCode = testCode(initialInput) const newInput = '5 + 10' @@ -396,7 +395,7 @@ test.describe('Feature Tree pane', () => { toolbar, cmdBar, }) => { - const beforeKclCode = `plane001 = offsetPlane('XY', offset = 5) + const beforeKclCode = `plane001 = offsetPlane(XY, offset = 5) sketch001 = startSketchOn(plane001) profile001 = circle(sketch001, center = [0, 20], radius = 12) profile002 = startProfileAt([0, 7.25], sketch001) diff --git a/e2e/playwright/file-tree.spec.ts b/e2e/playwright/file-tree.spec.ts index 1e90d485f..7ac2408a7 100644 --- a/e2e/playwright/file-tree.spec.ts +++ b/e2e/playwright/file-tree.spec.ts @@ -1,7 +1,12 @@ import { test, expect } from './zoo-test' import * as fsp from 'fs/promises' import * as fs from 'fs' -import { createProject, executorInputPath, getUtils } from './test-utils' +import { + createProject, + executorInputPath, + getUtils, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { join } from 'path' import { FILE_EXT } from 'lib/constants' @@ -272,7 +277,7 @@ test.describe('when using the file tree to', () => { tag: '@electron', }, async ({ page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const { panesOpen, pasteCodeInEditor, @@ -1059,7 +1064,7 @@ test.describe('Undo and redo do not keep history when navigating between files', // Click in the editor and add some new lines. await u.codeLocator.click() - await page.keyboard.type(`sketch001 = startSketchOn('XY') + await page.keyboard.type(`sketch001 = startSketchOn(XY) some other shit`) // Ensure the content in the editor changed. diff --git a/e2e/playwright/fixtures/editorFixture.ts b/e2e/playwright/fixtures/editorFixture.ts index f4719f0a4..ea393c26a 100644 --- a/e2e/playwright/fixtures/editorFixture.ts +++ b/e2e/playwright/fixtures/editorFixture.ts @@ -205,7 +205,7 @@ export class EditorFixture { // Use Playwright's built-in text selection on the code content // it seems to only select whole divs, which works out to align with syntax highlighting - // for code mirror, so you can probably select "sketch002 = startSketchOn('XZ')" + // for code mirror, so you can probably select "sketch002 = startSketchOn(XZ)" // but less so for exactly "sketch002 = startS" await this.codeContent.getByText(text).first().selectText() diff --git a/e2e/playwright/onboarding-tests.spec.ts b/e2e/playwright/onboarding-tests.spec.ts index 7a0e80516..167f22010 100644 --- a/e2e/playwright/onboarding-tests.spec.ts +++ b/e2e/playwright/onboarding-tests.spec.ts @@ -6,6 +6,7 @@ import { executorInputPath, createProject, settingsToToml, + orRunWhenFullSuiteEnabled, } from './test-utils' import { bracket } from 'lib/exampleKcl' import { onboardingPaths } from 'routes/Onboarding/paths' @@ -116,7 +117,7 @@ test.describe('Onboarding tests', () => { } await tronApp.cleanProjectDir() - const initialCode = `sketch001 = startSketchOn('XZ')` + const initialCode = `sketch001 = startSketchOn(XZ)` // Load the page up with some code so we see the confirmation warning // when we go to replay onboarding @@ -325,7 +326,7 @@ test.describe('Onboarding tests', () => { homePage, tronApp, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) if (!tronApp) { fail() } @@ -398,7 +399,7 @@ test.describe('Onboarding tests', () => { homePage, tronApp, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) if (!tronApp) { fail() } @@ -457,7 +458,7 @@ test('Restarting onboarding on desktop takes one attempt', async ({ page, tronApp, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) if (!tronApp) { fail() } diff --git a/e2e/playwright/point-click.spec.ts b/e2e/playwright/point-click.spec.ts index cfa1dd366..2d11377ff 100644 --- a/e2e/playwright/point-click.spec.ts +++ b/e2e/playwright/point-click.spec.ts @@ -5,7 +5,7 @@ import { SceneFixture } from './fixtures/sceneFixture' import { ToolbarFixture } from './fixtures/toolbarFixture' import fs from 'node:fs/promises' import path from 'node:path' -import { getUtils } from './test-utils' +import { getUtils, orRunWhenFullSuiteEnabled } from './test-utils' import { Locator } from '@playwright/test' // test file is for testing point an click code gen functionality that's not sketch mode related @@ -45,7 +45,7 @@ test.describe('Point-and-click tests', () => { await moveToCircle() const circleSnippet = 'circle(center = [318.33, 168.1], radius = 182.8)' await editor.expectState({ - activeLines: ["sketch002=startSketchOn('XZ')"], + activeLines: ['sketch002=startSketchOn(XZ)'], highlightedCode: circleSnippet, diagnostics: [], }) @@ -54,7 +54,7 @@ test.describe('Point-and-click tests', () => { await moveToCircle() const circleSnippet = 'circle(center = [318.33, 168.1], radius = 182.8)' await editor.expectState({ - activeLines: ["sketch002=startSketchOn('XZ')"], + activeLines: ['sketch002=startSketchOn(XZ)'], highlightedCode: circleSnippet, diagnostics: [], }) @@ -525,7 +525,7 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) ) const expectedCodeSnippets = { - sketchOnXzPlane: `sketch001 = startSketchOn('XZ')`, + sketchOnXzPlane: `sketch001 = startSketchOn(XZ)`, pointAtOrigin: `startProfileAt([${originSloppy.kcl[0]}, ${originSloppy.kcl[1]}], sketch001)`, segmentOnXAxis: `xLine(length = ${xAxisSloppy.kcl[0]})`, afterSegmentDraggedOffYAxis: `startProfileAt([${offYAxis.kcl[0]}, ${offYAxis.kcl[1]}], sketch001)`, @@ -583,9 +583,9 @@ profile001 = startProfileAt([205.96, 254.59], sketch002) }) => { const u = await getUtils(page) - const initialCode = `closedSketch = startSketchOn('XZ') + const initialCode = `closedSketch = startSketchOn(XZ) |> circle(center = [8, 5], radius = 2) -openSketch = startSketchOn('XY') +openSketch = startSketchOn(XY) |> startProfileAt([-5, 0], %) |> line(endAbsolute = [0, 5]) |> xLine(length = 5) @@ -689,7 +689,7 @@ openSketch = startSketchOn('XY') scene, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0]) @@ -858,7 +858,7 @@ openSketch = startSketchOn('XY') scene, editor, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) // Locators const firstPointLocation = { x: 200, y: 100 } const secondPointLocation = { x: 800, y: 100 } @@ -1019,7 +1019,7 @@ openSketch = startSketchOn('XY') // One dumb hardcoded screen pixel value const testPoint = { x: 700, y: 150 } const [clickOnXzPlane] = scene.makeMouseHelpers(testPoint.x, testPoint.y) - const expectedOutput = `plane001 = offsetPlane('XZ', offset = 5)` + const expectedOutput = `plane001 = offsetPlane(XZ, offset = 5)` await homePage.goToModelingScene() // FIXME: Since there is no KCL code loaded. We need to wait for the scene to load before we continue. @@ -1195,9 +1195,9 @@ openSketch = startSketchOn('XY') toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('XZ') + const initialCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 30) - plane001 = offsetPlane('XZ', offset = 50) + plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) |> circle(center = [0, 0], radius = 20) ` @@ -1281,9 +1281,9 @@ openSketch = startSketchOn('XY') homePage, scene, }) => { - const initialCode = `sketch001 = startSketchOn('XZ') + const initialCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 30) - plane001 = offsetPlane('XZ', offset = 50) + plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) |> circle(center = [0, 0], radius = 20) loft001 = loft([sketch001, sketch002]) @@ -1330,7 +1330,7 @@ loft001 = loft([sketch001, sketch002]) await page.waitForTimeout(1000) await clickOnSketch2() await expect(page.locator('.cm-activeLine')).toHaveText(` - plane001 = offsetPlane('XZ', offset = 50) + plane001 = offsetPlane(XZ, offset = 50) `) await page.keyboard.press('Delete') // Check for sketch 1 @@ -1338,7 +1338,7 @@ loft001 = loft([sketch001, sketch002]) }) }) - test(`Sweep point-and-click`, async ({ + test(`Sweep point-and-click base`, async ({ context, page, homePage, @@ -1347,12 +1347,12 @@ loft001 = loft([sketch001, sketch002]) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('YZ') + const initialCode = `sketch001 = startSketchOn(YZ) |> circle( center = [0, 0], radius = 500 ) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = -500) |> tangentialArcTo([-2000, 500], %) @@ -1371,7 +1371,10 @@ sketch002 = startSketchOn('XZ') testPoint.x - 50, testPoint.y ) - const sweepDeclaration = 'sweep001 = sweep(sketch001, path = sketch002)' + const sweepDeclaration = + 'sweep001 = sweep(sketch001, path = sketch002, sectional = false)' + const editedSweepDeclaration = + 'sweep001 = sweep(sketch001, path = sketch002, sectional = true)' await test.step(`Look for sketch001`, async () => { await toolbar.closePane('code') @@ -1385,6 +1388,7 @@ sketch002 = startSketchOn('XZ') currentArgKey: 'target', currentArgValue: '', headerArguments: { + Sectional: '', Target: '', Trajectory: '', }, @@ -1397,6 +1401,7 @@ sketch002 = startSketchOn('XZ') currentArgKey: 'trajectory', currentArgValue: '', headerArguments: { + Sectional: '', Target: '1 face', Trajectory: '', }, @@ -1406,18 +1411,50 @@ sketch002 = startSketchOn('XZ') await clickOnSketch2() await page.waitForTimeout(500) await cmdBar.progressCmdBar() - await toolbar.openPane('code') - await page.waitForTimeout(500) + await cmdBar.expectState({ + commandName: 'Sweep', + headerArguments: { + Target: '1 face', + Trajectory: '1 segment', + Sectional: '', + }, + stage: 'review', + }) + await cmdBar.progressCmdBar() }) await test.step(`Confirm code is added to the editor, scene has changed`, async () => { - // await scene.expectPixelColor([135, 64, 73], testPoint, 15) // FIXME + await toolbar.openPane('code') await editor.expectEditor.toContain(sweepDeclaration) - await editor.expectState({ - diagnostics: [], - activeLines: [sweepDeclaration], - highlightedCode: '', + await toolbar.closePane('code') + }) + + await test.step('Edit sweep via feature tree selection works', async () => { + await toolbar.openPane('feature-tree') + const operationButton = await toolbar.getFeatureTreeOperation('Sweep', 0) + await operationButton.dblclick({ button: 'left' }) + await cmdBar.expectState({ + commandName: 'Sweep', + currentArgKey: 'sectional', + currentArgValue: '', + headerArguments: { + Sectional: '', + }, + highlightedHeaderArg: 'sectional', + stage: 'arguments', }) + await cmdBar.selectOption({ name: 'True' }).click() + await cmdBar.expectState({ + commandName: 'Sweep', + headerArguments: { + Sectional: '', + }, + stage: 'review', + }) + await cmdBar.progressCmdBar() + await toolbar.closePane('feature-tree') + await toolbar.openPane('code') + await editor.expectEditor.toContain(editedSweepDeclaration) await toolbar.closePane('code') }) @@ -1441,12 +1478,12 @@ sketch002 = startSketchOn('XZ') toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('YZ') + const initialCode = `sketch001 = startSketchOn(YZ) |> circle( center = [0, 0], radius = 500 ) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = -500) |> line(endAbsolute = [-2000, 500]) @@ -1478,6 +1515,7 @@ sketch002 = startSketchOn('XZ') currentArgKey: 'target', currentArgValue: '', headerArguments: { + Sectional: '', Target: '', Trajectory: '', }, @@ -1490,6 +1528,7 @@ sketch002 = startSketchOn('XZ') currentArgKey: 'trajectory', currentArgValue: '', headerArguments: { + Sectional: '', Target: '1 face', Trajectory: '', }, @@ -1515,7 +1554,7 @@ sketch002 = startSketchOn('XZ') cmdBar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0]) @@ -1750,7 +1789,7 @@ extrude001 = extrude(sketch001, length = -12) toolbar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0], tag = $seg02) @@ -1893,7 +1932,7 @@ fillet04 = fillet(extrude001, radius = 5, tags = [getOppositeEdge(seg02)]) cmdBar, }) => { // Create a cube with small edges that will cause some fillets to fail - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) profile001 = startProfileAt([0, 0], sketch001) |> yLine(length = -1) |> xLine(length = -10) @@ -2006,7 +2045,7 @@ extrude001 = extrude(profile001, length = 5) cmdBar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0]) @@ -2230,7 +2269,7 @@ extrude001 = extrude(sketch001, length = -12) toolbar, }) => { // Code samples - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-12, -6], %) |> line(end = [0, 12]) |> line(end = [24, 0], tag = $seg02) @@ -2384,7 +2423,7 @@ chamfer04 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg02)]) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('XZ') + const initialCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 30) extrude001 = extrude(sketch001, length = 30) ` @@ -2519,7 +2558,7 @@ extrude001 = extrude(sketch001, length = 30) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('XY') + const initialCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-20, 20], %) |> xLine(length = 40) |> yLine(length = -60) @@ -2637,7 +2676,7 @@ extrude001 = extrude(sketch001, length = 40) }) const shellSketchOnFacesCases = [ - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 100) |> extrude(length = 100) @@ -2645,7 +2684,7 @@ sketch002 = startSketchOn(sketch001, 'END') |> circle(center = [0, 0], radius = 50) |> extrude(length = 50) `, - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 100) extrude001 = extrude(sketch001, length = 100) @@ -2740,7 +2779,7 @@ extrude002 = extrude(sketch002, length = 50) toolbar, cmdBar, }) => { - const sketchCode = `sketch001 = startSketchOn('XY') + const sketchCode = `sketch001 = startSketchOn(XY) profile001 = startProfileAt([-20, 20], sketch001) |> xLine(length = 40) |> yLine(length = -60) @@ -2823,12 +2862,12 @@ profile001 = startProfileAt([-20, 20], sketch001) toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('YZ') + const initialCode = `sketch001 = startSketchOn(YZ) |> circle( center = [0, 0], radius = 500 ) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = -2000) sweep001 = sweep(sketch001, path = sketch002) @@ -2883,7 +2922,7 @@ sweep001 = sweep(sketch001, path = sketch002) cmdBar, }) => { const initialCode = ` -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([-100.0, 100.0], %) |> angledLine([0, 200.0], %, $rectangleSegmentA001) |> angledLine([segAng(rectangleSegmentA001) - 90, 200], %, $rectangleSegmentB001) @@ -2939,7 +2978,7 @@ segAng(rectangleSegmentA002), cmdBar, }) => { const initialCode = ` -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([-102.57, 101.72], %) |> angledLine([0, 202.6], %, $rectangleSegmentA001) |> angledLine([ @@ -2989,7 +3028,7 @@ radius = 8.69 cmdBar, }) => { const initialCode = ` - sketch002 = startSketchOn('XY') + sketch002 = startSketchOn(XY) |> startProfileAt([-2.02, 1.79], %) |> xLine(length = 2.6) sketch001 = startSketchOn('-XY') @@ -3041,7 +3080,7 @@ radius = 8.69 toolbar, cmdBar, }) => { - const initialCode = `sketch001 = startSketchOn('XZ') + const initialCode = `sketch001 = startSketchOn(XZ) profile001 = circle( sketch001, center = [0, 0], diff --git a/e2e/playwright/projects.spec.ts b/e2e/playwright/projects.spec.ts index 63d86f724..9a901db5c 100644 --- a/e2e/playwright/projects.spec.ts +++ b/e2e/playwright/projects.spec.ts @@ -7,6 +7,7 @@ import { Paths, createProject, getPlaywrightDownloadDir, + orRunWhenFullSuiteEnabled, } from './test-utils' import fsp from 'fs/promises' import fs from 'fs' @@ -1248,7 +1249,7 @@ test( 'Deleting projects, can delete individual project, can still create projects after deleting all', { tag: '@electron' }, async ({ context, page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const projectData = [ ['router-template-slate', 'cylinder.kcl'], ['bracket', 'focusrite_scarlett_mounting_braket.kcl'], @@ -1471,7 +1472,7 @@ test( 'When the project folder is empty, user can create new project and open it.', { tag: '@electron' }, async ({ page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await page.setBodyDimensions({ width: 1200, height: 500 }) @@ -2061,7 +2062,7 @@ test( 'Original project name persist after onboarding', { tag: '@electron' }, async ({ page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await page.setBodyDimensions({ width: 1200, height: 500 }) const getAllProjects = () => page.getByTestId('project-link').all() diff --git a/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts b/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts index df19c18f6..083ea8406 100644 --- a/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts +++ b/e2e/playwright/prompt-to-edit-snapshot-tests.spec.ts @@ -21,7 +21,7 @@ import { test, expect } from './zoo-test' * */ -const file = `sketch001 = startSketchOn('XZ') +const file = `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([57.81, 250.51], sketch001) |> line(end = [121.13, 56.63], tag = $seg02) |> line(end = [83.37, -34.61], tag = $seg01) @@ -30,7 +30,7 @@ profile001 = startProfileAt([57.81, 250.51], sketch001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 200) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([-73.64, -42.89], %) |> xLine(length = 173.71) |> line(end = [-22.12, -94.4]) @@ -38,7 +38,7 @@ sketch002 = startSketchOn('XZ') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude002 = extrude(sketch002, length = 50) -sketch003 = startSketchOn('XY') +sketch003 = startSketchOn(XY) |> startProfileAt([52.92, 157.81], %) |> angledLine([0, 176.4], %, $rectangleSegmentA001) |> angledLine([ diff --git a/e2e/playwright/prompt-to-edit.spec.ts b/e2e/playwright/prompt-to-edit.spec.ts index bb17c75a4..0121a1d32 100644 --- a/e2e/playwright/prompt-to-edit.spec.ts +++ b/e2e/playwright/prompt-to-edit.spec.ts @@ -1,8 +1,9 @@ import { test, expect } from './zoo-test' +import { orRunWhenFullSuiteEnabled } from './test-utils' /* eslint-disable jest/no-conditional-expect */ -const file = `sketch001 = startSketchOn('XZ') +const file = `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([57.81, 250.51], sketch001) |> line(end = [121.13, 56.63], tag = $seg02) |> line(end = [83.37, -34.61], tag = $seg01) @@ -11,7 +12,7 @@ profile001 = startProfileAt([57.81, 250.51], sketch001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(profile001, length = 200) -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([-114, 85.52], %) |> xLine(length = 265.36) |> line(end = [33.17, -261.22]) @@ -19,7 +20,7 @@ sketch002 = startSketchOn('XZ') |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude002 = extrude(sketch002, length = 50) -sketch003 = startSketchOn('XY') +sketch003 = startSketchOn(XY) |> startProfileAt([52.92, 157.81], %) |> angledLine([0, 176.4], %, $rectangleSegmentA001) |> angledLine([ @@ -204,7 +205,7 @@ test.describe('Prompt-to-edit tests', { tag: '@skipWin' }, () => { page, scene, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const body1CapCoords = { x: 571, y: 311 } await context.addInitScript((file) => { @@ -224,7 +225,7 @@ test.describe('Prompt-to-edit tests', { tag: '@skipWin' }, () => { // Verify the selection was made await editor.expectState({ highlightedCode: '', - activeLines: ["sketch002 = startSketchOn('XZ')"], + activeLines: ['sketch002 = startSketchOn(XZ)'], diagnostics: [], }) }) diff --git a/e2e/playwright/regression-tests.spec.ts b/e2e/playwright/regression-tests.spec.ts index f59f43136..a938b9fb5 100644 --- a/e2e/playwright/regression-tests.spec.ts +++ b/e2e/playwright/regression-tests.spec.ts @@ -2,9 +2,16 @@ import { Page } from '@playwright/test' import { test, expect } from './zoo-test' import path from 'path' import * as fsp from 'fs/promises' -import { getUtils, executorInputPath } from './test-utils' +import { + getUtils, + executorInputPath, + TEST_COLORS, + TestColor, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { TEST_CODE_TRIGGER_ENGINE_EXPORT_ERROR } from './storageStates' import { bracket } from 'lib/exampleKcl' +import { reportRejection } from 'lib/trap' test.describe('Regression tests', { tag: ['@skipWin'] }, () => { // bugs we found that don't fit neatly into other categories @@ -58,7 +65,7 @@ test.describe('Regression tests', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([82.33, 238.21], %) |> angledLine([0, 288.63], %, $rectangleSegmentA001) |> angledLine([ @@ -126,7 +133,7 @@ extrude001 = extrude(sketch001, length = 50) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('-XZ') + `sketch001 = startSketchOn(-XZ) |> startProfileAt([-6.95, 4.98], %) |> line(end = [25.1, 0.41]) |> line(end = [0.73, -14.93]) @@ -187,7 +194,7 @@ extrude001 = extrude(sketch001, length = 50) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part = startSketchOn('XY') + `part = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 1]) |> line(end = [1, 0]) @@ -315,6 +322,89 @@ extrude001 = extrude(sketch001, length = 50) } ) + test( + 'window resize updates should reconfigure the stream', + { tag: '@skipLocalEngine' }, + async ({ scene, page, homePage, cmdBar, toolbar }) => { + await page.addInitScript( + async ({ code }) => { + localStorage.setItem( + 'persistCode', + `@settings(defaultLengthUnit = mm) +sketch002 = startSketchOn('XY') +profile002 = startProfileAt([72.24, -52.05], sketch002) + |> angledLine([0, 181.26], %, $rectangleSegmentA001) + |> angledLine([ + segAng(rectangleSegmentA001) - 90, + 21.54 + ], %) + |> angledLine([ + segAng(rectangleSegmentA001), + -segLen(rectangleSegmentA001) + ], %) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() +extrude002 = extrude(profile002, length = 150) +` + ) + ;(window as any).playwrightSkipFilePicker = true + }, + { code: TEST_CODE_TRIGGER_ENGINE_EXPORT_ERROR } + ) + + const websocketPromise = page.waitForEvent('websocket') + await page.setBodyDimensions({ width: 500, height: 500 }) + + await homePage.goToModelingScene() + const websocket = await websocketPromise + + await scene.connectionEstablished() + await scene.settled(cmdBar) + await toolbar.closePane('code') + + // expect pixel color to be background color + const offModelBefore = { x: 446, y: 250 } + const onModelBefore = { x: 422, y: 250 } + const offModelAfter = { x: 692, y: 262 } + const onModelAfter = { x: 673, y: 266 } + + await scene.expectPixelColor( + TEST_COLORS.DARK_MODE_BKGD, + offModelBefore, + 15 + ) + const standardModelGrey: TestColor = [100, 100, 100] + await scene.expectPixelColor(standardModelGrey, onModelBefore, 15) + + await test.step('resize window and expect "reconfigure_stream" websocket message', async () => { + // note this is a bit low level for our tests, usually this would go into a fixture + // but it's pretty unique to this resize test, it can be moved/abstracted if we have further need + // to listen to websocket messages + await Promise.all([ + new Promise((resolve) => { + websocket + // @ts-ignore + .waitForEvent('framesent', (frame) => { + frame.payload + .toString() + .includes( + '"type":"reconfigure_stream","width":1000,"height":500' + ) && resolve(true) + }) + .catch(reportRejection) + }), + page.setBodyDimensions({ width: 1000, height: 500 }), + ]) + }) + + await scene.expectPixelColor( + TEST_COLORS.DARK_MODE_BKGD, + offModelAfter, + 15 + ) + await scene.expectPixelColor(standardModelGrey, onModelAfter, 15) + } + ) test( 'when engine fails export we handle the failure and alert the user', { tag: '@skipLocalEngine' }, @@ -487,7 +577,7 @@ extrude001 = extrude(sketch001, length = 50) `Network health indicator only appears in modeling view`, { tag: '@electron' }, async ({ context, page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await context.folderSetupFn(async (dir) => { const bracketDir = path.join(dir, 'bracket') await fsp.mkdir(bracketDir, { recursive: true }) @@ -534,7 +624,7 @@ extrude001 = extrude(sketch001, length = 50) // Constants and locators const planeColor: [number, number, number] = [170, 220, 170] - const bgColor: [number, number, number] = [27, 27, 27] + const bgColor: [number, number, number] = TEST_COLORS.DARK_MODE_BKGD const middlePixelIsColor = async (color: [number, number, number]) => { return u.getGreatestPixDiff({ x: 600, y: 250 }, color) } diff --git a/e2e/playwright/sketch-tests.spec.ts b/e2e/playwright/sketch-tests.spec.ts index 907f28c8a..40d5eafb8 100644 --- a/e2e/playwright/sketch-tests.spec.ts +++ b/e2e/playwright/sketch-tests.spec.ts @@ -9,6 +9,7 @@ import { getUtils, PERSIST_MODELING_CONTEXT, TEST_COLORS, + orRunWhenFullSuiteEnabled, } from './test-utils' import { uuidv4, roundOff } from 'lib/utils' import { SceneFixture } from './fixtures/sceneFixture' @@ -41,7 +42,7 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { wireRadius = 2 wireOffset = 0.5 - screwHole = startSketchOn('XY') + screwHole = startSketchOn(XY) ${startProfileAt1} |> arc({ radius = screwRadius, @@ -49,7 +50,7 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { angleEnd = 360 }, %) - part001 = startSketchOn('XY') + part001 = startSketchOn(XY) ${startProfileAt2} |> xLine(length = width * .5) |> yLine(length = height) @@ -58,7 +59,7 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { |> hole(screwHole, %) |> extrude(length = thickness) - part002 = startSketchOn('-XZ') + part002 = startSketchOn(-XZ) ${startProfileAt3} |> xLine(length = width / 4) |> tangentialArcTo([width / 2, 0], %) @@ -112,7 +113,7 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([2.61, -4.01], %) |> xLine(length = 8.73) |> tangentialArcTo([8.33, -1.31], %)` @@ -158,7 +159,7 @@ test.describe('Sketch tests', { tag: ['@skipWin'] }, () => { await page.mouse.click(700, 200) await expect.poll(u.normalisedEditorCode, { timeout: 1000 }) - .toBe(`sketch002 = startSketchOn('XZ') + .toBe(`sketch002 = startSketchOn(XZ) sketch001 = startProfileAt([12.34, -12.34], sketch002) |> yLine(length = 12.34) @@ -189,7 +190,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) ).toBeVisible() }) test('Can edit segments by dragging their handles', () => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const doEditSegmentsByDraggingHandle = async ( page: Page, homePage: HomePageFixture, @@ -202,7 +203,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) @@ -252,7 +253,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') + await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) @@ -397,7 +398,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // expect the code to have changed await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([6.44, -12.07], %) |> line(end = [14.72, 1.97]) |> tangentialArcTo([26.92, -3.32], %) @@ -474,7 +475,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> circle(center = [4.61, -5.01], radius = 8)` ) }) @@ -551,7 +552,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // expect the code to have changed await editor.expectEditor.toContain( - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> circle(center = [7.26, -2.37], radius = 11.44)`, { shouldNormalise: true } ) @@ -564,7 +565,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -10.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -0.38], %) @@ -650,7 +651,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // expect the code to have changed await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([7.12, -12.68], %) |> line(end = [12.68, -1.09]) |> tangentialArcTo([24.89, 0.68], %) @@ -668,7 +669,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([4.61, -14.01], %) |> line(end = [12.73, -0.09]) |> tangentialArcTo([24.95, -5.38], %) @@ -754,7 +755,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // expect the code to have changed await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ') + .toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([6.44, -12.07], %) |> line(end = [14.72, 1.97]) |> tangentialArcTo([24.95, -5.38], %) @@ -788,7 +789,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) 200 ) - let codeStr = "sketch001 = startSketchOn('XY')" + let codeStr = 'sketch001 = startSketchOn(XY)' await page.mouse.click(center.x, viewportSize.height * 0.55) await expect(u.codeLocator).toHaveText(codeStr) @@ -827,7 +828,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) // so selecting the plane again is a bit easier. await page.mouse.click(center.x + 200, center.y + 100) await page.waitForTimeout(600) // TODO detect animation ending, or disable animation - codeStr += "sketch002 = startSketchOn('XY')" + codeStr += 'sketch002 = startSketchOn(XY)' await expect(u.codeLocator).toHaveText(codeStr) await u.closeDebugPanel() @@ -867,7 +868,7 @@ sketch001 = startProfileAt([12.34, -12.34], sketch002) await u.openDebugPanel() - const code = `sketch001 = startSketchOn('-XZ') + const code = `sketch001 = startSketchOn(-XZ) profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( scale * 34.8 )}], sketch001) @@ -897,7 +898,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.mouse.move(700, 200, { steps: 10 }) await page.mouse.click(700, 200, { delay: 200 }) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('-XZ')` + `sketch001 = startSketchOn(-XZ)` ) let prevContent = await page.locator('.cm-content').innerText() @@ -972,7 +973,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([-0.45, 0.87], %) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) @@ -1030,7 +1031,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([-0.45, 0.87], %) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) @@ -1073,7 +1074,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( ).toBeVisible() await expect((await u.codeLocator.innerText()).replace(/\s/g, '')).toBe( - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([-0.45, 0.87], %) |> line(end = [1.32, 0.38]) |> line(end = [1.02, -1.32], tag = $seg01) @@ -1091,7 +1092,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) /** * Tests the following things * 1) The the planes are there on load because the scene is empty @@ -1126,7 +1127,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await u.openAndClearDebugPanel() - await u.codeLocator.fill(`sketch001 = startSketchOn('XY') + await u.codeLocator.fill(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -1165,7 +1166,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.mouse.click(XYPlanePoint.x, XYPlanePoint.y) await page.waitForTimeout(200) await page.mouse.click(XYPlanePoint.x + 50, XYPlanePoint.y + 50) - await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ') + await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ) |> startProfileAt([11.8, 9.09], %) |> line(end = [3.39, -3.39]) `) @@ -1173,7 +1174,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([11.8, 9.09], %) |> line(end = [3.39, -3.39]) ` @@ -1213,7 +1214,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( return lugSketch } - lug([0, 0], 10, .5, "XY")` + lug([0, 0], 10, .5, XY)` ) }) @@ -1272,7 +1273,7 @@ profile001 = startProfileAt([${roundOff(scale * 69.6)}, ${roundOff( const railBaseLength = in2mm(.200) const railClampable = in2mm(.200) - const rail = startSketchOn('XZ') + const rail = startSketchOn(XZ) |> startProfileAt([ -railTop / 2, railClampable + railBaseLength @@ -1425,7 +1426,7 @@ test.describe(`Sketching with offset planes`, () => { await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `offsetPlane001 = offsetPlane("XY", offset = 10)` + `offsetPlane001 = offsetPlane(XY, offset = 10)` ) }) @@ -1439,9 +1440,9 @@ test.describe(`Sketching with offset planes`, () => { await test.step(`Hovering should highlight code`, async () => { await planeHover() await editor.expectState({ - activeLines: [`offsetPlane001=offsetPlane("XY",offset=10)`], + activeLines: [`offsetPlane001=offsetPlane(XY,offset=10)`], diagnostics: [], - highlightedCode: 'offsetPlane("XY", offset = 10)', + highlightedCode: 'offsetPlane(XY, offset = 10)', }) }) @@ -1452,7 +1453,7 @@ test.describe(`Sketching with offset planes`, () => { await expect(toolbar.lineBtn).toBeEnabled() await editor.expectEditor.toContain('startSketchOn(offsetPlane001)') await editor.expectState({ - activeLines: [`offsetPlane001=offsetPlane("XY",offset=10)`], + activeLines: [`offsetPlane001=offsetPlane(XY,offset=10)`], diagnostics: [], highlightedCode: '', }) @@ -1466,13 +1467,13 @@ test.describe('multi-profile sketching', () => { `test it removes half-finished expressions when changing tools in sketch mode`, { tag: ['@skipWin'] }, async ({ context, page, scene, toolbar, editor, homePage, cmdBar }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) // We seed the scene with a single offset plane await context.addInitScript(() => { localStorage.setItem( 'persistCode', `yo = 5 -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([121.52, 168.25], sketch001) |> line(end = [115.04, 113.61]) |> line(end = [130.87, -97.79]) @@ -1603,7 +1604,7 @@ profile002 = startProfileAt([117.2, 56.08], sketch001) await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile002 = startProfileAt([40.68, 87.67], sketch001) |> xLine(length = 239.17) profile003 = startProfileAt([206.63, -56.73], sketch001) @@ -1682,7 +1683,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) ` ) }) @@ -1732,7 +1733,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await selectXZPlane() // timeout wait for engine animation is unavoidable await page.waitForTimeout(600) - await editor.expectEditor.toContain(`sketch001 = startSketchOn('XZ')`) + await editor.expectEditor.toContain(`sketch001 = startSketchOn(XZ)`) const [startProfile1] = scene.makeMouseHelpers(568, 70) const [segment1Clk] = scene.makeMouseHelpers(701, 78) @@ -1750,7 +1751,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) }) await test.step('delete all profiles', async () => { - await editor.replaceCode('', "sketch001 = startSketchOn('XZ')\n") + await editor.replaceCode('', 'sketch001 = startSketchOn(XZ)\n') await page.waitForTimeout(600) // wait for deferred execution }) @@ -1833,7 +1834,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await selectXZPlane() // timeout wait for engine animation is unavoidable await page.waitForTimeout(600) - await editor.expectEditor.toContain(`sketch001 = startSketchOn('XZ')`) + await editor.expectEditor.toContain(`sketch001 = startSketchOn(XZ)`) 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( @@ -2171,7 +2172,7 @@ profile003 = startProfileAt([206.63, -56.73], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.24, 4.54], sketch001) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) @@ -2316,7 +2317,7 @@ profile004 = circleThreePoint(sketch001, p1 = [13.44, -6.8], p2 = [13.39, -2.07] await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.24, 4.54], sketch001) |> line(end = [-0.41, 6.99]) |> line(end = [8.61, 0.74]) @@ -2421,7 +2422,7 @@ profile003 = circle(sketch001, center = [6.92, -4.2], radius = 3.16) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([-63.43, 193.08], sketch001) |> line(end = [168.52, 149.87]) |> line(end = [190.29, -39.18]) @@ -2503,16 +2504,16 @@ extrude001 = extrude(profile003, length = 5) // timeout wait for engine animation is unavoidable await page.waitForTimeout(600) - await editor.expectEditor.toContain(`sketch001 = startSketchOn('XZ')`) + await editor.expectEditor.toContain(`sketch001 = startSketchOn(XZ)`) await toolbar.exitSketch() - await editor.expectEditor.not.toContain(`sketch001 = startSketchOn('XZ')`) + await editor.expectEditor.not.toContain(`sketch001 = startSketchOn(XZ)`) await test.step("still renders code, hasn't got into a weird state", async () => { await editor.replaceCode( 'myVar = 5', `myVar = 5 - sketch001 = startSketchOn('XZ') + sketch001 = startSketchOn(XZ) profile001 = circle( sketch001, center = [12.41, 3.87], @@ -2532,13 +2533,13 @@ extrude001 = extrude(profile003, length = 5) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([85.19, 338.59], sketch001) |> line(end = [213.3, -94.52]) |> line(end = [-230.09, -55.34]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) profile002 = startProfileAt([85.81, 52.55], sketch002) ` @@ -2574,7 +2575,7 @@ profile002 = startProfileAt([85.81, 52.55], sketch002) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `thePart = startSketchOn('XZ') + `thePart = startSketchOn(XZ) |> startProfileAt([7.53, 10.51], %) |> line(end = [12.54, 1.83]) |> line(end = [6.65, -6.91]) @@ -2605,14 +2606,14 @@ 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) |> startProfileAt([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 = startProfileAt([7.53, 10.51], sketch001)` ) }) @@ -2635,7 +2636,7 @@ extrude001 = extrude(thePart, length = 75) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.71, -3.66], sketch001) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) @@ -2675,7 +2676,7 @@ revolve001 = revolve( axis = getNextAdjacentEdge(seg01) ) extrude002 = extrude(profile006, length = 4) -sketch003 = startSketchOn('-XZ') +sketch003 = startSketchOn(-XZ) profile007 = startProfileAt([4.8, 7.55], sketch003) |> line(end = [7.39, 2.58]) |> line(end = [7.02, -2.85]) @@ -2808,13 +2809,13 @@ extrude003 = extrude(profile011, length = 2.5) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([34, 42.66], sketch001) |> line(end = [102.65, 151.99]) |> line(end = [76, -138.66]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -plane001 = offsetPlane('XZ', offset = 50) +plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) profile002 = startProfileAt([39.43, 172.21], sketch002) |> xLine(length = 183.99) @@ -2862,17 +2863,17 @@ loft([profile001, profile002]) page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([34, 42.66], sketch001) |> line(end = [102.65, 151.99]) |> line(end = [76, -138.66]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -plane001 = offsetPlane('XZ', offset = 50) +plane001 = offsetPlane(XZ, offset = 50) sketch002 = startSketchOn(plane001) profile002 = startProfileAt([39.43, 172.21], sketch002) |> xLine(length = 183.99) @@ -2942,7 +2943,7 @@ test.describe(`Click based selection don't brick the app when clicked out of ran await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [3.14, 3.14]) |> arcTo({ @@ -2980,7 +2981,7 @@ test.describe(`Click based selection don't brick the app when clicked out of ran // Check that the code is highlighted await editor.expectState({ - activeLines: ["sketch001=startSketchOn('XZ')"], + activeLines: ['sketch001=startSketchOn(XZ)'], diagnostics: [], highlightedCode: 'arcTo({end = [4, 2], interior = [1, 2]}, %)', }) @@ -2991,7 +2992,7 @@ test.describe(`Click based selection don't brick the app when clicked out of ran await page.mouse.move(655, 337) await editor.expectState({ - activeLines: ["sketch001=startSketchOn('XZ')"], + activeLines: ['sketch001=startSketchOn(XZ)'], diagnostics: [], highlightedCode: '', }) @@ -3024,7 +3025,7 @@ test.describe('Redirecting to home page and back to the original file should cle await context.addInitScript(() => { localStorage.setItem( 'persistCode', - ` sketch001 = startSketchOn('XZ') + ` sketch001 = startSketchOn(XZ) |> startProfileAt([256.85, 14.41], %) |> line(endAbsolute = [0, 211.07]) ` diff --git a/e2e/playwright/snapshot-tests.spec.ts b/e2e/playwright/snapshot-tests.spec.ts index 783365441..8e2171696 100644 --- a/e2e/playwright/snapshot-tests.spec.ts +++ b/e2e/playwright/snapshot-tests.spec.ts @@ -1,6 +1,12 @@ import { test, expect } from './zoo-test' import { secrets } from './secrets' -import { Paths, doExport, getUtils, settingsToToml } from './test-utils' +import { + Paths, + doExport, + getUtils, + settingsToToml, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { Models } from '@kittycad/lib' import fsp from 'fs/promises' import { spawn } from 'child_process' @@ -40,7 +46,7 @@ test( 'exports of each format should work', { tag: ['@snapshot', '@skipWin', '@skipMacos'] }, async ({ page, context, scene, cmdBar, tronApp }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) if (!tronApp) { fail() } @@ -59,7 +65,7 @@ baseHeight = 1 totalHeightHalf = 2 armThick = 0.5 totalLen = 9.5 -part001 = startSketchOn('-XZ') +part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> yLine(length = baseHeight) |> xLine(length = baseLen) @@ -316,7 +322,7 @@ const extrudeDefaultPlane = async ( scene: SceneFixture, plane: string ) => { - const code = `part001 = startSketchOn('${plane}') + const code = `part001 = startSketchOn(${plane}) |> startProfileAt([7.00, 4.40], %) |> line(end = [6.60, -0.20]) |> line(end = [2.80, 5.00]) @@ -440,7 +446,7 @@ test( // select a plane await page.mouse.click(700, 200) - let code = `sketch001 = startSketchOn('XZ')` + let code = `sketch001 = startSketchOn(XZ)` await expect(page.locator('.cm-content')).toHaveText(code) await page.waitForTimeout(700) // TODO detect animation ending, or disable animation @@ -554,7 +560,7 @@ test( await page.mouse.click(700, 200) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) // Wait for camera animation @@ -600,7 +606,7 @@ test( await page.mouse.click(700, 200) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) // Wait for camera animation @@ -622,7 +628,7 @@ test( mask: [page.getByTestId('model-state-indicator')], }) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')profile001 = circle(sketch001, center = [14.44, -2.44], radius = 1)` + `sketch001 = startSketchOn(XZ)profile001 = circle(sketch001, center = [14.44, -2.44], radius = 1)` ) } ) @@ -651,7 +657,7 @@ test.describe( // select a plane await page.mouse.click(700, 200) - let code = `sketch001 = startSketchOn('XZ')` + let code = `sketch001 = startSketchOn(XZ)` await expect(page.locator('.cm-content')).toHaveText(code) // Wait for camera animation @@ -746,7 +752,7 @@ test.describe( // select a plane await page.mouse.click(700, 200) - let code = `sketch001 = startSketchOn('XZ')` + let code = `sketch001 = startSketchOn(XZ)` await expect(u.codeLocator).toHaveText(code) // Wait for camera animation @@ -817,7 +823,7 @@ test( await context.addInitScript(async (KCL_DEFAULT_LENGTH) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('-XZ') + `part001 = startSketchOn(-XZ) |> startProfileAt([1.4, 2.47], %) |> line(end = [9.31, 10.55], tag = $seg01) |> line(end = [11.91, -10.42]) @@ -879,7 +885,7 @@ test( await context.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XY') + `part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -919,7 +925,7 @@ test( await context.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XY') + `part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -1093,12 +1099,12 @@ test.describe('Grid visibility', { tag: '@snapshot' }, () => { }) test('theme persists', async ({ page, context }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await context.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XY') + `part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -1168,7 +1174,7 @@ test.describe('code color goober', { tag: '@snapshot' }, () => { `// Create a pipe using a sweep. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -1176,7 +1182,7 @@ sweepPath = startSketchOn('XZ') |> tangentialArc({ offset = -90, radius = 5 }, %) |> line(end = [0, 7]) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> startProfileAt([2, 0], %) |> arc({ angleEnd = 360, @@ -1218,7 +1224,7 @@ sweepSketch = startSketchOn('XY') `// Create a pipe using a sweep. // Create a path for the sweep. -sweepPath = startSketchOn('XZ') +sweepPath = startSketchOn(XZ) |> startProfileAt([0.05, 0.05], %) |> line(end = [0, 7]) |> tangentialArc({ offset = 90, radius = 5 }, %) @@ -1226,7 +1232,7 @@ sweepPath = startSketchOn('XZ') |> tangentialArc({ offset = -90, radius = 5 }, %) |> line(end = [0, 7]) -sweepSketch = startSketchOn('XY') +sweepSketch = startSketchOn(XY) |> startProfileAt([2, 0], %) |> arc({ angleEnd = 360, diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png index 021c589bf..b2954c343 100644 Binary files a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png and b/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-circle-should-look-right-1-Google-Chrome-linux.png differ diff --git a/e2e/playwright/snapshot-tests.spec.ts-snapshots/Draft-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 efd71721a..c0a52375a 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/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 c580f8931..2779f732d 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 6a7a2ec45..d2f4cbe68 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 304fdc743..0ac20fca6 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 a6ecdc976..feb68fd77 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 a69400aa6..e9fbb5fee 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--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 78899446b..eaa45b1b9 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 da8525be1..93adcda7d 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-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 2859f9d59..8240ecba9 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/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 676f3dde5..91724538d 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,5 +1,5 @@ { - "original_source_code": "sketch001 = startSketchOn('XZ')\nprofile001 = startProfileAt([57.81, 250.51], sketch001)\n |> line(end = [121.13, 56.63], tag = $seg02)\n |> line(end = [83.37, -34.61], tag = $seg01)\n |> line(end = [19.66, -116.4])\n |> line(end = [-221.8, -41.69])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude001 = extrude(profile001, length = 200)\nsketch002 = startSketchOn('XZ')\n |> startProfileAt([-73.64, -42.89], %)\n |> xLine(length = 173.71)\n |> line(end = [-22.12, -94.4])\n |> xLine(length = -156.98)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude002 = extrude(sketch002, length = 50)\nsketch003 = startSketchOn('XY')\n |> startProfileAt([52.92, 157.81], %)\n |> angledLine([0, 176.4], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 53.4\n ], %, $rectangleSegmentB001)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %, $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", + "original_source_code": "sketch001 = startSketchOn(XZ)\nprofile001 = startProfileAt([57.81, 250.51], sketch001)\n |> line(end = [121.13, 56.63], tag = $seg02)\n |> line(end = [83.37, -34.61], tag = $seg01)\n |> line(end = [19.66, -116.4])\n |> line(end = [-221.8, -41.69])\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude001 = extrude(profile001, length = 200)\nsketch002 = startSketchOn(XZ)\n |> startProfileAt([-73.64, -42.89], %)\n |> xLine(length = 173.71)\n |> line(end = [-22.12, -94.4])\n |> xLine(length = -156.98)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude002 = extrude(sketch002, length = 50)\nsketch003 = startSketchOn(XY)\n |> startProfileAt([52.92, 157.81], %)\n |> angledLine([0, 176.4], %, $rectangleSegmentA001)\n |> angledLine([\n segAng(rectangleSegmentA001) - 90,\n 53.4\n ], %, $rectangleSegmentB001)\n |> angledLine([\n segAng(rectangleSegmentA001),\n -segLen(rectangleSegmentA001)\n ], %, $rectangleSegmentC001)\n |> line(endAbsolute = [profileStartX(%), profileStartY(%)])\n |> close()\nextrude003 = extrude(sketch003, length = 20)\n", "prompt": "make this neon green please, use #39FF14", "source_ranges": [ { diff --git a/e2e/playwright/storageStates.ts b/e2e/playwright/storageStates.ts index 4ddda716d..4b2cc30c6 100644 --- a/e2e/playwright/storageStates.ts +++ b/e2e/playwright/storageStates.ts @@ -77,7 +77,7 @@ export const TEST_SETTINGS_CORRUPTED = { }, } satisfies Partial -export const TEST_CODE_GIZMO = `part001 = startSketchOn('XZ') +export const TEST_CODE_GIZMO = `part001 = startSketchOn(XZ) |> startProfileAt([20, 0], %) |> line(end = [7.13, 4 + 0]) |> angledLine({ angle: 3 + 0, length: 3.14 + 0 }, %) @@ -128,7 +128,7 @@ keychain2 = startSketchOn("XY") |> close() |> extrude(length = thickness) -box = startSketchOn('XY') +box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -147,7 +147,7 @@ sketch001 = startSketchOn(box, revolveAxis) angle = 90 ) -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([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 8d03b72a3..50bf53b64 100644 --- a/e2e/playwright/test-network-and-connection-issues.spec.ts +++ b/e2e/playwright/test-network-and-connection-issues.spec.ts @@ -1,5 +1,5 @@ import { test, expect } from './zoo-test' -import { commonPoints, getUtils } from './test-utils' +import { commonPoints, getUtils, orRunWhenFullSuiteEnabled } from './test-utils' import { EngineCommand } from 'lang/std/artifactGraph' import { uuidv4 } from 'lib/utils' @@ -8,7 +8,7 @@ test.describe('Test network and connection issues', () => { 'simulate network down and network little widget', { tag: '@skipLocalEngine' }, async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await page.setBodyDimensions({ width: 1200, height: 500 }) @@ -85,7 +85,7 @@ test.describe('Test network and connection issues', () => { 'Engine disconnect & reconnect in sketch mode', { tag: '@skipLocalEngine' }, async ({ page, homePage, toolbar }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const networkToggle = page.getByTestId('network-toggle') const u = await getUtils(page) @@ -105,7 +105,7 @@ test.describe('Test network and connection issues', () => { await page.mouse.click(700, 200) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) await u.closeDebugPanel() @@ -114,7 +114,7 @@ test.describe('Test network and connection issues', () => { 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 = startProfileAt(${commonPoints.startAt}, sketch001)` ) await page.waitForTimeout(100) @@ -122,7 +122,7 @@ test.describe('Test network and connection issues', () => { await page.waitForTimeout(100) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) |> xLine(length = ${commonPoints.num1})`) // Expect the network to be up @@ -211,7 +211,7 @@ test.describe('Test network and connection issues', () => { // Ensure we can continue sketching await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20) await expect.poll(u.normalisedEditorCode) - .toBe(`sketch001 = startSketchOn('XZ') + .toBe(`sketch001 = startSketchOn(XZ) profile001 = startProfileAt([12.34, -12.34], sketch001) |> xLine(length = 12.34) |> line(end = [-12.34, 12.34]) @@ -221,7 +221,7 @@ profile001 = startProfileAt([12.34, -12.34], sketch001) await page.mouse.click(startXPx, 500 - PUR * 20) await expect.poll(u.normalisedEditorCode) - .toBe(`sketch001 = startSketchOn('XZ') + .toBe(`sketch001 = startSketchOn(XZ) profile001 = startProfileAt([12.34, -12.34], sketch001) |> xLine(length = 12.34) |> line(end = [-12.34, 12.34]) diff --git a/e2e/playwright/test-utils.ts b/e2e/playwright/test-utils.ts index 71144112e..f4a36a8fa 100644 --- a/e2e/playwright/test-utils.ts +++ b/e2e/playwright/test-utils.ts @@ -31,11 +31,13 @@ const toNormalizedCode = (text: string) => { return text.replace(/\s+/g, '') } -type TestColor = [number, number, number] -export const TEST_COLORS = { - WHITE: [249, 249, 249] as TestColor, - YELLOW: [255, 255, 0] as TestColor, - BLUE: [0, 0, 255] as TestColor, +export type TestColor = [number, number, number] +export const TEST_COLORS: { [key: string]: TestColor } = { + WHITE: [249, 249, 249], + YELLOW: [255, 255, 0], + BLUE: [0, 0, 255], + DARK_MODE_BKGD: [27, 27, 27], + DARK_MODE_PLANE_XZ: [50, 50, 99], } as const export const PERSIST_MODELING_CONTEXT = 'persistModelingContext' @@ -50,17 +52,13 @@ export const commonPoints = { num3: -2.44, } as const -/** A semi-reliable color to check the default XZ plane on - * in dark mode in the default camera position - */ -export const darkModePlaneColorXZ: [number, number, number] = [50, 50, 99] - -/** A semi-reliable color to check the default dark mode bg color against */ -export const darkModeBgColor: [number, number, number] = [27, 27, 27] - export const editorSelector = '[role="textbox"][data-language="kcl"]' type PaneId = 'variables' | 'code' | 'files' | 'logs' +export function orRunWhenFullSuiteEnabled() { + return process.env.GITHUB_HEAD_REF !== 'all-e2e' +} + async function waitForPageLoadWithRetry(page: Page) { await expect(async () => { await page.goto('/') @@ -938,8 +936,8 @@ function failOnConsoleErrors(page: Page, testInfo?: TestInfo) { // Fail when running on CI and FAIL_ON_CONSOLE_ERRORS is set // use expect to prevent page from closing and not cleaning up expect(`An error was detected in the console: \r\n message:${exception.message} \r\n name:${exception.name} \r\n stack:${exception.stack} - - *Either fix the console error or add it to the whitelist defined in ./lib/console-error-whitelist.ts (if the error can be safely ignored) + + *Either fix the console error or add it to the whitelist defined in ./lib/console-error-whitelist.ts (if the error can be safely ignored) `).toEqual('Console error detected') } else { // the (test-results/exceptions.txt) file will be uploaded as part of an upload artifact in GH diff --git a/e2e/playwright/testing-camera-movement.spec.ts b/e2e/playwright/testing-camera-movement.spec.ts index 63fef3748..c900f3fc6 100644 --- a/e2e/playwright/testing-camera-movement.spec.ts +++ b/e2e/playwright/testing-camera-movement.spec.ts @@ -1,7 +1,7 @@ import { test, expect } from './zoo-test' import { EngineCommand } from 'lang/std/artifactGraph' import { uuidv4 } from 'lib/utils' -import { getUtils } from './test-utils' +import { getUtils, orRunWhenFullSuiteEnabled } from './test-utils' test.describe('Testing Camera Movement', { tag: ['@skipWin'] }, () => { test('Can move camera reliably', async ({ page, context, homePage }) => { @@ -183,7 +183,7 @@ test.describe('Testing Camera Movement', { tag: ['@skipWin'] }, () => { page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) // start new sketch pan and zoom before exiting, when exiting the sketch should stay in the same place // than zoom and pan outside of sketch mode and enter again and it should not change from where it is // than again for sketching diff --git a/e2e/playwright/testing-constraints.spec.ts b/e2e/playwright/testing-constraints.spec.ts index aefed0288..57ae5e8da 100644 --- a/e2e/playwright/testing-constraints.spec.ts +++ b/e2e/playwright/testing-constraints.spec.ts @@ -5,6 +5,7 @@ import { TEST_COLORS, pollEditorLinesSelectedLength, executorInputPath, + orRunWhenFullSuiteEnabled, } from './test-utils' import { XOR } from 'lib/utils' import path from 'node:path' @@ -14,7 +15,7 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -57,7 +58,7 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { .click() await expect(page.locator('.cm-content')).toHaveText( - `length001 = 20sketch001 = startSketchOn('XY') |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> angledLine([90, length001], %) |> xLine(length = -20)` + `length001 = 20sketch001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> angledLine([90, length001], %) |> xLine(length = -20)` ) // Make sure we didn't pop out of sketch mode. @@ -81,13 +82,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 79 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4], tag = $seg01) |> line(end = [78.92, -120.11]) |> angledLine([segAng(seg01), yo], %) |> line(end = [41.19, 58.97 + 5]) - part002 = startSketchOn('XZ') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 120], %) |> xLine(length = -385.34, tag = $seg_what) |> yLine(length = -170.06) @@ -145,13 +146,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> line(end = [74.36, 130.4], tag = $seg01) |> line(end = [78.92, -120.11]) |> angledLine([segAng(seg01), 78.33], %) |> line(end = [51.19, 48.97]) - part002 = startSketchOn('XZ') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -277,13 +278,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -387,13 +388,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -500,13 +501,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -602,13 +603,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -688,13 +689,13 @@ test.describe('Testing constraints', { tag: ['@skipWin'] }, () => { localStorage.setItem( 'persistCode', `yo = 5 -part001 = startSketchOn('XZ') +part001 = startSketchOn(XZ) |> startProfileAt([-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') +part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -768,13 +769,13 @@ part002 = startSketchOn('XZ') localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -869,12 +870,12 @@ part002 = startSketchOn('XZ') localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -950,12 +951,12 @@ part002 = startSketchOn('XZ') localStorage.setItem( 'persistCode', `yo = 5 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-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') + part002 = startSketchOn(XZ) |> startProfileAt([299.05, 231.45], %) |> xLine(length = -425.34, tag = $seg_what) |> yLine(length = -264.06) @@ -1009,12 +1010,12 @@ part002 = startSketchOn('XZ') page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) test.setTimeout(70_000) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-1.05, -1.07], %) |> line(end = [3.79, 2.68], tag = $seg01) |> line(end = [3.13, -2.4])` diff --git a/e2e/playwright/testing-gizmo.spec.ts b/e2e/playwright/testing-gizmo.spec.ts index b1bba54be..a08382412 100644 --- a/e2e/playwright/testing-gizmo.spec.ts +++ b/e2e/playwright/testing-gizmo.spec.ts @@ -256,7 +256,7 @@ test.describe(`Testing gizmo, fixture-based`, () => { localStorage.setItem( 'persistCode', ` - const sketch002 = startSketchOn('XZ') + const sketch002 = startSketchOn(XZ) |> startProfileAt([-108.83, -57.48], %) |> angledLine([0, 105.13], %, $rectangleSegmentA001) |> angledLine([ @@ -268,7 +268,7 @@ test.describe(`Testing gizmo, fixture-based`, () => { -segLen(rectangleSegmentA001) ], %) |> close() - const sketch001 = startSketchOn('XZ') + const sketch001 = startSketchOn(XZ) |> circle(center = [818.33, 168.1], radius = 182.8) |> extrude(length = 50) ` diff --git a/e2e/playwright/testing-perspective-toggle.spec.ts b/e2e/playwright/testing-perspective-toggle.spec.ts index 48363973c..78c83e7b0 100644 --- a/e2e/playwright/testing-perspective-toggle.spec.ts +++ b/e2e/playwright/testing-perspective-toggle.spec.ts @@ -1,9 +1,9 @@ import { test, expect } from './zoo-test' -import { getUtils } from './test-utils' +import { getUtils, orRunWhenFullSuiteEnabled } from './test-utils' test.describe('Test toggling perspective', () => { test('via command palette and toggle', async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) // Locators and constants diff --git a/e2e/playwright/testing-segment-overlays.spec.ts b/e2e/playwright/testing-segment-overlays.spec.ts index ddd0c265c..f888909f9 100644 --- a/e2e/playwright/testing-segment-overlays.spec.ts +++ b/e2e/playwright/testing-segment-overlays.spec.ts @@ -1,7 +1,12 @@ import { Page } from '@playwright/test' import { test, expect } from './zoo-test' -import { deg, getUtils, wiggleMove } from './test-utils' +import { + deg, + getUtils, + wiggleMove, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { LineInputsType } from 'lang/std/sketchcombos' import { uuidv4 } from 'lib/utils' import { EditorFixture } from './fixtures/editorFixture' @@ -9,7 +14,7 @@ import { EditorFixture } from './fixtures/editorFixture' test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { test('Hover over a segment should show its overlay, hovering over the input overlays should show its popover, clicking the input overlay should constrain/unconstrain it:\nfor the following segments', () => { // TODO: fix this test on mac after the electron migration - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) /** * Clicks on an constrained element * @param {Page} page - The page to perform the action on @@ -205,7 +210,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([5 + 0, 20 + 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -371,7 +376,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { editor, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', @@ -382,7 +387,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { yAbs001 = 11.5 xAbs001 = 33 xAbs002 = 4 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, yRel001]) |> angledLine({ angle = angle001, length = len001 }, %) @@ -454,7 +459,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -585,7 +590,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -746,7 +751,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -826,7 +831,7 @@ test.describe('Testing segment overlays', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([56.37, 120.33], sketch001) |> line(end = [162.86, 106.48]) |> arcTo({ @@ -952,7 +957,7 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> circle(center = [1 + 0, 0], radius = 8) ` ) @@ -1072,7 +1077,7 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |>startProfileAt([0, 0], %) |> line(end = [0.5, -14 + 0]) |> angledLine({ angle = 3 + 0, length = 32 + 0 }, %) @@ -1346,7 +1351,7 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) async ({ lineToBeDeleted, extraLine }) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([5, 6], %) |> ${lineToBeDeleted} |> line(end = [-10, -15]) @@ -1511,7 +1516,7 @@ profile001 = startProfileAt([56.37, 120.33], sketch001) async ({ lineToBeDeleted }) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([5, 6], %) |> ${lineToBeDeleted} |> line(end = [-10, -15]) diff --git a/e2e/playwright/testing-selections.spec.ts b/e2e/playwright/testing-selections.spec.ts index 2c889226c..3db4e7f43 100644 --- a/e2e/playwright/testing-selections.spec.ts +++ b/e2e/playwright/testing-selections.spec.ts @@ -1,6 +1,6 @@ import { test, expect } from './zoo-test' -import { commonPoints, getUtils } from './test-utils' +import { commonPoints, getUtils, orRunWhenFullSuiteEnabled } from './test-utils' import { Coords2d } from 'lang/std/sketch' import { KCL_DEFAULT_LENGTH } from 'lib/constants' import { uuidv4 } from 'lib/utils' @@ -68,20 +68,20 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await u.closeDebugPanel() await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` + `sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` ) await page.waitForTimeout(100) await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 10) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${commonPoints.startAt}, sketch001) + .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) |> xLine(length = ${commonPoints.num1})`) await page.waitForTimeout(100) await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ + .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -89,7 +89,7 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await page.waitForTimeout(100) await page.mouse.click(startXPx, 500 - PUR * 20) await expect(page.locator('.cm-content')) - .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ + .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ commonPoints.startAt }, sketch001) |> xLine(length = ${commonPoints.num1}) @@ -260,7 +260,7 @@ test.describe('Testing selections', { tag: ['@skipWin'] }, () => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([-79.26, 95.04], %) |> line(end = [112.54, 127.64], tag = $seg02) |> line(end = [170.36, -121.61], tag = $seg01) @@ -299,7 +299,7 @@ pipeLength = 40 pipeSmallDia = 10 pipeLargeDia = 20 thickness = 0.5 -part009 = startSketchOn('XY') +part009 = startSketchOn(XY) |> startProfileAt([pipeLargeDia - (thickness / 2), 38], %) |> line(end = [thickness, 0]) |> line(end = [0, -1]) @@ -320,7 +320,7 @@ part009 = startSketchOn('XY') |> angledLineToX({ angle = 60, to = pipeLargeDia }, %) |> close() rev = revolve(part009, axis = 'y') -sketch006 = startSketchOn('XY') +sketch006 = startSketchOn(XY) profile001 = circle( sketch006, center = [42.91, -70.42], @@ -455,13 +455,13 @@ profile003 = startProfileAt([40.16, -120.48], sketch006) cmdBar, editor, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) test.setTimeout(90_000) const u = await getUtils(page) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XY') + `part001 = startSketchOn(XY) yo = startProfileAt([4.83, 12.56], part001) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) @@ -528,7 +528,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.addInitScript(async (KCL_DEFAULT_LENGTH) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) |> startProfileAt([20, 0], %) |> line(end = [7.13, 4 + 0]) |> angledLine({ angle = 3 + 0, length = 3.14 + 0 }, %) @@ -747,7 +747,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.waitForTimeout(200) await u.removeCurrentCode() - await u.codeLocator.fill(`sketch001 = startSketchOn('XZ') + await u.codeLocator.fill(`sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -869,7 +869,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) @@ -966,7 +966,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) localStorage.setItem( 'persistCode', `yo = 79 - part001 = startSketchOn('XZ') + part001 = startSketchOn(XZ) |> startProfileAt([-7.54, -26.74], %) |> ${cases[0].expectedCode} |> line(end = [-3.19, -138.43]) @@ -1020,7 +1020,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([-79.26, 95.04], %) |> line(end = [112.54, 127.64]) |> line(end = [170.36, -121.61], tag = $seg01) @@ -1135,7 +1135,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) }: any) => { localStorage.setItem( 'persistCode', - `part001 = startSketchOn('XZ') + `part001 = startSketchOn(XZ) ${extrudeAndEditBlocked} |> line(end = [25.96, 2.93]) |> line(end = [5.25, -5.72]) @@ -1143,14 +1143,14 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) |> line(end = [-27.65, -2.78]) |> close() |> extrude(length = 5) - sketch002 = startSketchOn('XZ') + sketch002 = startSketchOn(XZ) ${extrudeAndEditAllowed} |> line(end = [10.32, 6.47]) |> line(end = [9.71, -6.16]) |> line(end = [-3.08, -9.86]) |> line(end = [-12.02, -1.54]) |> close() - sketch003 = startSketchOn('XZ') + sketch003 = startSketchOn(XZ) ${editOnly} |> line(end = [27.55, -1.65]) |> line(end = [4.95, -8]) @@ -1158,7 +1158,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) |> line(end = [-15.79, 17.08]) fn yohey = (pos) => { - sketch004 = startSketchOn('XZ') + sketch004 = startSketchOn(XZ) ${extrudeAndEditBlockedInFunction} |> line(end = [27.55, -1.65]) |> line(end = [4.95, -10.53]) @@ -1253,7 +1253,7 @@ profile001 = startProfileAt([7.49, 9.96], sketch001) await page.mouse.click(700, 200) await expect(page.locator('.cm-content')).toHaveText( - `sketch001 = startSketchOn('XZ')` + `sketch001 = startSketchOn(XZ)` ) await page.waitForTimeout(600) diff --git a/e2e/playwright/testing-settings.spec.ts b/e2e/playwright/testing-settings.spec.ts index 3ea8003b5..b0c856aa1 100644 --- a/e2e/playwright/testing-settings.spec.ts +++ b/e2e/playwright/testing-settings.spec.ts @@ -6,6 +6,8 @@ import { executorInputPath, createProject, tomlToSettings, + TEST_COLORS, + orRunWhenFullSuiteEnabled, } from './test-utils' import { SettingsLevel } from 'lib/settings/settingsTypes' import { SETTINGS_FILE_NAME, PROJECT_SETTINGS_FILE_NAME } from 'lib/constants' @@ -59,7 +61,7 @@ test.describe('Testing settings', () => { page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await test.step(`Setup`, async () => { await page.setBodyDimensions({ width: 1200, height: 500 }) @@ -172,7 +174,7 @@ test.describe('Testing settings', () => { }) test('Project and user settings can be reset', async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) await test.step(`Setup`, async () => { await page.setBodyDimensions({ width: 1200, height: 500 }) @@ -262,7 +264,7 @@ test.describe('Testing settings', () => { `Project settings override user settings on desktop`, { tag: ['@electron', '@skipWin'] }, async ({ context, page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const projectName = 'bracket' const { dir: projectDirName } = await context.folderSetupFn( async (dir) => { @@ -404,7 +406,7 @@ test.describe('Testing settings', () => { tag: '@electron', }, async ({ context, page, tronApp }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) if (!tronApp) { fail() } @@ -462,7 +464,7 @@ test.describe('Testing settings', () => { 'project settings reload on external change', { tag: '@electron' }, async ({ context, page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const { dir: projectDirName } = await context.folderSetupFn( async () => {} ) @@ -731,7 +733,7 @@ test.describe('Testing settings', () => { await context.addInitScript(() => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [5, 0]) |> line(end = [0, 5]) @@ -811,7 +813,7 @@ test.describe('Testing settings', () => { // Selectors and constants const darkBackgroundCss = 'oklch(0.3012 0 264.5)' const lightBackgroundCss = 'oklch(0.9911 0 264.5)' - const darkBackgroundColor: [number, number, number] = [27, 27, 27] + const darkBackgroundColor = TEST_COLORS.DARK_MODE_BKGD const lightBackgroundColor: [number, number, number] = [245, 245, 245] const streamBackgroundPixelIsColor = async ( color: [number, number, number] @@ -983,7 +985,7 @@ fn cube` toolbar, cmdBar, }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await context.folderSetupFn(async (dir) => { const projectDir = join(dir, 'project-000') await fsp.mkdir(projectDir, { recursive: true }) diff --git a/e2e/playwright/text-to-cad-tests.spec.ts b/e2e/playwright/text-to-cad-tests.spec.ts index 639921fa8..8dddbcb33 100644 --- a/e2e/playwright/text-to-cad-tests.spec.ts +++ b/e2e/playwright/text-to-cad-tests.spec.ts @@ -1,6 +1,10 @@ import { Page } from '@playwright/test' import { test, expect } from './zoo-test' -import { getUtils, createProject } from './test-utils' +import { + getUtils, + createProject, + orRunWhenFullSuiteEnabled, +} from './test-utils' import { join } from 'path' import fs from 'fs' @@ -435,7 +439,7 @@ test.describe('Text-to-CAD tests', { tag: ['@skipWin'] }, () => { 'can do many at once and get many prompts back, and interact with many', { tag: ['@skipWin'] }, async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) // Let this test run longer since we've seen it timeout. test.setTimeout(180_000) @@ -624,7 +628,7 @@ test( 'Text-to-CAD functionality', { tag: '@electron' }, async ({ context, page }, testInfo) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const projectName = 'project-000' const prompt = 'lego 2x4' const textToCadFileName = 'lego-2x4.kcl' diff --git a/e2e/playwright/various.spec.ts b/e2e/playwright/various.spec.ts index c7ce7c0f8..3591a6f7d 100644 --- a/e2e/playwright/various.spec.ts +++ b/e2e/playwright/various.spec.ts @@ -1,9 +1,14 @@ import { test, expect } from './zoo-test' -import { doExport, getUtils, makeTemplate } from './test-utils' +import { + doExport, + getUtils, + makeTemplate, + orRunWhenFullSuiteEnabled, +} from './test-utils' test('Units menu', async ({ page, homePage }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) await page.setBodyDimensions({ width: 1200, height: 500 }) await homePage.goToModelingScene() @@ -51,7 +56,7 @@ baseHeight = 1 totalHeightHalf = 2 armThick = 0.5 totalLen = 9.5 -part001 = startSketchOn('-XZ') +part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> yLine(length = baseHeight) |> xLine(length = baseLen) @@ -268,7 +273,7 @@ test('Basic default modeling and sketch hotkeys work', async ({ page, homePage, }) => { - test.fixme(process.env.GITHUB_HEAD_REF !== 'all-e2e') + test.fixme(orRunWhenFullSuiteEnabled()) const u = await getUtils(page) // This test can run long if it takes a little too long to load @@ -478,7 +483,7 @@ test('Sketch on face', async ({ page, homePage, scene, cmdBar, toolbar }) => { await page.addInitScript(async () => { localStorage.setItem( 'persistCode', - `sketch001 = startSketchOn('XZ') + `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) diff --git a/rust/Cargo.lock b/rust/Cargo.lock index 70ed283c9..c2ec9fcb8 100644 --- a/rust/Cargo.lock +++ b/rust/Cargo.lock @@ -193,9 +193,9 @@ dependencies = [ [[package]] name = "async-trait" -version = "0.1.87" +version = "0.1.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d556ec1359574147ec0c4fc5eb525f3f23263a592b1a9c07e0a75b427de55c97" +checksum = "e539d3fca749fcee5236ab05e93a52867dd549cc157c8cb7f99595f3cedffdb5" dependencies = [ "proc-macro2", "quote", @@ -789,9 +789,9 @@ checksum = "da692b8d1080ea3045efaab14434d40468c3d8657e42abddfffca87b428f4c1b" [[package]] name = "deranged" -version = "0.3.11" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +checksum = "9c9e6a11ca8224451684bc0d7d5a7adbf8f2fd6887261a1cfc3c0432f9d4068e" dependencies = [ "powerfmt", ] @@ -1230,9 +1230,9 @@ dependencies = [ [[package]] name = "handlebars" -version = "6.3.1" +version = "6.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d752747ddabc4c1a70dd28e72f2e3c218a816773e0d7faf67433f1acfa6cba7c" +checksum = "759e2d5aea3287cb1190c8ec394f42866cb5bf74fcbf213f354e3c856ea26098" dependencies = [ "derive_builder", "log", @@ -2033,9 +2033,9 @@ dependencies = [ [[package]] name = "kittycad-modeling-cmds" -version = "0.2.105" +version = "0.2.107" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f64667cdf4b21ba87940b6733aad67ce9fd819b94fd3b6ca90f10389c1a3750c" +checksum = "cb129c1f4906a76e3518e58f61968f16cb56f1279366415d2bae6059aa68fce8" dependencies = [ "anyhow", "chrono", @@ -3086,9 +3086,9 @@ checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c" [[package]] name = "reqwest" -version = "0.12.14" +version = "0.12.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "989e327e510263980e231de548a33e63d34962d29ae61b467389a1a09627a254" +checksum = "d19c46a6fdd48bc4dab94b6103fccc55d34c67cc0ad04653aad4ea2a07cd7bbb" dependencies = [ "base64", "bytes", @@ -3890,9 +3890,9 @@ dependencies = [ [[package]] name = "time" -version = "0.3.39" +version = "0.3.40" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dad298b01a40a23aac4580b67e3dbedb7cc8402f3592d7f49469de2ea4aecdd8" +checksum = "9d9c75b47bdff86fa3334a3db91356b8d7d86a9b839dab7d0bdc5c3d3a077618" dependencies = [ "deranged", "itoa", @@ -3905,15 +3905,15 @@ dependencies = [ [[package]] name = "time-core" -version = "0.1.3" +version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "765c97a5b985b7c11d7bc27fa927dc4fe6af3a6dfb021d28deb60d3bf51e76ef" +checksum = "c9e9a38711f559d9e3ce1cdb06dd7c5b8ea546bc90052da6d06bb76da74bb07c" [[package]] name = "time-macros" -version = "0.2.20" +version = "0.2.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e8093bc3e81c3bc5f7879de09619d06c9a5a5e45ca44dfeeb7225bae38005c5c" +checksum = "29aa485584182073ed57fd5004aa09c371f021325014694e432313345865fd04" dependencies = [ "num-conv", "time-core", @@ -4389,9 +4389,9 @@ checksum = "06abde3611657adf66d383f00b093d7faecc7fa57071cce2578660c9f1010821" [[package]] name = "uuid" -version = "1.15.1" +version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0f540e3240398cce6128b64ba83fdbdd86129c16a3aa1a3a252efd66eb3d587" +checksum = "458f7a779bf54acc9f347480ac654f68407d3aab21269a6e3c9f922acd9e2da9" dependencies = [ "getrandom 0.3.1", "js-sys", @@ -5027,9 +5027,9 @@ dependencies = [ [[package]] name = "zip" -version = "2.4.1" +version = "2.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "938cc23ac49778ac8340e366ddc422b2227ea176edb447e23fc0627608dddadd" +checksum = "fabe6324e908f85a1c52063ce7aa26b68dcb7eb6dbc83a2d148403c9bc3eba50" dependencies = [ "aes", "arbitrary", diff --git a/rust/Cargo.toml b/rust/Cargo.toml index 273803707..3de4d4ebb 100644 --- a/rust/Cargo.toml +++ b/rust/Cargo.toml @@ -28,7 +28,7 @@ similar = { opt-level = 3 } debug = "line-tables-only" [workspace.dependencies] -async-trait = "0.1.85" +async-trait = "0.1.88" anyhow = { version = "1" } bson = { version = "2.13.0", features = ["uuid-1", "chrono"] } clap = { version = "4.5.31", features = ["derive"] } @@ -36,7 +36,7 @@ dashmap = { version = "6.1.0" } http = "1" indexmap = "2.7.0" kittycad = { version = "0.3.33", default-features = false, features = ["js", "requests"] } -kittycad-modeling-cmds = { version = "0.2.105", features = ["ts-rs", "websocket"] } +kittycad-modeling-cmds = { version = "0.2.107", features = ["ts-rs", "websocket"] } lazy_static = "1.5.0" miette = "7.5.0" pyo3 = { version = "0.24.0" } @@ -50,7 +50,7 @@ tokio = { version = "1" } tower-lsp = { version = "0.20.0", default-features = false } tracing-subscriber = { version = "0.3.19", features = ["registry", "std", "fmt", "smallvec", "ansi", "tracing-log", "json"] } uuid = { version = "1", features = ["v4", "serde"] } -zip = { version = "2.4.1", default-features = false } +zip = { version = "2.4.2", default-features = false } [workspace.lints.clippy] assertions_on_result_states = "warn" diff --git a/rust/kcl-language-server-release/Cargo.toml b/rust/kcl-language-server-release/Cargo.toml index 0836efb63..393c7be16 100644 --- a/rust/kcl-language-server-release/Cargo.toml +++ b/rust/kcl-language-server-release/Cargo.toml @@ -21,7 +21,7 @@ slog = { workspace = true } slog-async = { workspace = true } slog-json = { workspace = true } slog-term = { workspace = true } -time = "0.3.37" +time = "0.3.40" tokio = { workspace = true, features = ["full"] } tracing-subscriber = { workspace = true } xshell = "0.2.6" diff --git a/rust/kcl-lib/Cargo.toml b/rust/kcl-lib/Cargo.toml index 3913292ae..e8566d2c4 100644 --- a/rust/kcl-lib/Cargo.toml +++ b/rust/kcl-lib/Cargo.toml @@ -120,7 +120,7 @@ approx = "0.5" base64 = "0.22.1" criterion = { version = "0.5.1", features = ["async_tokio"] } expectorate = "1.1.0" -handlebars = "6.3.0" +handlebars = "6.3.2" image = { version = "0.25.5", default-features = false, features = ["png"] } insta = { version = "1.41.1", features = ["json", "filters", "redactions"] } kcl-directory-test-macro = { version = "0.1", path = "../kcl-directory-test-macro" } diff --git a/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl b/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl index c6d1bd348..9a3e4f20d 100644 --- a/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/angled_line.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([4.83, 12.56], %) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) 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 b5270d2c1..da85cb418 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,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 27b6795bb..431759464 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,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 9663891ca..7a4309eef 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,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) 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 fe9f642a2..eeeb9adea 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,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) 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 17d764599..7212d7fed 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,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 index 321f48a47..05ea423dc 100644 --- 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 @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82], tag = $seg01) |> angledLineToX([ 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 index f3f66699d..66b8ea47a 100644 --- 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 @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82], tag = $seg01) |> angledLineToX([ 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 7301c0726..883fa21da 100644 --- a/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/broken-code-test.kcl @@ -20,7 +20,7 @@ const thickness = sqrt(6 * M * FOS / (width * sigmaAllow)) const filletR = 0.25 // Sketch the bracket and extrude with fillets -const bracket = startSketchOn('XY') +const bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, wallMountL], tag = 'outerEdge') |> line(end = [-shelfMountL, 0]) 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 cdf86f94c..20e085499 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,4 +1,4 @@ -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) diff --git a/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl b/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl index 3cafb98a4..bd6c23c87 100644 --- a/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/close_arc.kcl @@ -2,7 +2,7 @@ const center = [0,0] const radius = 40 const height = 3 -const body = startSketchOn('XY') +const body = startSketchOn(XY) |> startProfileAt([center[0]+radius, center[1]], %) |> arc({angleEnd: 360, angleStart: 0, radius}, %) |> close() diff --git a/rust/kcl-lib/e2e/executor/inputs/cylinder.kcl b/rust/kcl-lib/e2e/executor/inputs/cylinder.kcl index 94a7b4372..e5e058274 100644 --- a/rust/kcl-lib/e2e/executor/inputs/cylinder.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/cylinder.kcl @@ -1,3 +1,3 @@ -const cylinder = startSketchOn('XY') +const cylinder = startSketchOn(XY) |> circle(center= [0, 0], radius= 22) |> extrude(length = 14) diff --git a/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl b/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl index 5e34ad96c..fed26eb9e 100644 --- a/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/dimensions_match.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) 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 3a7812c18..76adba417 100644 --- a/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/extrude-custom-plane.kcl @@ -1,5 +1,5 @@ // create a sketch with name sketch000 -const sketch000 = startSketchOn('XY') +const sketch000 = startSketchOn(XY) |> startProfileAt([0.0, 0.0], %) |> line(end = [1.0, 1.0], tag = $line000) |> line(end = [0.0, -1.0], tag = $line001) 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 762a76aea..7cd53de80 100644 --- a/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/fillet-and-shell.kcl @@ -41,7 +41,7 @@ miniHdmiHole = startSketchOn(XY) ], %) |> close() -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [caseWidth, 0], $edge1) |> line(endAbsolute = [caseWidth, caseLength], $edge2) diff --git a/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl b/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl index 0b7252e24..01b9e0eac 100644 --- a/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/function_sketch.kcl @@ -1,5 +1,5 @@ fn box = (h, l, w) => { - const myBox = startSketchOn('XY') + const myBox = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(end = [0, l]) |> line(end = [w, 0]) 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 d84f7ccc3..b54642210 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,5 +1,5 @@ fn box = (p, h, l, w) => { - const myBox = startSketchOn('XY') + const myBox = startSketchOn(XY) |> startProfileAt(p, %) |> line(end = [0, l]) |> line(end = [w, 0]) diff --git a/rust/kcl-lib/e2e/executor/inputs/helix_defaults.kcl b/rust/kcl-lib/e2e/executor/inputs/helix_defaults.kcl index 68ddef5c8..d816fdc1e 100644 --- a/rust/kcl-lib/e2e/executor/inputs/helix_defaults.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/helix_defaults.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> circle(center= [5, 5], radius= 10) |> extrude(length = 10) |> helixRevolutions({revolutions = 16, angleStart = 0}, %) diff --git a/rust/kcl-lib/e2e/executor/inputs/helix_defaults_negative_extrude.kcl b/rust/kcl-lib/e2e/executor/inputs/helix_defaults_negative_extrude.kcl index 23a8170e0..8cd30053c 100644 --- a/rust/kcl-lib/e2e/executor/inputs/helix_defaults_negative_extrude.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/helix_defaults_negative_extrude.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> circle(center = [5, 5], radius = 10) |> extrude(length = -10) |> helixRevolutions({revolutions = 16, angleStart = 0}, %) diff --git a/rust/kcl-lib/e2e/executor/inputs/helix_with_length.kcl b/rust/kcl-lib/e2e/executor/inputs/helix_with_length.kcl index 9cca910d2..43cfcd8fb 100644 --- a/rust/kcl-lib/e2e/executor/inputs/helix_with_length.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/helix_with_length.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> circle(center= [5, 5], radius= 10) |> extrude(length = 10) |> helixRevolutions({revolutions = 16, angleStart = 0, length = 3}, %) diff --git a/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl b/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl index 3e4597d34..431421f21 100644 --- a/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/kittycad_svg.kcl @@ -1,4 +1,4 @@ -const svg = startSketchOn('XY') +const svg = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [2.52, -26.04]) // MoveAbsolute diff --git a/rust/kcl-lib/e2e/executor/inputs/lego.kcl b/rust/kcl-lib/e2e/executor/inputs/lego.kcl index b131b07b0..66426668d 100644 --- a/rust/kcl-lib/e2e/executor/inputs/lego.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/lego.kcl @@ -19,7 +19,7 @@ const lSegments = total_length / (lbumps + 1) const wSegments = total_width / (wbumps + 1) // make the base -const s = startSketchOn('XY') +const s = startSketchOn(XY) |> startProfileAt([-total_width / 2, -total_length / 2], %) |> line(end = [total_width, 0]) |> line(end = [0, total_length]) 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 6c8b37146..9103d13d6 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,4 +1,4 @@ -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) diff --git a/rust/kcl-lib/e2e/executor/inputs/math.kcl b/rust/kcl-lib/e2e/executor/inputs/math.kcl index 972da0422..e6f9da6cb 100644 --- a/rust/kcl-lib/e2e/executor/inputs/math.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/math.kcl @@ -1,4 +1,4 @@ -const svg = startSketchOn('XY') +const svg = startSketchOn(XY) |> lineTo([0],%) |> lineTo([0 + 1],%) |> lineTo([0 + 1 + 2],%) 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 e400e8824..1a0291af9 100644 --- a/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/member_expression_sketch.kcl @@ -1,5 +1,5 @@ fn square = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 0519ffc6a..27bb6d9ba 100644 --- a/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/mike_stress_test.kcl @@ -1,4 +1,4 @@ -const part001 = startSketchOn('XY') +const part001 = startSketchOn(XY) |> startProfileAt([0.0, 0.0], %) |> line(end = [-0.3670208139314082, 0.21201331909674526]) |> line(end = [-0.4707511307971115, 0.4905279615419764]) diff --git a/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl b/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl index a4e33f589..969064596 100644 --- a/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/negative_args.kcl @@ -3,7 +3,7 @@ const height = 10 const length = 12 fn box = (sk1, sk2, scale) => { - const boxSketch = startSketchOn('XY') + const boxSketch = startSketchOn(XY) |> startProfileAt([sk1, sk2], %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 2a2d6b7d4..b76fe3cfe 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 @@ -1,5 +1,5 @@ export fn foo = () => { return 0 } // This interacts with the engine. -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) diff --git a/rust/kcl-lib/e2e/executor/inputs/parametric.kcl b/rust/kcl-lib/e2e/executor/inputs/parametric.kcl index ddbe0cf8f..8ea8f5908 100644 --- a/rust/kcl-lib/e2e/executor/inputs/parametric.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/parametric.kcl @@ -7,7 +7,7 @@ const FOS = 2 const leg1 = 5 // inches const leg2 = 8 // inches const thickness = sqrt(distance * p * FOS * 6 / sigmaAllow / width) // inches -const bracket = startSketchOn('XY') +const bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) 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 cd60cfc0e..1fc82d798 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 circ = {angle_start: 0, angle_end: 360, radius: radius} let triangleLen = 500 -const p = startSketchOn('XY') +const p = startSketchOn(XY) |> startProfileAt([0, 0], %) |> angledLine({angle: 60, length:triangleLen}, %, $a) |> angledLine({angle: 180, length: triangleLen}, %, $b) 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 4289a1b81..7cfe89ef1 100644 --- a/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/pipes_on_pipes.kcl @@ -1,4 +1,4 @@ -const svg = startSketchOn('XY') +const svg = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [22.687663, -2.7664351]) // MoveRelative diff --git a/rust/kcl-lib/e2e/executor/inputs/riddle.kcl b/rust/kcl-lib/e2e/executor/inputs/riddle.kcl index 3a5a8178f..19480e19f 100644 --- a/rust/kcl-lib/e2e/executor/inputs/riddle.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/riddle.kcl @@ -6,7 +6,7 @@ fn m = (s) => { fn p = (xs, ys) => { let ox = 35 - (m(xs) % 70) let oy = 35 - (m(ys) % 70) - const r = startSketchOn('XZ') + const r = startSketchOn(XZ) |> startProfileAt([ox, oy], %) |> line(end = [1, 0]) |> line(end = [0, -1]) diff --git a/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl b/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl index 915c966d9..50e31c1ce 100644 --- a/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/riddle_small.kcl @@ -8,7 +8,7 @@ let xs = 205804 let ys = 71816 let ox = 35 - (t(xs) % 70) let oy = 35 - (t(ys) % 70) - const r = startSketchOn('XZ') + const r = startSketchOn(XZ) |> startProfileAt([ox, oy], %) |> line(end = [1, 0]) |> line(end = [0, -1]) 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 0667284eb..f2ea4f3f8 100644 --- a/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/router-template-slate.kcl @@ -9,7 +9,7 @@ const radius = 10 const depth = 30 const length001 = slateWidthHalf - radius const length002 = depth + minClampingDistance -const sketch001 = startSketchOn('XZ') +const sketch001 = startSketchOn(XZ) |> startProfileAt([0, depth - templateGap], %) |> xLine(length = length001, tag = $seg01) |> arc({ diff --git a/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl b/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl index 24c075a08..5ee1962fa 100644 --- a/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/scoped-tags.kcl @@ -1,5 +1,5 @@ fn rect = (origin) => { - return startSketchOn('XZ') + return startSketchOn(XZ) |> startProfileAt(origin, %) |> angledLine([0, 191.26], %, $rectangleSegmentA001) |> angledLine([ 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 9e3f65986..1159bdd7c 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,4 +1,4 @@ -const sketch001 = startSketchOn('XZ') +const sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ 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 1d46f473a..5cdd0a23f 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,4 +1,4 @@ -const sketch001 = startSketchOn('XZ') +const sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ 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 2b1b537a5..4e0d6f78d 100644 --- a/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/sketch_on_face.kcl @@ -1,4 +1,4 @@ -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([11.19, 28.35], %) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) 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 7230bde81..1c3562268 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 @@ -23,7 +23,7 @@ thickness = sqrt(6 * M * FOS / (width * sigmaAllow)) filletR = 0.25 // Sketch the bracket and extrude with fillets -bracket = startSketchOn('XY') +bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0], tag = $seg01) 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 e11b6405f..0d1e62d40 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,5 +1,5 @@ fn cube = (pos, scale) => { - const sg = startSketchOn('XY') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 88a56772f..6f97f426b 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,5 +1,5 @@ fn cube = (pos, scale) => { - const sg = startSketchOn('XY') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 45c48793e..b479b80d1 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,5 +1,5 @@ fn cube = (pos, scale) => { - const sg = startSketchOn('XY') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 b64f626c1..f71df502e 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,5 +1,5 @@ fn cube = (pos, scale) => { - const sg = startSketchOn('XY') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 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 f2b46c3f5..84effde32 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 @@ -4,7 +4,7 @@ let angleOffset = 135 let r = 1 let angleStart = 110 -startSketchOn('XY') +startSketchOn(XY) |> startProfileAt([startX, startY], %) |> angledLine({ angle: angleStart, 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 cd31727ba..b601a90a7 100644 --- a/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/test-circle-extrude.kcl @@ -1,4 +1,4 @@ -sketch002 = startSketchOn('XZ') +sketch002 = startSketchOn(XZ) |> startProfileAt([-108.83, -57.48], %) |> angledLine([0, 105.13], %, $rectangleSegmentA001) |> angledLine([ @@ -10,5 +10,5 @@ sketch002 = startSketchOn('XZ') -segLen(rectangleSegmentA001) ], %) |> close() -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> circle(center = [318.33, 168.1], radius = 182.8) diff --git a/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl b/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl index d073d7830..cc59d93e6 100644 --- a/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/xz_plane.kcl @@ -1,4 +1,4 @@ -part001 = startSketchOn('XZ') +part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) diff --git a/rust/kcl-lib/e2e/executor/main.rs b/rust/kcl-lib/e2e/executor/main.rs index 718486348..38b18082d 100644 --- a/rust/kcl-lib/e2e/executor/main.rs +++ b/rust/kcl-lib/e2e/executor/main.rs @@ -39,7 +39,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([5.5229, 5.25217], %) |> line(end = [10.50433, -1.19122]) |> line(end = [8.01362, -5.48731]) @@ -52,7 +52,7 @@ async fn kcl_test_execute_engine_error_return() { assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"engine: KclErrorDetails { source_ranges: [SourceRange([228, 247, 0])], message: "Modeling command failed: [ApiError { error_code: BadRequest, message: \"The path is not closed. Solid2D construction requires a closed path!\" }]" }"#, + r#"engine: KclErrorDetails { source_ranges: [SourceRange([226, 245, 0])], message: "Modeling command failed: [ApiError { error_code: BadRequest, message: \"The path is not closed. Solid2D construction requires a closed path!\" }]" }"#, ); } @@ -221,7 +221,7 @@ filletR = thickness * 2 shelfMountL = 9 wallMountL = 8 -bracket = startSketchOn('XY') +bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, wallMountL]) |> tangentialArc({ radius= filletR, offset: 90 }, %) @@ -236,7 +236,7 @@ bracket = startSketchOn('XY') |> close() |> extrude(length = width) -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-15.53, -10.28], %) |> line(end = [10.49, -2.08]) |> line(end = [10.42, 8.47]) @@ -256,7 +256,7 @@ part003 = startSketchOn('-XZ') |> line(end = [8.39, -3.73]) |> close() -part004 = startSketchOn('YZ') +part004 = startSketchOn(YZ) |> startProfileAt([19.04, 20.22], %) |> line(end = [9.44, -30.16]) |> line(end = [8.39, -3.73]) @@ -269,7 +269,7 @@ part004 = startSketchOn('YZ') #[tokio::test(flavor = "multi_thread")] async fn kcl_test_holes() { - let code = r#"square = startSketchOn('XY') + let code = r#"square = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -288,7 +288,7 @@ async fn kcl_test_holes() { async fn optional_params() { let code = r#" fn other_circle = (pos, radius, tag?) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> arc({angleEnd = 360, angleStart = 0, radius}, %) |> close() @@ -310,7 +310,7 @@ async fn kcl_test_rounded_with_holes() { } fn roundedRectangle = (pos, w, l, cornerRadius) => { - rr = startSketchOn('XY') + rr = startSketchOn(XY) |> startProfileAt([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) @@ -341,7 +341,7 @@ part = roundedRectangle([0, 0], 20, 20, 4) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_top_level_expression() { - let code = r#"startSketchOn('XY') |> circle(center = [0,0], radius= 22) |> extrude(length = 14)"#; + let code = r#"startSketchOn(XY) |> circle(center = [0,0], radius= 22) |> extrude(length = 14)"#; let result = execute_and_snapshot(code, None).await.unwrap(); assert_out("top_level_expression", &result); @@ -351,7 +351,7 @@ async fn kcl_test_top_level_expression() { async fn kcl_test_patterns_linear_basic_with_math() { let code = r#"num = 12 distance = 5 -part = startSketchOn('XY') +part = startSketchOn(XY) |> circle(center = [0,0], radius= 2) |> patternLinear2d(axis = [0,1], instances = num, distance = distance - 1) |> extrude(length = 1) @@ -363,7 +363,7 @@ part = startSketchOn('XY') #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_linear_basic() { - let code = r#"part = startSketchOn('XY') + let code = r#"part = startSketchOn(XY) |> circle(center = [0,0], radius= 2) |> patternLinear2d(axis = [0,1], instances = 13, distance = 4) |> extrude(length = 1) @@ -375,7 +375,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') + let code = r#"part = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0,1]) |> line(end = [1, 0]) @@ -391,7 +391,7 @@ async fn kcl_test_patterns_linear_basic_3d() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_linear_basic_negative_distance() { - let code = r#"part = startSketchOn('XY') + let code = r#"part = startSketchOn(XY) |> circle(center = [0,0], radius= 2) |> patternLinear2d(axis = [0,1], instances = 13, distance = -2) |> extrude(length = 1) @@ -403,7 +403,7 @@ async fn kcl_test_patterns_linear_basic_negative_distance() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_linear_basic_negative_axis() { - let code = r#"part = startSketchOn('XY') + let code = r#"part = startSketchOn(XY) |> circle(center = [0,0], radius= 2) |> patternLinear2d(axis = [0,-1], instances = 13, distance = 2) |> extrude(length = 1) @@ -415,11 +415,11 @@ async fn kcl_test_patterns_linear_basic_negative_axis() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_linear_basic_holes() { - let code = r#"circles = startSketchOn('XY') + let code = r#"circles = startSketchOn(XY) |> circle(center = [5, 5], radius= 1) |> patternLinear2d(axis = [1,1], instances = 13, distance = 3) -rectangle = startSketchOn('XY') +rectangle = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 50]) |> line(end = [50, 0]) @@ -436,7 +436,7 @@ rectangle = startSketchOn('XY') #[tokio::test(flavor = "multi_thread")] async fn kcl_test_patterns_circular_basic_2d() { - let code = r#"part = startSketchOn('XY') + let code = r#"part = startSketchOn(XY) |> circle(center = [0,0], radius= 2) |> patternCircular2d(center = [20, 20], instances = 13, arcDegrees = 210, rotateDuplicates = true) |> extrude(length = 1) @@ -448,7 +448,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') + let code = r#"part = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0,1]) |> line(end = [1, 0]) @@ -464,7 +464,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') + let code = r#"part = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0,1]) |> line(end = [1, 0]) @@ -572,7 +572,7 @@ model = cube"#; #[tokio::test(flavor = "multi_thread")] async fn kcl_test_cube_mm() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -703,7 +703,7 @@ myCube = cube([0,0], 10) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_error_sketch_on_arc_face() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> tangentialArcToRelative([0, scale], %, $here) |> line(end = [scale, 0]) @@ -739,7 +739,7 @@ part002 = startSketchOn(part001, part001.sketch.tags.here) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_sketch_on_face_of_face() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -774,7 +774,7 @@ part003 = startSketchOn(part002, "end") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_stdlib_kcl_error_right_code_path() { - let code = r#"square = startSketchOn('XY') + let code = r#"square = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -799,7 +799,7 @@ async fn kcl_test_stdlib_kcl_error_right_code_path() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_sketch_on_face_circle() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -827,7 +827,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') + rr = startSketchOn(XY) |> startProfileAt([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) @@ -842,10 +842,10 @@ holeIndex = 6 // Create the mounting plate extrusion, holes, and fillets part = rectShape([0, 0], 20, 20) - |> hole(circle('XY', [-holeIndex, holeIndex], holeRadius), %) - |> hole(circle('XY', [holeIndex, holeIndex], holeRadius), %) - |> hole(circle('XY', [-holeIndex, -holeIndex], holeRadius), %) - |> hole(circle('XY', [holeIndex, -holeIndex], holeRadius), %) + |> hole(circle(XY, [-holeIndex, holeIndex], holeRadius), %) + |> hole(circle(XY, [holeIndex, holeIndex], holeRadius), %) + |> hole(circle(XY, [-holeIndex, -holeIndex], holeRadius), %) + |> hole(circle(XY, [holeIndex, -holeIndex], holeRadius), %) |> extrude(length = 2) |> fillet( radius = 4, @@ -865,13 +865,13 @@ part = rectShape([0, 0], 20, 20) }; assert_eq!( err.error.message(), - "This function expected the input argument to be of type SketchOrSurface but it's actually of type string (text)" + "This function requires a keyword argument 'center'" ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_simple_revolve() { - let code = r#"part001 = startSketchOn('XY') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -891,7 +891,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -911,7 +911,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -931,7 +931,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -957,7 +957,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -983,7 +983,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -1003,7 +1003,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -1023,7 +1023,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') + let code = r#"box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -1047,7 +1047,7 @@ sketch001 = startSketchOn(box, "end") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_edge_get_edge() { - let code = r#"box = startSketchOn('XY') + let code = r#"box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -1077,7 +1077,7 @@ sketch001 = startSketchOn(box, revolveAxis) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face_circle_edge() { - let code = r#"box = startSketchOn('XY') + let code = r#"box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> line(end = [20, 0]) @@ -1099,7 +1099,7 @@ sketch001 = startSketchOn(box, "END") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face_circle() { - let code = r#"box = startSketchOn('XY') + let code = r#"box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 20]) |> line(end = [20, 0], tag = $revolveAxis) @@ -1121,7 +1121,7 @@ sketch001 = startSketchOn(box, "END") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_revolve_on_face() { - let code = r#"box = startSketchOn('XY') + let code = r#"box = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -1147,7 +1147,7 @@ sketch001 = startSketchOn(box, "end") #[tokio::test(flavor = "multi_thread")] async fn kcl_test_basic_revolve_circle() { - let code = r#"sketch001 = startSketchOn('XY') + let code = r#"sketch001 = startSketchOn(XY) |> circle(center = [15, 0], radius= 5) |> revolve( angle = 360, @@ -1161,7 +1161,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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) @@ -1202,7 +1202,7 @@ async fn kcl_test_plumbus_fillets() { } fn pentagon = (len) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt([-len / 2, -len / 2], %) |> angledLine({ angle: 0, length: len }, %, $a) |> angledLine({ @@ -1309,7 +1309,7 @@ thickness = sqrt(6 * M * FOS / (width * sigmaAllow)) filletR = 0.25 // Sketch the bracket and extrude with fillets -bracket = startSketchOn('XY') +bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0]) @@ -1364,7 +1364,7 @@ height = 0.500 dia = 4 fn squareHole = (l, w) => { - squareHoleSketch = startSketchOn('XY') + squareHoleSketch = startSketchOn(XY) |> startProfileAt([-width / 2, -length / 2], %) |> line(endAbsolute = [width / 2, -length / 2]) |> line(endAbsolute = [width / 2, length / 2]) @@ -1373,7 +1373,7 @@ fn squareHole = (l, w) => { return squareHoleSketch } -extrusion = startSketchOn('XY') +extrusion = startSketchOn(XY) |> circle(center = [0, 0], radius= dia/2 ) |> hole(squareHole(length, width, height), %) |> extrude(length = height) @@ -1383,13 +1383,13 @@ extrusion = startSketchOn('XY') assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"semantic: KclErrorDetails { source_ranges: [SourceRange([68, 360, 0]), SourceRange([449, 482, 0])], message: "Expected 2 arguments, got 3" }"# + r#"semantic: KclErrorDetails { source_ranges: [SourceRange([68, 358, 0]), SourceRange([445, 478, 0])], message: "Expected 2 arguments, got 3" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_array_of_sketches() { - let code = r#"plane001 = startSketchOn('XZ') + let code = r#"plane001 = startSketchOn(XZ) profile001 = plane001 |> startProfileAt([40.82, 240.82], %) @@ -1418,7 +1418,7 @@ sketch001 = [profile001, profile002] #[tokio::test(flavor = "multi_thread")] async fn kcl_test_circular_pattern3d_array_of_extrudes() { - let code = r#"plane001 = startSketchOn('XZ') + let code = r#"plane001 = startSketchOn(XZ) sketch001 = plane001 |> startProfileAt([40.82, 240.82], %) @@ -1551,7 +1551,7 @@ baseExtrusion = extrude(sketch001, length = width) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_shell_with_tag() { - let code = r#"sketch001 = startSketchOn('XZ') + let code = r#"sketch001 = startSketchOn(XZ) |> startProfileAt([61.74, 206.13], %) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) @@ -1572,7 +1572,7 @@ async fn kcl_test_shell_with_tag() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_linear_pattern3d_filleted_sketch() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -1603,7 +1603,7 @@ pattn1 = patternLinear3d( #[tokio::test(flavor = "multi_thread")] async fn kcl_test_circular_pattern3d_filleted_sketch() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -1630,7 +1630,7 @@ pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], i #[tokio::test(flavor = "multi_thread")] async fn kcl_test_circular_pattern3d_chamfered_sketch() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -1656,7 +1656,7 @@ pattn2 = patternCircular3d(part001, axis = [0,0, 1], center = [-20, -20, -20], i #[tokio::test(flavor = "multi_thread")] async fn kcl_test_tag_chamfer_with_more_than_one_edge_should_fail() { let code = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -1690,7 +1690,7 @@ part001 = cube([0,0], 20) #[tokio::test(flavor = "multi_thread")] async fn kcl_test_duplicate_tags_should_error() { let code = r#"fn triangle = (len) => { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([-len / 2, -len / 2], %) |> angledLine({ angle: 0, length: len }, %, $a) |> angledLine({ @@ -1710,7 +1710,7 @@ let p = triangle(200) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"value already defined: KclErrorDetails { source_ranges: [SourceRange([311, 313, 0]), SourceRange([326, 339, 0])], message: "Cannot redefine `a`" }"# + r#"value already defined: KclErrorDetails { source_ranges: [SourceRange([309, 311, 0]), SourceRange([324, 337, 0])], message: "Cannot redefine `a`" }"# ); } @@ -1765,7 +1765,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') + let code = r#"startSketchOn(XY) |> startProfileAt([10, 0], %) |> arc({ angleStart: 180, @@ -1785,13 +1785,13 @@ async fn kcl_test_arc_error_same_start_end() { assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([57, 138, 0])], message: "Arc start and end angles must be different" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([55, 136, 0])], message: "Arc start and end angles must be different" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_x_90() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineToX({ angle: 90, to: 10 }, %) |> line(end = [0, 10]) @@ -1805,13 +1805,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([72, 111, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([70, 109, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_x_270() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineToX({ angle: 270, to: 10 }, %) |> line(end = [0, 10]) @@ -1825,13 +1825,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([72, 112, 0])], message: "Cannot have an x constrained angle of 270 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([70, 110, 0])], message: "Cannot have an x constrained angle of 270 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_y_0() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineToY({ angle: 0, to: 20 }, %) |> line(end = [-20, 0]) @@ -1845,13 +1845,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([72, 110, 0])], message: "Cannot have a y constrained angle of 0 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([70, 108, 0])], message: "Cannot have a y constrained angle of 0 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_to_y_180() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineToY({ angle: 180, to: 20 }, %) |> line(end = [-20, 0]) @@ -1865,13 +1865,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([72, 112, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([70, 110, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_x_length_90() { - let code = r#"sketch001 = startSketchOn('XZ') + let code = r#"sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineOfXLength({ angle: 90, length: 10 }, %, $edge1) |> angledLineOfXLength({ angle: -15, length: 20 }, %, $edge2) @@ -1885,13 +1885,13 @@ extrusion = extrude(sketch001, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([68, 125, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([66, 123, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_x_length_270() { - let code = r#"sketch001 = startSketchOn('XZ') + let code = r#"sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> angledLineOfXLength({ angle: 90, length: 10 }, %, $edge1) |> angledLineOfXLength({ angle: -15, length: 20 }, %, $edge2) @@ -1905,13 +1905,13 @@ extrusion = extrude(sketch001, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([68, 125, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([66, 123, 0])], message: "Cannot have an x constrained angle of 90 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_0() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLineOfYLength({ angle: 0, length: 10 }, %) @@ -1927,13 +1927,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([97, 145, 0])], message: "Cannot have a y constrained angle of 0 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([95, 143, 0])], message: "Cannot have a y constrained angle of 0 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_180() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLineOfYLength({ angle: 180, length: 10 }, %) @@ -1949,13 +1949,13 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([97, 147, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([95, 145, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# ); } #[tokio::test(flavor = "multi_thread")] async fn kcl_test_angled_line_of_y_length_negative_180() { - let code = r#"exampleSketch = startSketchOn('XZ') + let code = r#"exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [10, 0]) |> angledLineOfYLength({ angle: -180, length: 10 }, %) @@ -1971,7 +1971,7 @@ example = extrude(exampleSketch, length = 10) assert!(result.is_err()); assert_eq!( result.err().unwrap().to_string(), - r#"type: KclErrorDetails { source_ranges: [SourceRange([97, 148, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# + r#"type: KclErrorDetails { source_ranges: [SourceRange([95, 146, 0])], message: "Cannot have a y constrained angle of 180 degrees" }"# ); } @@ -2015,7 +2015,7 @@ someFunction('INVALID') #[tokio::test(flavor = "multi_thread")] async fn kcl_test_error_no_auth_websocket() { - let code = r#"const sketch001 = startSketchOn('XZ') + let code = r#"const sketch001 = startSketchOn(XZ) |> startProfileAt([61.74, 206.13], %) |> xLine(length = 305.11, tag = $seg01) |> yLine(length = -291.85) @@ -2049,8 +2049,8 @@ innerDiameter = 0.364 outerDiameter = 35 / 64 length = 1 + 1 / 2 -// create a sketch on the 'XY' plane -sketch000 = startSketchOn('XY') +// create a sketch on the XY plane +sketch000 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, innerDiameter / 2]) "#; @@ -2092,7 +2092,7 @@ async fn kcl_test_ensure_nothing_left_in_batch_multi_file() { #[tokio::test(flavor = "multi_thread")] async fn kcl_test_better_type_names() { - let code = r#"startSketchOn('XY') + let code = r#"startSketchOn(XY) |> circle(center = [-95.51, -74.7], radius = 262.23) |> appearance(metalness = 0.9) "#; diff --git a/rust/kcl-lib/e2e/modify/main.rs b/rust/kcl-lib/e2e/modify/main.rs index fe963c8f4..c93a7de84 100644 --- a/rust/kcl-lib/e2e/modify/main.rs +++ b/rust/kcl-lib/e2e/modify/main.rs @@ -60,7 +60,7 @@ async fn setup(code: &str, name: &str) -> Result<(ExecutorContext, Program, Modu async fn kcl_test_modify_sketch_part001() { let name = "part001"; let code = format!( - r#"{} = startSketchOn("XY") + r#"{} = startSketchOn(XY) |> startProfileAt([8.41, 5.78], %) |> line(end = [7.37, -11]) |> line(end = [-8.69, -3.75]) @@ -85,7 +85,7 @@ async fn kcl_test_modify_sketch_part001() { async fn kcl_test_modify_sketch_part002() { let name = "part002"; let code = format!( - r#"{} = startSketchOn("XY") + r#"{} = startSketchOn(XY) |> startProfileAt([8.41, 5.78], %) |> line(end = [7.42, -8.62]) |> line(end = [-6.38, -3.51]) @@ -111,7 +111,7 @@ async fn kcl_test_modify_sketch_part002() { async fn kcl_test_modify_close_sketch() { let name = "part002"; let code = format!( - r#"{} = startSketchOn("XY") + r#"{} = startSketchOn(XY) |> startProfileAt([7.91, 3.89], %) |> line(end = [7.42, -8.62]) |> line(end = [-6.38, -3.51]) @@ -137,7 +137,7 @@ async fn kcl_test_modify_close_sketch() { async fn kcl_test_modify_line_to_close_sketch() { let name = "part002"; let code = format!( - r#"const {} = startSketchOn("XY") + r#"const {} = startSketchOn(XY) |> startProfileAt([7.91, 3.89], %) |> line(end = [7.42, -8.62]) |> line(end = [-6.38, -3.51]) @@ -157,7 +157,7 @@ async fn kcl_test_modify_line_to_close_sketch() { assert_eq!( new_code, format!( - r#"{} = startSketchOn("XY") + r#"{} = startSketchOn(XY) |> startProfileAt([7.91, 3.89], %) |> line(end = [7.42, -8.62]) |> line(end = [-6.38, -3.51]) @@ -174,7 +174,7 @@ async fn kcl_test_modify_with_constraint() { let name = "part002"; let code = format!( r#"const thing = 12 -const {} = startSketchOn("XY") +const {} = startSketchOn(XY) |> startProfileAt([7.91, 3.89], %) |> line(end = [7.42, -8.62]) |> line(end = [-6.38, -3.51]) @@ -199,7 +199,7 @@ const {} = startSketchOn("XY") async fn kcl_test_modify_line_should_close_sketch() { let name = "part003"; let code = format!( - r#"const {} = startSketchOn("XY") + r#"const {} = startSketchOn(XY) |> startProfileAt([13.69, 3.8], %) |> line(end = [4.23, -11.79]) |> line(end = [-10.7, -1.16]) @@ -219,7 +219,7 @@ async fn kcl_test_modify_line_should_close_sketch() { assert_eq!( new_code, format!( - r#"{} = startSketchOn("XY") + r#"{} = startSketchOn(XY) |> startProfileAt([13.69, 3.8], %) |> line(end = [4.23, -11.79]) |> line(end = [-10.7, -1.16]) diff --git a/rust/kcl-lib/src/lsp/tests.rs b/rust/kcl-lib/src/lsp/tests.rs index e0f2dee63..196ab8e86 100644 --- a/rust/kcl-lib/src/lsp/tests.rs +++ b/rust/kcl-lib/src/lsp/tests.rs @@ -726,7 +726,7 @@ async fn test_kcl_lsp_completions_tags() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([11.19, 28.35], %) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) @@ -1078,7 +1078,7 @@ async fn test_kcl_lsp_signature_help() { content_changes: vec![tower_lsp::lsp_types::TextDocumentContentChangeEvent { range: None, range_length: None, - text: "startSketchOn('XY')".to_string(), + text: "startSketchOn(XY)".to_string(), }], }) .await; @@ -1123,7 +1123,7 @@ async fn test_kcl_lsp_semantic_tokens() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: "startSketchOn('XY')".to_string(), + text: "startSketchOn(XY)".to_string(), }, }) .await; @@ -1153,13 +1153,13 @@ async fn test_kcl_lsp_semantic_tokens() { .get_semantic_token_type_index(&SemanticTokenType::FUNCTION) .unwrap() ); - assert_eq!(semantic_tokens.data[1].length, 4); + assert_eq!(semantic_tokens.data[1].length, 2); assert_eq!(semantic_tokens.data[1].delta_start, 14); assert_eq!(semantic_tokens.data[1].delta_line, 0); assert_eq!( semantic_tokens.data[1].token_type, server - .get_semantic_token_type_index(&SemanticTokenType::STRING) + .get_semantic_token_type_index(&SemanticTokenType::VARIABLE) .unwrap() ); } else { @@ -1216,7 +1216,7 @@ async fn test_kcl_lsp_semantic_tokens_with_modifiers() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -1479,7 +1479,7 @@ async fn test_kcl_lsp_document_symbol() { language_id: "kcl".to_string(), version: 1, text: r#"myVar = 1 -startSketchOn('XY')"# +startSketchOn(XY)"# .to_string(), }, }) @@ -1518,7 +1518,7 @@ async fn test_kcl_lsp_document_symbol_tag() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([11.19, 28.35], %) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) @@ -1564,7 +1564,7 @@ async fn test_kcl_lsp_formatting() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"startSketchOn('XY') + text: r#"startSketchOn(XY) |> startProfileAt([0,0], %)"# .to_string(), }, @@ -1595,7 +1595,7 @@ async fn test_kcl_lsp_formatting() { assert_eq!(formatting.len(), 1); assert_eq!( formatting[0].new_text, - r#"startSketchOn('XY') + r#"startSketchOn(XY) |> startProfileAt([0, 0], %)"# ); } @@ -1621,7 +1621,7 @@ thickness = 0.25 overHangLength = .4 // Sketch and revolve the inside bearing piece -insideRevolve = startSketchOn('XZ') +insideRevolve = startSketchOn(XZ) |> startProfileAt([insideDia / 2, 0], %) |> line(end = [0, thickness + sphereDia / 2]) |> line(end = [overHangLength, 0]) @@ -1635,7 +1635,7 @@ insideRevolve = startSketchOn('XZ') |> revolve({ axis: 'y' }, %) // 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') +sphere = startSketchOn(XZ) |> startProfileAt([ 0.05 + insideDia / 2 + thickness, 0 - 0.05 @@ -1657,7 +1657,7 @@ sphere = startSketchOn('XZ') ) // Sketch and revolve the outside bearing -outsideRevolve = startSketchOn('XZ') +outsideRevolve = startSketchOn(XZ) |> startProfileAt([ insideDia / 2 + thickness + sphereDia, 0 @@ -1721,7 +1721,7 @@ thickness = 0.25 overHangLength = .4 // Sketch and revolve the inside bearing piece -insideRevolve = startSketchOn('XZ') +insideRevolve = startSketchOn(XZ) |> startProfileAt([insideDia / 2, 0], %) |> line(end = [0, thickness + sphereDia / 2]) |> line(end = [overHangLength, 0]) @@ -1735,7 +1735,7 @@ insideRevolve = startSketchOn('XZ') |> revolve({ axis = 'y' }, %) // 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') +sphere = startSketchOn(XZ) |> startProfileAt([ 0.05 + insideDia / 2 + thickness, 0 - 0.05 @@ -1757,7 +1757,7 @@ sphere = startSketchOn('XZ') ) // Sketch and revolve the outside bearing -outsideRevolve = startSketchOn('XZ') +outsideRevolve = startSketchOn(XZ) |> startProfileAt([ insideDia / 2 + thickness + sphereDia, 0 @@ -2007,7 +2007,7 @@ async fn test_copilot_lsp_completions_raw() { let completions = server .get_completions( "kcl".to_string(), - r#"bracket = startSketchOn('XY') + r#"bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) "# .to_string(), @@ -2026,7 +2026,7 @@ async fn test_copilot_lsp_completions_raw() { let completions_hit_cache = server .get_completions( "kcl".to_string(), - r#"bracket = startSketchOn('XY') + r#"bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) "# .to_string(), @@ -2066,7 +2066,7 @@ async fn test_copilot_lsp_completions() { path: "file:///test.copilot".to_string(), position: crate::lsp::copilot::types::CopilotPosition { line: 3, character: 3 }, relative_path: "test.copilot".to_string(), - source: r#"bracket = startSketchOn('XY') + source: r#"bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> close() @@ -2388,7 +2388,7 @@ async fn kcl_test_kcl_lsp_diagnostics_on_execution_error() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2409,7 +2409,7 @@ async fn kcl_test_kcl_lsp_diagnostics_on_execution_error() { assert_diagnostic_count(server.diagnostics_map.get("file:///test.kcl").as_deref(), 1); // Update the text. - let new_text = r#"part001 = startSketchOn('XY') + let new_text = r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2447,7 +2447,7 @@ async fn kcl_test_kcl_lsp_full_to_empty_file_updates_ast_and_memory() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2490,7 +2490,7 @@ async fn kcl_test_kcl_lsp_full_to_empty_file_updates_ast_and_memory() { 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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2576,7 +2576,7 @@ async fn kcl_test_kcl_lsp_code_unchanged_but_has_diagnostics_reexecute() { 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') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2651,7 +2651,7 @@ async fn kcl_test_kcl_lsp_code_and_ast_unchanged_but_has_diagnostics_reexecute() async fn kcl_test_kcl_lsp_cant_execute_set() { let server = kcl_lsp_server(true).await.unwrap(); - let code = r#"part001 = startSketchOn('XY') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2730,7 +2730,7 @@ async fn test_kcl_lsp_folding() { uri: "file:///test.kcl".try_into().unwrap(), language_id: "kcl".to_string(), version: 1, - text: r#"startSketchOn('XY') + text: r#"startSketchOn(XY) |> startProfileAt([0,0], %)"# .to_string(), }, @@ -2755,12 +2755,12 @@ async fn test_kcl_lsp_folding() { assert_eq!( folding.first().unwrap().clone(), tower_lsp::lsp_types::FoldingRange { - start_line: 19, + start_line: 17, start_character: None, - end_line: 67, + end_line: 65, end_character: None, kind: Some(tower_lsp::lsp_types::FoldingRangeKind::Region), - collapsed_text: Some("startSketchOn('XY')".to_string()) + collapsed_text: Some("startSketchOn(XY)".to_string()) } ); } @@ -2769,7 +2769,7 @@ async fn test_kcl_lsp_folding() { async fn kcl_test_kcl_lsp_code_with_parse_error_and_ast_unchanged_but_has_diagnostics_reparse() { let server = kcl_lsp_server(false).await.unwrap(); - let code = r#"part001 = startSketchOn('XY') + let code = r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2824,7 +2824,7 @@ async fn kcl_test_kcl_lsp_code_with_lint_and_ast_unchanged_but_has_diagnostics_r let server = kcl_lsp_server(false).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2878,7 +2878,7 @@ async fn kcl_test_kcl_lsp_code_with_lint_and_parse_error_and_ast_unchanged_but_h let server = kcl_lsp_server(false).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -2933,7 +2933,7 @@ async fn kcl_test_kcl_lsp_code_lint_and_ast_unchanged_but_has_diagnostics_reexec let server = kcl_lsp_server(true).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -2992,7 +2992,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_new_lint() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -3031,7 +3031,7 @@ part001 = startSketchOn('XY') content_changes: vec![tower_lsp::lsp_types::TextDocumentContentChangeEvent { range: None, range_length: None, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -3059,7 +3059,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_new_ast_error() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -3098,7 +3098,7 @@ part001 = startSketchOn('XY') content_changes: vec![tower_lsp::lsp_types::TextDocumentContentChangeEvent { range: None, range_length: None, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> ^^^^startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20], tag = $seg01) @@ -3126,7 +3126,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_had_lint_new_parse_error() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -3173,7 +3173,7 @@ part001 = startSketchOn('XY') content_changes: vec![tower_lsp::lsp_types::TextDocumentContentChangeEvent { range: None, range_length: None, - text: r#"part001 = startSketchOn('XY') + text: r#"part001 = startSketchOn(XY) |> ^^^^startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -3209,7 +3209,7 @@ async fn kcl_test_kcl_lsp_code_lint_reexecute_had_lint_new_execution_error() { let server = kcl_lsp_server(true).await.unwrap(); let code = r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0]) |> line(end = [0, 20]) @@ -3261,7 +3261,7 @@ part001 = startSketchOn('XY') range: None, range_length: None, text: r#"LINT = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, 20], tag = $seg01) diff --git a/rust/kcl-lib/src/parsing/ast/types/literal_value.rs b/rust/kcl-lib/src/parsing/ast/types/literal_value.rs index 4d813630d..4b0304603 100644 --- a/rust/kcl-lib/src/parsing/ast/types/literal_value.rs +++ b/rust/kcl-lib/src/parsing/ast/types/literal_value.rs @@ -25,6 +25,13 @@ impl LiteralValue { suffix: NumericSuffix::None, } } + + pub fn string_value(&self) -> Option<&str> { + match self { + Self::String(s) => Some(s), + _ => None, + } + } } impl fmt::Display for LiteralValue { diff --git a/rust/kcl-lib/src/parsing/ast/types/mod.rs b/rust/kcl-lib/src/parsing/ast/types/mod.rs index 89531d78d..33b640b79 100644 --- a/rust/kcl-lib/src/parsing/ast/types/mod.rs +++ b/rust/kcl-lib/src/parsing/ast/types/mod.rs @@ -2211,8 +2211,13 @@ impl Node { /// Get the constraint level for this identifier. /// Identifier are always fully constrained. pub fn get_constraint_level(&self) -> ConstraintLevel { - ConstraintLevel::Full { - source_ranges: vec![self.into()], + match &*self.name { + "XY" | "XZ" | "YZ" => ConstraintLevel::None { + source_ranges: vec![self.into()], + }, + _ => ConstraintLevel::Full { + source_ranges: vec![self.into()], + }, } } } @@ -3531,11 +3536,11 @@ mod tests { #[test] fn test_get_lsp_folding_ranges() { - let code = r#"const part001 = startSketchOn('XY') + let code = r#"const part001 = startSketchOn(XY) |> startProfileAt([0.0000000000, 5.0000000000], %) |> line([0.4900857016, -0.0240763666], %) -startSketchOn('XY') +startSketchOn(XY) |> startProfileAt([0.0000000000, 5.0000000000], %) |> line([0.4900857016, -0.0240763666], %) @@ -3554,20 +3559,17 @@ ghi("things") let program = crate::parsing::top_level_parse(code).unwrap(); let folding_ranges = program.get_lsp_folding_ranges(); assert_eq!(folding_ranges.len(), 3); - assert_eq!(folding_ranges[0].start_line, 29); - assert_eq!(folding_ranges[0].end_line, 134); + assert_eq!(folding_ranges[0].start_line, 27); + assert_eq!(folding_ranges[0].end_line, 132); assert_eq!( folding_ranges[0].collapsed_text, - Some("part001 = startSketchOn('XY')".to_string()) + Some("part001 = startSketchOn(XY)".to_string()) ); - assert_eq!(folding_ranges[1].start_line, 155); - assert_eq!(folding_ranges[1].end_line, 254); - assert_eq!( - folding_ranges[1].collapsed_text, - Some("startSketchOn('XY')".to_string()) - ); - assert_eq!(folding_ranges[2].start_line, 384); - assert_eq!(folding_ranges[2].end_line, 403); + assert_eq!(folding_ranges[1].start_line, 151); + assert_eq!(folding_ranges[1].end_line, 250); + assert_eq!(folding_ranges[1].collapsed_text, Some("startSketchOn(XY)".to_string())); + assert_eq!(folding_ranges[2].start_line, 380); + assert_eq!(folding_ranges[2].end_line, 399); assert_eq!(folding_ranges[2].collapsed_text, Some("fn ghi(x) {".to_string())); } @@ -4033,7 +4035,7 @@ const cylinder = startSketchOn('-XZ') async fn test_parse_get_meta_settings_inch() { let some_program_string = r#"@settings(defaultLengthUnit = inch) -startSketchOn('XY')"#; +startSketchOn(XY)"#; let program = crate::parsing::top_level_parse(some_program_string).unwrap(); let result = program.meta_settings().unwrap(); assert!(result.is_some()); @@ -4049,7 +4051,7 @@ startSketchOn('XY')"#; async fn test_parse_get_meta_settings_inch_to_mm() { let some_program_string = r#"@settings(defaultLengthUnit = inch) -startSketchOn('XY')"#; +startSketchOn(XY)"#; let program = crate::parsing::top_level_parse(some_program_string).unwrap(); let result = program.meta_settings().unwrap(); assert!(result.is_some()); @@ -4080,14 +4082,14 @@ startSketchOn('XY')"#; formatted, r#"@settings(defaultLengthUnit = mm) -startSketchOn('XY') +startSketchOn(XY) "# ); } #[tokio::test(flavor = "multi_thread")] async fn test_parse_get_meta_settings_nothing_to_mm() { - let some_program_string = r#"startSketchOn('XY')"#; + let some_program_string = r#"startSketchOn(XY)"#; let program = crate::parsing::top_level_parse(some_program_string).unwrap(); let result = program.meta_settings().unwrap(); assert!(result.is_none()); @@ -4112,7 +4114,7 @@ startSketchOn('XY') formatted, r#"@settings(defaultLengthUnit = mm) -startSketchOn('XY') +startSketchOn(XY) "# ); } diff --git a/rust/kcl-lib/src/parsing/mod.rs b/rust/kcl-lib/src/parsing/mod.rs index 1e6db35d4..00e422ba6 100644 --- a/rust/kcl-lib/src/parsing/mod.rs +++ b/rust/kcl-lib/src/parsing/mod.rs @@ -146,6 +146,32 @@ impl From for ParseResult { } } +const STR_DEPRECATIONS: [(&str, &str); 6] = [ + ("XY", "XY"), + ("XZ", "XZ"), + ("YZ", "YZ"), + ("-XY", "-XY"), + ("-XZ", "-XZ"), + ("-YZ", "-YZ"), +]; +const FN_DEPRECATIONS: [(&str, &str); 3] = [("pi", "PI"), ("e", "E"), ("tau", "TAU")]; +const CONST_DEPRECATIONS: [(&str, &str); 0] = []; + +#[derive(Clone, Copy)] +pub enum DeprecationKind { + String, + Function, + Const, +} + +pub fn deprecation(s: &str, kind: DeprecationKind) -> Option<&'static str> { + match kind { + DeprecationKind::String => STR_DEPRECATIONS.iter().find_map(|(a, b)| (*a == s).then_some(*b)), + DeprecationKind::Function => FN_DEPRECATIONS.iter().find_map(|(a, b)| (*a == s).then_some(*b)), + DeprecationKind::Const => CONST_DEPRECATIONS.iter().find_map(|(a, b)| (*a == s).then_some(*b)), + } +} + #[cfg(test)] mod tests { macro_rules! parse_and_lex { diff --git a/rust/kcl-lib/src/parsing/parser.rs b/rust/kcl-lib/src/parsing/parser.rs index 2a9098f4a..1c9828487 100644 --- a/rust/kcl-lib/src/parsing/parser.rs +++ b/rust/kcl-lib/src/parsing/parser.rs @@ -15,6 +15,7 @@ use winnow::{ use super::{ ast::types::{Ascription, ImportPath, LabelledExpression}, token::{NumericSuffix, RESERVED_WORDS}, + DeprecationKind, }; use crate::{ docs::StdLibFn, @@ -477,7 +478,8 @@ fn string_literal(i: &mut TokenSlice) -> PResult> { }) .context(expected("string literal (like \"myPart\"")) .parse_next(i)?; - Ok(Node::new( + + let result = Node::new( Literal { value, raw: token.value.clone(), @@ -486,7 +488,32 @@ fn string_literal(i: &mut TokenSlice) -> PResult> { token.start, token.end, token.module_id, - )) + ); + + if let Some(suggestion) = super::deprecation(result.value.string_value().unwrap(), DeprecationKind::String) { + ParseContext::warn( + CompilationError::err( + result.as_source_range(), + format!( + "Using `\"{}\"` is deprecated, prefer using `{}`.", + result.value.string_value().unwrap(), + suggestion + ), + ) + .with_suggestion( + format!( + "Replace `\"{}\"` with `{}`", + result.value.string_value().unwrap(), + suggestion + ), + suggestion, + None, + Tag::Deprecated, + ), + ); + } + + Ok(result) } /// Parse a KCL literal number, with no - sign. @@ -2315,6 +2342,21 @@ fn nameable_identifier(i: &mut TokenSlice) -> PResult> { )); } + if let Some(suggestion) = super::deprecation(&result.name, DeprecationKind::Const) { + ParseContext::warn( + CompilationError::err( + result.as_source_range(), + format!("Using `{}` is deprecated, prefer using `{}`.", result.name, suggestion), + ) + .with_suggestion( + format!("Replace `{}` with `{}`", result.name, suggestion), + suggestion, + None, + Tag::Deprecated, + ), + ); + } + Ok(result) } @@ -3016,7 +3058,7 @@ fn fn_call(i: &mut TokenSlice) -> PResult> { } let end = preceded(opt(whitespace), close_paren).parse_next(i)?.end; - Ok(Node::new_node( + let result = Node::new_node( fn_name.start, end, fn_name.module_id, @@ -3025,7 +3067,27 @@ fn fn_call(i: &mut TokenSlice) -> PResult> { arguments: args, digest: None, }, - )) + ); + + if let Some(suggestion) = super::deprecation(&result.callee.name, DeprecationKind::Function) { + ParseContext::warn( + CompilationError::err( + result.as_source_range(), + format!( + "Calling `{}` is deprecated, prefer using `{}`.", + result.callee.name, suggestion + ), + ) + .with_suggestion( + format!("Replace `{}` with `{}`", result.callee.name, suggestion), + suggestion, + None, + Tag::Deprecated, + ), + ); + } + + Ok(result) } fn fn_call_kw(i: &mut TokenSlice) -> PResult> { @@ -3097,7 +3159,7 @@ fn fn_call_kw(i: &mut TokenSlice) -> PResult> { non_code_nodes, ..Default::default() }; - Ok(Node::new_node( + let result = Node::new_node( fn_name.start, end, fn_name.module_id, @@ -3108,7 +3170,27 @@ fn fn_call_kw(i: &mut TokenSlice) -> PResult> { digest: None, non_code_meta, }, - )) + ); + + if let Some(suggestion) = super::deprecation(&result.callee.name, DeprecationKind::Function) { + ParseContext::warn( + CompilationError::err( + result.as_source_range(), + format!( + "Calling `{}` is deprecated, prefer using `{}`.", + result.callee.name, suggestion + ), + ) + .with_suggestion( + format!("Replace `{}` with `{}`", result.callee.name, suggestion), + suggestion, + None, + Tag::Deprecated, + ), + ); + } + + Ok(result) } #[cfg(test)] @@ -3326,7 +3408,7 @@ mySk1 = startSketchOn(XY) #[test] fn inline_comment_pipe_expression() { - let test_input = r#"a('XY') + let test_input = r#"a(XY) |> b(%) |> c(%) // inline-comment |> d(%)"#; diff --git a/rust/kcl-lib/src/parsing/snapshots/kcl_lib__parsing__parser__snapshot_tests__au.snap b/rust/kcl-lib/src/parsing/snapshots/kcl_lib__parsing__parser__snapshot_tests__au.snap index 916e7d1cf..865847668 100644 --- a/rust/kcl-lib/src/parsing/snapshots/kcl_lib__parsing__parser__snapshot_tests__au.snap +++ b/rust/kcl-lib/src/parsing/snapshots/kcl_lib__parsing__parser__snapshot_tests__au.snap @@ -8,7 +8,7 @@ expression: actual "commentStart": 0, "declaration": { "commentStart": 6, - "end": 106, + "end": 104, "id": { "commentStart": 6, "end": 14, @@ -22,12 +22,11 @@ expression: actual "arguments": [ { "commentStart": 31, - "end": 35, - "raw": "'XY'", + "end": 33, + "name": "XY", "start": 31, - "type": "Literal", - "type": "Literal", - "value": "XY" + "type": "Identifier", + "type": "Identifier" } ], "callee": { @@ -38,7 +37,7 @@ expression: actual "type": "Identifier" }, "commentStart": 17, - "end": 36, + "end": 34, "start": 17, "type": "CallExpression", "type": "CallExpression" @@ -48,20 +47,20 @@ expression: actual { "type": "LabeledArg", "label": { - "commentStart": 51, - "end": 57, + "commentStart": 49, + "end": 55, "name": "center", - "start": 51, + "start": 49, "type": "Identifier" }, "arg": { - "commentStart": 59, + "commentStart": 57, "elements": [ { - "commentStart": 60, - "end": 61, + "commentStart": 58, + "end": 59, "raw": "0", - "start": 60, + "start": 58, "type": "Literal", "type": "Literal", "value": { @@ -70,10 +69,10 @@ expression: actual } }, { - "commentStart": 63, - "end": 64, + "commentStart": 61, + "end": 62, "raw": "0", - "start": 63, + "start": 61, "type": "Literal", "type": "Literal", "value": { @@ -82,8 +81,8 @@ expression: actual } } ], - "end": 65, - "start": 59, + "end": 63, + "start": 57, "type": "ArrayExpression", "type": "ArrayExpression" } @@ -91,17 +90,17 @@ expression: actual { "type": "LabeledArg", "label": { - "commentStart": 67, - "end": 73, + "commentStart": 65, + "end": 71, "name": "radius", - "start": 67, + "start": 65, "type": "Identifier" }, "arg": { - "commentStart": 75, - "end": 77, + "commentStart": 73, + "end": 75, "raw": "22", - "start": 75, + "start": 73, "type": "Literal", "type": "Literal", "value": { @@ -112,15 +111,15 @@ expression: actual } ], "callee": { - "commentStart": 44, - "end": 50, + "commentStart": 42, + "end": 48, "name": "circle", - "start": 44, + "start": 42, "type": "Identifier" }, - "commentStart": 44, - "end": 78, - "start": 44, + "commentStart": 42, + "end": 76, + "start": 42, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": null @@ -130,17 +129,17 @@ expression: actual { "type": "LabeledArg", "label": { - "commentStart": 94, - "end": 100, + "commentStart": 92, + "end": 98, "name": "length", - "start": 94, + "start": 92, "type": "Identifier" }, "arg": { - "commentStart": 103, - "end": 105, + "commentStart": 101, + "end": 103, "raw": "14", - "start": 103, + "start": 101, "type": "Literal", "type": "Literal", "value": { @@ -151,22 +150,22 @@ expression: actual } ], "callee": { - "commentStart": 86, - "end": 93, + "commentStart": 84, + "end": 91, "name": "extrude", - "start": 86, + "start": 84, "type": "Identifier" }, - "commentStart": 86, - "end": 106, - "start": 86, + "commentStart": 84, + "end": 104, + "start": 84, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": null } ], "commentStart": 17, - "end": 106, + "end": 104, "start": 17, "type": "PipeExpression", "type": "PipeExpression" @@ -174,7 +173,7 @@ expression: actual "start": 6, "type": "VariableDeclarator" }, - "end": 106, + "end": 104, "kind": "const", "start": 0, "type": "VariableDeclaration", @@ -182,6 +181,6 @@ expression: actual } ], "commentStart": 0, - "end": 107, + "end": 105, "start": 0 } diff --git a/rust/kcl-lib/src/std/extrude.rs b/rust/kcl-lib/src/std/extrude.rs index 03a10e6bb..99279f6e3 100644 --- a/rust/kcl-lib/src/std/extrude.rs +++ b/rust/kcl-lib/src/std/extrude.rs @@ -130,6 +130,7 @@ async fn inner_extrude( sketch, id.into(), length, + false, &NamedCapTags { start: tag_start.as_ref(), end: tag_end.as_ref(), @@ -154,6 +155,7 @@ pub(crate) async fn do_post_extrude<'a>( sketch: &Sketch, solid_id: ArtifactId, length: f64, + sectional: bool, named_cap_tags: &'a NamedCapTags<'a>, exec_state: &mut ExecState, args: &Args, @@ -201,6 +203,25 @@ pub(crate) async fn do_post_extrude<'a>( vec![] }; + // Face filtering attempt in order to resolve https://github.com/KittyCAD/modeling-app/issues/5328 + // In case of a sectional sweep, empirically it looks that the first n faces that are yielded from the sweep + // are the ones that work with GetOppositeEdge and GetNextAdjacentEdge, aka the n sides in the sweep. + // So here we're figuring out that n number as yielded_sides_count here, + // making sure that circle() calls count but close() don't (no length) + let count_of_first_set_of_faces_if_sectional = if sectional { + sketch + .paths + .iter() + .filter(|p| { + let is_circle = matches!(p, Path::Circle { .. }); + let has_length = p.get_base().from != p.get_base().to; + is_circle || has_length + }) + .count() + } else { + usize::MAX + }; + for (curve_id, face_id) in face_infos .iter() .filter(|face_info| face_info.cap == ExtrusionFaceCapType::None) @@ -211,6 +232,7 @@ pub(crate) async fn do_post_extrude<'a>( None } }) + .take(count_of_first_set_of_faces_if_sectional) { // Batch these commands, because the Rust code doesn't actually care about the outcome. // So, there's no need to await them. diff --git a/rust/kcl-lib/src/std/loft.rs b/rust/kcl-lib/src/std/loft.rs index 86ed5db35..12fbffa54 100644 --- a/rust/kcl-lib/src/std/loft.rs +++ b/rust/kcl-lib/src/std/loft.rs @@ -174,6 +174,7 @@ async fn inner_loft( &sketch, id.into(), 0.0, + false, &super::extrude::NamedCapTags { start: tag_start.as_ref(), end: tag_end.as_ref(), diff --git a/rust/kcl-lib/src/std/revolve.rs b/rust/kcl-lib/src/std/revolve.rs index 872edc1af..be811dbd0 100644 --- a/rust/kcl-lib/src/std/revolve.rs +++ b/rust/kcl-lib/src/std/revolve.rs @@ -303,6 +303,7 @@ async fn inner_revolve( sketch, id.into(), 0.0, + false, &super::extrude::NamedCapTags { start: tag_start.as_ref(), end: tag_end.as_ref(), diff --git a/rust/kcl-lib/src/std/sweep.rs b/rust/kcl-lib/src/std/sweep.rs index 3c1242c36..32041cfd9 100644 --- a/rust/kcl-lib/src/std/sweep.rs +++ b/rust/kcl-lib/src/std/sweep.rs @@ -183,6 +183,7 @@ async fn inner_sweep( sketch, id.into(), 0.0, + sectional.unwrap_or(false), &super::extrude::NamedCapTags { start: tag_start.as_ref(), end: tag_end.as_ref(), diff --git a/rust/kcl-lib/src/unparser.rs b/rust/kcl-lib/src/unparser.rs index 4cfe7aefb..11918e20f 100644 --- a/rust/kcl-lib/src/unparser.rs +++ b/rust/kcl-lib/src/unparser.rs @@ -8,8 +8,9 @@ use crate::parsing::{ LiteralValue, MemberExpression, MemberObject, Node, NonCodeNode, NonCodeValue, ObjectExpression, Parameter, PipeExpression, Program, TagDeclarator, TypeDeclaration, UnaryExpression, VariableDeclaration, VariableKind, }, + deprecation, token::NumericSuffix, - PIPE_OPERATOR, + DeprecationKind, PIPE_OPERATOR, }; impl Program { @@ -292,7 +293,10 @@ impl Expr { } Expr::CallExpression(call_exp) => call_exp.recast(options, indentation_level, ctxt), Expr::CallExpressionKw(call_exp) => call_exp.recast(options, indentation_level, ctxt), - Expr::Identifier(ident) => ident.name.to_string(), + Expr::Identifier(ident) => match deprecation(&ident.name, DeprecationKind::Const) { + Some(suggestion) => suggestion.to_owned(), + None => ident.name.to_owned(), + }, Expr::TagDeclarator(tag) => tag.recast(), Expr::PipeExpression(pipe_exp) => pipe_exp.recast(options, indentation_level), Expr::UnaryExpression(unary_exp) => unary_exp.recast(options), @@ -321,7 +325,10 @@ impl BinaryPart { fn recast(&self, options: &FormatOptions, indentation_level: usize) -> String { match &self { BinaryPart::Literal(literal) => literal.recast(), - BinaryPart::Identifier(identifier) => identifier.name.to_string(), + BinaryPart::Identifier(ident) => match deprecation(&ident.name, DeprecationKind::Const) { + Some(suggestion) => suggestion.to_owned(), + None => ident.name.to_owned(), + }, BinaryPart::BinaryExpression(binary_expression) => binary_expression.recast(options), BinaryPart::CallExpression(call_expression) => { call_expression.recast(options, indentation_level, ExprContext::Other) @@ -376,6 +383,11 @@ impl CallExpressionKw { options.get_indentation(indentation_level) }; let name = &self.callee.name; + + if let Some(suggestion) = deprecation(name, DeprecationKind::Function) { + return format!("{indent}{suggestion}"); + } + let arg_list = self.recast_args(options, indentation_level, ctxt); let args = arg_list.clone().join(", "); let has_lots_of_args = arg_list.len() >= 4; @@ -480,6 +492,9 @@ impl Literal { } } LiteralValue::String(ref s) => { + if let Some(suggestion) = deprecation(s, DeprecationKind::String) { + return suggestion.to_owned(); + } let quote = if self.raw.trim().starts_with('"') { '"' } else { '\'' }; format!("{quote}{s}{quote}") } @@ -1078,7 +1093,7 @@ s = 1 // s = 1 -> height of Z is 13.4mm d = 1 fn rect(x, y, w, h) { - startSketchOn('XY') + startSketchOn(XY) |> startProfileAt([x, y], %) |> xLine(length = w) |> yLine(length = h) @@ -1088,7 +1103,7 @@ fn rect(x, y, w, h) { } fn quad(x1, y1, x2, y2, x3, y3, x4, y4) { - startSketchOn('XY') + startSketchOn(XY) |> startProfileAt([x1, y1], %) |> line(endAbsolute = [x2, y2]) |> line(endAbsolute = [x3, y3]) @@ -1098,7 +1113,7 @@ fn quad(x1, y1, x2, y2, x3, y3, x4, y4) { } fn crosshair(x, y) { - startSketchOn('XY') + startSketchOn(XY) |> startProfileAt([x, y], %) |> yLine(length = 1) |> yLine(length = -2) @@ -1144,7 +1159,7 @@ fn o(c_x, c_y) { // crosshair(c_x, c_y) - startSketchOn('XY') + startSketchOn(XY) |> startProfileAt([o_x1, o_y1], %) |> arc({ radius = o_r, @@ -1160,7 +1175,7 @@ fn o(c_x, c_y) { |> close() |> extrude(d, %) - startSketchOn('XY') + startSketchOn(XY) |> startProfileAt([o_x2, o_y2], %) |> arc({ radius = o_r, @@ -1203,7 +1218,7 @@ thickness = 0.25 overHangLength = .4 // Sketch and revolve the inside bearing piece -insideRevolve = startSketchOn('XZ') +insideRevolve = startSketchOn(XZ) |> startProfileAt([insideDia / 2, 0], %) |> line([0, thickness + sphereDia / 2], %) |> line([overHangLength, 0], %) @@ -1217,7 +1232,7 @@ insideRevolve = startSketchOn('XZ') |> revolve({ axis: 'y' }, %) // 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') +sphere = startSketchOn(XZ) |> startProfileAt([ 0.05 + insideDia / 2 + thickness, 0 - 0.05 @@ -1239,7 +1254,7 @@ sphere = startSketchOn('XZ') ) // Sketch and revolve the outside bearing -outsideRevolve = startSketchOn('XZ') +outsideRevolve = startSketchOn(XZ) |> startProfileAt([ insideDia / 2 + thickness + sphereDia, 0 @@ -1269,7 +1284,7 @@ thickness = 0.25 overHangLength = .4 // Sketch and revolve the inside bearing piece -insideRevolve = startSketchOn('XZ') +insideRevolve = startSketchOn(XZ) |> startProfileAt([insideDia / 2, 0], %) |> line([0, thickness + sphereDia / 2], %) |> line([overHangLength, 0], %) @@ -1283,7 +1298,7 @@ insideRevolve = startSketchOn('XZ') |> revolve({ axis = 'y' }, %) // 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') +sphere = startSketchOn(XZ) |> startProfileAt([ 0.05 + insideDia / 2 + thickness, 0 - 0.05 @@ -1305,7 +1320,7 @@ sphere = startSketchOn('XZ') ) // Sketch and revolve the outside bearing -outsideRevolve = startSketchOn('XZ') +outsideRevolve = startSketchOn(XZ) |> startProfileAt([ insideDia / 2 + thickness + sphereDia, 0 @@ -1455,7 +1470,7 @@ myNestedVar = [ #[test] fn test_recast_shebang() { let some_program_string = r#"#!/usr/local/env zoo kcl -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1470,7 +1485,7 @@ part001 = startSketchOn('XY') recasted, r#"#!/usr/local/env zoo kcl -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1486,7 +1501,7 @@ part001 = startSketchOn('XY') -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1501,7 +1516,7 @@ part001 = startSketchOn('XY') recasted, r#"#!/usr/local/env zoo kcl -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1516,7 +1531,7 @@ part001 = startSketchOn('XY') let some_program_string = r#"#!/usr/local/env zoo kcl // Yo yo my comments. -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1532,7 +1547,7 @@ part001 = startSketchOn('XY') r#"#!/usr/local/env zoo kcl // Yo yo my comments. -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-10, -10], %) |> line([20, 0], %) |> line([0, 20], %) @@ -1795,7 +1810,7 @@ tabs_l = startSketchOn({ #[test] fn test_recast_nested_var_declaration_in_fn_body() { let some_program_string = r#"fn cube = (pos, scale) => { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line([0, scale], %) |> line([scale, 0], %) @@ -1809,7 +1824,7 @@ tabs_l = startSketchOn({ assert_eq!( recasted, r#"fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line([0, scale], %) |> line([scale, 0], %) @@ -1826,7 +1841,7 @@ tabs_l = startSketchOn({ let some_program_string = r#"fn cube(pos, scale) { x = dfsfs + dfsfsd as y - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) as foo |> line([0, scale], %) |> line([scale, 0], %) as bar @@ -1845,7 +1860,7 @@ cube(0, 0) as cub #[test] fn test_recast_with_bad_indentation() { - let some_program_string = r#"part001 = startSketchOn('XY') + let some_program_string = r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) |> line([0.6804562304, 0.9087880491], %)"#; @@ -1854,7 +1869,7 @@ cube(0, 0) as cub let recasted = program.recast(&Default::default(), 0); assert_eq!( recasted, - r#"part001 = startSketchOn('XY') + r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) |> line([0.6804562304, 0.9087880491], %) @@ -1864,7 +1879,7 @@ cube(0, 0) as cub #[test] fn test_recast_with_bad_indentation_and_inline_comment() { - let some_program_string = r#"part001 = startSketchOn('XY') + let some_program_string = r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) // hello world |> line([0.6804562304, 0.9087880491], %)"#; @@ -1873,7 +1888,7 @@ cube(0, 0) as cub let recasted = program.recast(&Default::default(), 0); assert_eq!( recasted, - r#"part001 = startSketchOn('XY') + r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) // hello world |> line([0.6804562304, 0.9087880491], %) @@ -1882,7 +1897,7 @@ cube(0, 0) as cub } #[test] fn test_recast_with_bad_indentation_and_line_comment() { - let some_program_string = r#"part001 = startSketchOn('XY') + let some_program_string = r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) // hello world @@ -1892,7 +1907,7 @@ cube(0, 0) as cub let recasted = program.recast(&Default::default(), 0); assert_eq!( recasted, - r#"part001 = startSketchOn('XY') + r#"part001 = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) // hello world @@ -2047,7 +2062,7 @@ mySk1 = startSketchOn(XY) #[test] fn test_recast_lots_of_comments() { let some_program_string = r#"// comment at start -mySk1 = startSketchOn('XY') +mySk1 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) // comment here @@ -2068,7 +2083,7 @@ mySk1 = startSketchOn('XY') assert_eq!( recasted, r#"// comment at start -mySk1 = startSketchOn('XY') +mySk1 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) // comment here @@ -2088,7 +2103,7 @@ mySk1 = startSketchOn('XY') #[test] fn test_recast_multiline_object() { - let some_program_string = r#"part001 = startSketchOn('XY') + let some_program_string = r#"part001 = startSketchOn(XY) |> startProfileAt([-0.01, -0.08], %) |> line([0.62, 4.15], %, $seg01) |> line([2.77, -1.24], %) @@ -2170,7 +2185,7 @@ myVar2 = 5 myVar3 = 6 myAng = 40 myAng2 = 134 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line([1, 3.82], %, $seg01) // ln-should-get-tag |> angledLineToX([ @@ -2194,7 +2209,7 @@ myVar2 = 5 myVar3 = 6 myAng = 40 myAng2 = 134 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line([1, 3.82], %, $seg01) // ln-should-get-tag |> angledLineToX([ @@ -2221,7 +2236,7 @@ part001 = startSketchOn('XY') #[test] fn test_recast_after_rename_std() { - let some_program_string = r#"part001 = startSketchOn('XY') + let some_program_string = r#"part001 = startSketchOn(XY) |> startProfileAt([0.0000000000, 5.0000000000], %) |> line([0.4900857016, -0.0240763666], %) @@ -2241,7 +2256,7 @@ fn ghi = (part001) => { let recasted = program.recast(&Default::default(), 0); assert_eq!( recasted, - r#"mySuperCoolPart = startSketchOn('XY') + r#"mySuperCoolPart = startSketchOn(XY) |> startProfileAt([0.0, 5.0], %) |> line([0.4900857016, -0.0240763666], %) @@ -2278,7 +2293,7 @@ fn ghi(part001) { #[test] fn test_recast_trailing_comma() { - let some_program_string = r#"startSketchOn('XY') + let some_program_string = r#"startSketchOn(XY) |> startProfileAt([0, 0], %) |> arc({ radius = 1, @@ -2290,7 +2305,7 @@ fn ghi(part001) { let recasted = program.recast(&Default::default(), 0); assert_eq!( recasted, - r#"startSketchOn('XY') + r#"startSketchOn(XY) |> startProfileAt([0, 0], %) |> arc({ radius = 1, @@ -2307,7 +2322,7 @@ fn ghi(part001) { l = 8 h = 10 -firstExtrude = startSketchOn('XY') +firstExtrude = startSketchOn(XY) |> startProfileAt([0,0], %) |> line([0, l], %) |> line([w, 0], %) @@ -2324,7 +2339,7 @@ firstExtrude = startSketchOn('XY') l = 8 h = 10 -firstExtrude = startSketchOn('XY') +firstExtrude = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line([0, l], %) |> line([w, 0], %) @@ -2344,7 +2359,7 @@ h = 10 // This is my comment // It has multiple lines // And it's really long -firstExtrude = startSketchOn('XY') +firstExtrude = startSketchOn(XY) |> startProfileAt([0,0], %) |> line([0, l], %) |> line([w, 0], %) @@ -2364,7 +2379,7 @@ h = 10 // This is my comment // It has multiple lines // And it's really long -firstExtrude = startSketchOn('XY') +firstExtrude = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line([0, l], %) |> line([w, 0], %) @@ -2389,7 +2404,7 @@ firstExtrude = startSketchOn('XY') let some_program_string = r#"wallMountL = 3.82 thickness = 0.5 -startSketchOn('XY') +startSketchOn(XY) |> startProfileAt([0, 0], %) |> line([0, -(wallMountL - thickness)], %) |> line([0, -(5 - thickness)], %) diff --git a/rust/kcl-lib/tests/angled_line/unparsed.snap b/rust/kcl-lib/tests/angled_line/unparsed.snap index 0ca96a22f..bbd85b2f2 100644 --- a/rust/kcl-lib/tests/angled_line/unparsed.snap +++ b/rust/kcl-lib/tests/angled_line/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing angled_line.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([4.83, 12.56], %) |> line(end = [15.1, 2.48]) |> line(end = [3.15, -9.85], tag = $seg01) 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 11ed2f8b4..6a100aae8 100644 --- a/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap +++ b/rust/kcl-lib/tests/artifact_graph_example_code1/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_example_code1.kcl --- -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> startProfileAt([-5, -5], %) |> line(end = [0, 10]) |> line(end = [10.55, 0], tag = $seg01) 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 aa5165ea1..851b697cb 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_example_code_no_3d.kcl --- -sketch003 = startSketchOn('YZ') +sketch003 = startSketchOn(YZ) |> startProfileAt([5.82, 0], %) |> angledLine([180, 11.54], %, $rectangleSegmentA001) |> angledLine([ @@ -15,7 +15,7 @@ sketch003 = startSketchOn('YZ') ], %, $rectangleSegmentC001) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch004 = startSketchOn('-XZ') +sketch004 = startSketchOn(-XZ) |> startProfileAt([0, 14.36], %) |> line(end = [15.49, 0.05]) |> tangentialArcTo([0, 0], %) 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 3f873bb4e..7601bafda 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 @@ -2,9 +2,9 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_example_code_offset_planes.kcl --- -offsetPlane001 = offsetPlane("XY", offset = 20) -offsetPlane002 = offsetPlane("XZ", offset = -50) -offsetPlane003 = offsetPlane("YZ", offset = 10) +offsetPlane001 = offsetPlane(XY, offset = 20) +offsetPlane002 = offsetPlane(XZ, offset = -50) +offsetPlane003 = offsetPlane(YZ, offset = 10) sketch002 = startSketchOn(offsetPlane001) |> startProfileAt([0, 0], %) 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 09dde98f5..96225d5dc 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing artifact_graph_sketch_on_face_etc.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [4, 8]) |> line(end = [5, -8], tag = $seg01) 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 8cd3c97b2..3e5740699 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 @@ -4,7 +4,7 @@ description: Result of unparsing tests/assembly_mixed_units_cubes/cube-inches.kc --- @settings(defaultLengthUnit = in) -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) cubeIn = startProfileAt([-10, -10], sketch001) |> xLine(length = 5) |> yLine(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 54f504c25..d576d0b69 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 @@ -4,7 +4,7 @@ description: Result of unparsing tests/assembly_mixed_units_cubes/cube-mm.kcl --- @settings(defaultLengthUnit = mm) -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) cubeMm = startProfileAt([10, 10], sketch001) |> xLine(length = 5) |> yLine(length = -5) diff --git a/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other1.kcl.snap b/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other1.kcl.snap index dea808c88..d7973a85f 100644 --- a/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other1.kcl.snap +++ b/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other1.kcl.snap @@ -8,5 +8,5 @@ description: Result of unparsing tests/assembly_non_default_units/other1.kcl import radius from "globals.kcl" // Use the same units as in the main importing file. -startSketchOn('XZ') +startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) diff --git a/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other2.kcl.snap b/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other2.kcl.snap index eaacced1d..59419f580 100644 --- a/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other2.kcl.snap +++ b/rust/kcl-lib/tests/assembly_non_default_units/unparsed@other2.kcl.snap @@ -5,5 +5,5 @@ description: Result of unparsing tests/assembly_non_default_units/other2.kcl @settings(defaultLengthUnit = in) // Use the same units as in the main importing file. -startSketchOn('XZ') +startSketchOn(XZ) |> circle(center = [0, 2], radius = 1) diff --git a/rust/kcl-lib/tests/bad_units_in_annotation/unparsed.snap b/rust/kcl-lib/tests/bad_units_in_annotation/unparsed.snap index 2078debfe..e9551f5ce 100644 --- a/rust/kcl-lib/tests/bad_units_in_annotation/unparsed.snap +++ b/rust/kcl-lib/tests/bad_units_in_annotation/unparsed.snap @@ -15,7 +15,7 @@ bondAngle = 104.5 // Bond angle in degrees // Function to create a sphere representing an atom fn createAtom(center, radius) { - return startSketchOn('XY') + return startSketchOn(XY) |> circle(center = center, radius = radius) |> extrude(length = radius * 2) } 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 db64a8e02..837d8eabb 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_close_opposite.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 1442a822a..7ccce9cf2 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_end/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_end.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 4b6b1a8e0..9ff053f6b 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_next_adjacent.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) 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 510e57e56..46eb82f52 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_previous_adjacent.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0], tag = $thing1) 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 e40b1714c..761d820db 100644 --- a/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap +++ b/rust/kcl-lib/tests/basic_fillet_cube_start/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing basic_fillet_cube_start.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $thing) |> line(end = [10, 0]) 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 index 3a8b5f98a..db783a70a 100644 --- 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing big_number_angle_to_match_length_x.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82], tag = $seg01) |> angledLineToX([-angleToMatchLengthX(seg01, 3, %), 3], %) 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 index efdc2da42..a0b943da3 100644 --- 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing big_number_angle_to_match_length_y.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82], tag = $seg01) |> angledLineToX([-angleToMatchLengthY(seg01, 3, %), 3], %) diff --git a/rust/kcl-lib/tests/circle_three_point/unparsed.snap b/rust/kcl-lib/tests/circle_three_point/unparsed.snap index fc7f2749f..a7eb114c7 100644 --- a/rust/kcl-lib/tests/circle_three_point/unparsed.snap +++ b/rust/kcl-lib/tests/circle_three_point/unparsed.snap @@ -2,6 +2,6 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing circle_three_point.kcl --- -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> circleThreePoint(p1 = [25, 25], p2 = [30, 20], p3 = [27, 15]) |> extrude(length = 10) 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 cb84ef1f7..025ac304f 100644 --- a/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/circular_pattern3d_a_pattern/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing circular_pattern3d_a_pattern.kcl --- -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) diff --git a/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap b/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap index 7dacfb050..c00813ae5 100644 --- a/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap +++ b/rust/kcl-lib/tests/crazy_multi_profile/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing crazy_multi_profile.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([6.71, -3.66], sketch001) |> line(end = [2.65, 9.02], tag = $seg02) |> line(end = [3.73, -9.36], tag = $seg01) @@ -38,7 +38,7 @@ profile006 = startProfileAt([9.65, 3.82], sketch002) |> close() revolve001 = revolve(profile004, angle = 45, axis = getNextAdjacentEdge(seg01)) extrude002 = extrude(profile006, length = 4) -sketch003 = startSketchOn('-XZ') +sketch003 = startSketchOn(-XZ) profile007 = startProfileAt([4.8, 7.55], sketch003) |> line(end = [7.39, 2.58]) |> line(end = [7.02, -2.85]) diff --git a/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap b/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap index a25023d7f..b6a895302 100644 --- a/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap +++ b/rust/kcl-lib/tests/fillet-and-shell/unparsed.snap @@ -45,7 +45,7 @@ miniHdmiHole = startSketchOn(XY) ]) |> close(%) -case = startSketchOn('XY') +case = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [caseWidth, 0], tag = $edge1) |> line(endAbsolute = [caseWidth, caseLength], tag = $edge2) @@ -63,7 +63,7 @@ case = startSketchOn('XY') ) fn m25Screw(x, y, height) { - screw = startSketchOn("XY") + screw = startSketchOn(XY) |> startProfileAt([0, 0], %) |> circle(center = [x, y], radius = 2.5) |> hole(circle(center = [x, y], radius = 1.25), %) diff --git a/rust/kcl-lib/tests/flush_batch_on_end/unparsed.snap b/rust/kcl-lib/tests/flush_batch_on_end/unparsed.snap index b78861884..45b88fe14 100644 --- a/rust/kcl-lib/tests/flush_batch_on_end/unparsed.snap +++ b/rust/kcl-lib/tests/flush_batch_on_end/unparsed.snap @@ -12,7 +12,7 @@ outerDiameter = 35 / 64 length = 1 + 1 / 2 // create a sketch on the 'XY' plane -sketch000 = startSketchOn('XY') +sketch000 = startSketchOn(XY) // create a profile of the outside of the pipe outerProfile = circle( diff --git a/rust/kcl-lib/tests/function_sketch/unparsed.snap b/rust/kcl-lib/tests/function_sketch/unparsed.snap index 33e1805e9..772c58ea0 100644 --- a/rust/kcl-lib/tests/function_sketch/unparsed.snap +++ b/rust/kcl-lib/tests/function_sketch/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing function_sketch.kcl --- fn box(h, l, w) { - myBox = startSketchOn('XY') + myBox = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, l]) |> line(end = [w, 0]) 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 b27bd14e7..7642a5451 100644 --- a/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap +++ b/rust/kcl-lib/tests/function_sketch_with_position/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing function_sketch_with_position.kcl --- fn box(p, h, l, w) { - myBox = startSketchOn('XY') + myBox = startSketchOn(XY) |> startProfileAt(p, %) |> line(end = [0, l]) |> line(end = [w, 0]) diff --git a/rust/kcl-lib/tests/helix_ccw/unparsed.snap b/rust/kcl-lib/tests/helix_ccw/unparsed.snap index 2f73f721b..ce0409af7 100644 --- a/rust/kcl-lib/tests/helix_ccw/unparsed.snap +++ b/rust/kcl-lib/tests/helix_ccw/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing helix_ccw.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> circle(center = [5, 5], radius = 10) |> extrude(length = 10) |> helixRevolutions({ diff --git a/rust/kcl-lib/tests/helix_simple/unparsed.snap b/rust/kcl-lib/tests/helix_simple/unparsed.snap index 1d9ffe2a5..4a86b68ff 100644 --- a/rust/kcl-lib/tests/helix_simple/unparsed.snap +++ b/rust/kcl-lib/tests/helix_simple/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing helix_simple.kcl --- // Create a helix around an edge. -helper001 = startSketchOn('XZ') +helper001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 10], tag = $edge001) 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 b8581c544..fc9ae5c5c 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 @@ -4,7 +4,7 @@ description: Result of unparsing tests/import_function_not_sketch/my_functions.k --- @settings(defaultLengthUnit = mm) -export part001 = startSketchOn('XY') +export part001 = startSketchOn(XY) |> startProfileAt([4, 12], %) |> line(end = [2, 0]) |> line(end = [0, -6]) diff --git a/rust/kcl-lib/tests/import_side_effect/unparsed@export_side_effect.kcl.snap b/rust/kcl-lib/tests/import_side_effect/unparsed@export_side_effect.kcl.snap index b9ccb5bd6..093382e43 100644 --- a/rust/kcl-lib/tests/import_side_effect/unparsed@export_side_effect.kcl.snap +++ b/rust/kcl-lib/tests/import_side_effect/unparsed@export_side_effect.kcl.snap @@ -7,5 +7,5 @@ export fn foo() { } // This interacts with the engine. -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> circle(center = [0, 0], radius = 10) diff --git a/rust/kcl-lib/tests/import_whole/unparsed@exported_mod.kcl.snap b/rust/kcl-lib/tests/import_whole/unparsed@exported_mod.kcl.snap index d0d0fcc2a..8e932bef1 100644 --- a/rust/kcl-lib/tests/import_whole/unparsed@exported_mod.kcl.snap +++ b/rust/kcl-lib/tests/import_whole/unparsed@exported_mod.kcl.snap @@ -4,6 +4,6 @@ description: Result of unparsing tests/import_whole/exported_mod.kcl --- @settings(defaultLengthUnit = inch) -startSketchOn('XY') +startSketchOn(XY) |> circle(center = [5, 5], radius = 10) |> extrude(length = 10) diff --git a/rust/kcl-lib/tests/kittycad_svg/unparsed.snap b/rust/kcl-lib/tests/kittycad_svg/unparsed.snap index 7dfd82caf..3c95b0300 100644 --- a/rust/kcl-lib/tests/kittycad_svg/unparsed.snap +++ b/rust/kcl-lib/tests/kittycad_svg/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing kittycad_svg.kcl --- -svg = startSketchOn('XY') +svg = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [2.52, -26.04]) // MoveAbsolute |> line(endAbsolute = [2.52, -25.2]) // VerticalLineAbsolute 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 ecc867003..0338a53db 100644 --- a/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/linear_pattern3d_a_pattern/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing linear_pattern3d_a_pattern.kcl --- -exampleSketch = startSketchOn('XZ') +exampleSketch = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [0, 2]) |> line(end = [3, 1]) diff --git a/rust/kcl-lib/tests/mike_stress_test/unparsed.snap b/rust/kcl-lib/tests/mike_stress_test/unparsed.snap index c404e6e6d..88ce32802 100644 --- a/rust/kcl-lib/tests/mike_stress_test/unparsed.snap +++ b/rust/kcl-lib/tests/mike_stress_test/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing mike_stress_test.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0.0, 0.0], %) |> line(end = [ -0.3670208139314082, diff --git a/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap b/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap index 846d62b5e..32c698dba 100644 --- a/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap +++ b/rust/kcl-lib/tests/neg_xz_plane/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing neg_xz_plane.kcl --- -part001 = startSketchOn('-XZ') +part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) 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 e5876a622..d791c0954 100644 --- a/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap +++ b/rust/kcl-lib/tests/out_of_band_sketches/unparsed.snap @@ -2,13 +2,13 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing out_of_band_sketches.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) profile001 = startProfileAt([27.67, 239.34], sketch001) // 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') +sketch002 = startSketchOn(XY) profile002 = startProfileAt([67.04, -63.5], sketch002) // enter sketch mode, start path, move path pen, disable sketch mode |> line(end = [282.37, 0]) // extend path diff --git a/rust/kcl-lib/tests/parametric/unparsed.snap b/rust/kcl-lib/tests/parametric/unparsed.snap index 88ddcccd9..e31e84fe4 100644 --- a/rust/kcl-lib/tests/parametric/unparsed.snap +++ b/rust/kcl-lib/tests/parametric/unparsed.snap @@ -11,7 +11,7 @@ FOS = 2 leg1 = 5 // inches leg2 = 8 // inches thickness = sqrt(distance * p * FOS * 6 / sigmaAllow / width) // inches -bracket = startSketchOn('XY') +bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, leg1]) |> line(end = [leg2, 0]) diff --git a/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap b/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap index 398536b55..aa45e4c96 100644 --- a/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap +++ b/rust/kcl-lib/tests/pentagon_fillet_sugar/unparsed.snap @@ -12,7 +12,7 @@ circ = { } triangleLen = 500 -p = startSketchOn('XY') +p = startSketchOn(XY) |> startProfileAt([0, 0], %) |> angledLine({ angle = 60, length = triangleLen }, %, $a) |> angledLine({ angle = 180, length = triangleLen }, %, $b) diff --git a/rust/kcl-lib/tests/poop_chute/unparsed.snap b/rust/kcl-lib/tests/poop_chute/unparsed.snap index b3b37dac3..2f0de61d3 100644 --- a/rust/kcl-lib/tests/poop_chute/unparsed.snap +++ b/rust/kcl-lib/tests/poop_chute/unparsed.snap @@ -13,7 +13,7 @@ front_length = 6 Fx = 0.5 Fy = 0.5 -sketch001 = startSketchOn('-YZ') +sketch001 = startSketchOn(-YZ) |> startProfileAt([back_walls_width / 2, 0], %) |> xLine(length = wall_thickness / 2) |> angledLineToX({ angle = 45, to = back_walls_width }, %, $seg01) @@ -45,7 +45,7 @@ part001 = revolve( }, ) -sketch002 = startSketchOn('-YZ') +sketch002 = startSketchOn(-YZ) |> startProfileAt([back_walls_width / 2, 0], %) |> xLine(length = wall_thickness / 2) |> angledLineToX({ angle = 45, to = back_walls_width }, %, $seg02) diff --git a/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap b/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap index 4faff93e6..f369a36b6 100644 --- a/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap +++ b/rust/kcl-lib/tests/revolve_about_edge/unparsed.snap @@ -2,9 +2,9 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing revolve_about_edge.kcl --- -sketch001 = startSketchOn('XY') +sketch001 = startSketchOn(XY) |> startProfileAt([-25, 25], %) |> yLine(length = -50, tag = $rectangleSegmentB001) -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) |> circle(center = [-50, 0], radius = 10) |> revolve(angle = 90, axis = rectangleSegmentB001) diff --git a/rust/kcl-lib/tests/riddle_small/unparsed.snap b/rust/kcl-lib/tests/riddle_small/unparsed.snap index 48d59e390..1b71ac92c 100644 --- a/rust/kcl-lib/tests/riddle_small/unparsed.snap +++ b/rust/kcl-lib/tests/riddle_small/unparsed.snap @@ -12,7 +12,7 @@ xs = 205804 ys = 71816 ox = 35 - (t(xs) % 70) oy = 35 - (t(ys) % 70) -r = startSketchOn('XZ') +r = startSketchOn(XZ) |> startProfileAt([ox, oy], %) |> line(end = [1, 0]) |> line(end = [0, -1]) diff --git a/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap b/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap index 9ce59bb10..95ee065b1 100644 --- a/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/rotate_after_fillet/unparsed.snap @@ -12,7 +12,7 @@ export boltThreadLength = 1.75 export fn bolt() { // Create the head of the cap screw - boltHead = startSketchOn('XZ') + boltHead = startSketchOn(XZ) |> circle(center = [0, 0], radius = boltHeadDiameter / 2, tag = $topEdge) |> extrude(length = -boltHeadLength) |> fillet(radius = 0.020, tags = [topEdge, getOppositeEdge(topEdge)]) diff --git a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap index f17594b02..c2e54902a 100644 --- a/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/scale_after_fillet/unparsed.snap @@ -12,7 +12,7 @@ export boltThreadLength = 1.75 export fn bolt() { // Create the head of the cap screw - boltHead = startSketchOn('XZ') + boltHead = startSketchOn(XZ) |> circle(center = [0, 0], radius = boltHeadDiameter / 2, tag = $topEdge) |> extrude(length = -boltHeadLength) |> fillet(radius = 0.020, tags = [topEdge, getOppositeEdge(topEdge)]) 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 f40748cd5..5180e23e8 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch-on-chamfer-two-times-different-order.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ 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 e4ad1e79c..5d89888de 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 @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch-on-chamfer-two-times.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ diff --git a/rust/kcl-lib/tests/sketch_in_object/unparsed.snap b/rust/kcl-lib/tests/sketch_in_object/unparsed.snap index ad5a5296a..655d1a771 100644 --- a/rust/kcl-lib/tests/sketch_in_object/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_in_object/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_in_object.kcl --- fn test() { - return startSketchOn('XY') + return startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 1]) |> line(end = [1, 0]) @@ -14,7 +14,7 @@ fn test() { fn test2() { return { thing1 = { - thing2 = startSketchOn('XY') + thing2 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, 1]) |> line(end = [1, 0]) diff --git a/rust/kcl-lib/tests/sketch_on_face/unparsed.snap b/rust/kcl-lib/tests/sketch_on_face/unparsed.snap index fffb67ee7..7e33de2b2 100644 --- a/rust/kcl-lib/tests/sketch_on_face/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face.kcl --- -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([11.19, 28.35], %) |> line(end = [28.67, -13.25], tag = $here) |> line(end = [-4.12, -22.81]) 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 cbd6e6d04..ab9101f90 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 @@ -26,7 +26,7 @@ thickness = sqrt(6 * M * FOS / (width * sigmaAllow)) filletR = 0.25 // Sketch the bracket and extrude with fillets -bracket = startSketchOn('XY') +bracket = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0, wallMountL], tag = $outerEdge) |> line(end = [-shelfMountL, 0], tag = $seg01) 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 97b3eb046..681d35e42 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 @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face_circle_tagged.kcl --- fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 8bb90bff8..d5f655826 100644 --- a/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_end/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face_end.kcl --- fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 717a9e502..c92c89d30 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 @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face_end_negative_extrude.kcl --- fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) 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 3176dad81..c08390a4f 100644 --- a/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap +++ b/rust/kcl-lib/tests/sketch_on_face_start/unparsed.snap @@ -3,7 +3,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing sketch_on_face_start.kcl --- fn cube(pos, scale) { - sg = startSketchOn('XY') + sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) diff --git a/rust/kcl-lib/tests/ssi_pattern/unparsed.snap b/rust/kcl-lib/tests/ssi_pattern/unparsed.snap index 3d50f5dbf..e3384349a 100644 --- a/rust/kcl-lib/tests/ssi_pattern/unparsed.snap +++ b/rust/kcl-lib/tests/ssi_pattern/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing ssi_pattern.kcl --- -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([-4.35, -12.26], %) |> yLine(length = 10.2) |> line(end = [0.54, -0.03]) 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 86ad1f00a..201586091 100644 --- a/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap +++ b/rust/kcl-lib/tests/tan_arc_x_line/unparsed.snap @@ -8,7 +8,7 @@ angleOffset = 135 r = 1 angleStart = 110 -startSketchOn('XY') +startSketchOn(XY) |> startProfileAt([startX, startY], %) |> angledLine({ angle = angleStart, length = .000001 }, %) |> tangentialArc({ offset = angleOffset, radius = r }, %, $arc1) diff --git a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap index c0698897e..54648c487 100644 --- a/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap +++ b/rust/kcl-lib/tests/translate_after_fillet/unparsed.snap @@ -12,7 +12,7 @@ export boltThreadLength = 1.75 export fn bolt() { // Create the head of the cap screw - boltHead = startSketchOn('XZ') + boltHead = startSketchOn(XZ) |> circle(center = [0, 0], radius = boltHeadDiameter / 2, tag = $topEdge) |> extrude(length = -boltHeadLength) |> fillet(radius = 0.020, tags = [topEdge, getOppositeEdge(topEdge)]) diff --git a/rust/kcl-lib/tests/xz_plane/unparsed.snap b/rust/kcl-lib/tests/xz_plane/unparsed.snap index 185034dfe..75fa6fa24 100644 --- a/rust/kcl-lib/tests/xz_plane/unparsed.snap +++ b/rust/kcl-lib/tests/xz_plane/unparsed.snap @@ -2,7 +2,7 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing xz_plane.kcl --- -part001 = startSketchOn('XZ') +part001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(endAbsolute = [100, 100]) |> line(endAbsolute = [100, 0]) diff --git a/src/Toolbar.tsx b/src/Toolbar.tsx index 824e9c245..280993300 100644 --- a/src/Toolbar.tsx +++ b/src/Toolbar.tsx @@ -392,7 +392,8 @@ const ToolbarItemTooltip = memo(function ToolbarItemContents({ inert={false} wrapperStyle={ isDesktop() - ? ({ '-webkit-app-region': 'no-drag' } as React.CSSProperties) + ? // Without this, the tooltip disappears before being able to click on anything in it + ({ WebkitAppRegion: 'no-drag' } as React.CSSProperties) : {} } hoverOnly diff --git a/src/clientSideScene/sceneEntities.ts b/src/clientSideScene/sceneEntities.ts index ec68f01e0..9b25013aa 100644 --- a/src/clientSideScene/sceneEntities.ts +++ b/src/clientSideScene/sceneEntities.ts @@ -12,7 +12,6 @@ import { PlaneGeometry, Points, Quaternion, - Scene, Vector2, Vector3, Shape, @@ -189,19 +188,17 @@ type Vec3Array = [number, number, number] // That mostly mean sketch elements. // Cameras, controls, raycasters, etc are handled by sceneInfra export class SceneEntities { - engineCommandManager: EngineCommandManager - scene: Scene + readonly engineCommandManager: EngineCommandManager activeSegments: { [key: string]: Group } = {} - intersectionPlane: Mesh | null = null + readonly intersectionPlane: Mesh axisGroup: Group | null = null draftPointGroups: Group[] = [] currentSketchQuaternion: Quaternion | null = null constructor(engineCommandManager: EngineCommandManager) { this.engineCommandManager = engineCommandManager - this.scene = sceneInfra?.scene - sceneInfra?.camControls.subscribeToCamChange(this.onCamChange) + this.intersectionPlane = SceneEntities.createIntersectionPlane() + sceneInfra.camControls.subscribeToCamChange(this.onCamChange) window.addEventListener('resize', this.onWindowResize) - this.createIntersectionPlane() } onWindowResize = () => { @@ -328,11 +325,7 @@ export class SceneEntities { sceneInfra.overlayCallbacks(callbacks) } - createIntersectionPlane() { - if (sceneInfra.scene.getObjectByName(RAYCASTABLE_PLANE)) { - console.warn('createIntersectionPlane called when it already exists') - return - } + private static createIntersectionPlane() { const hundredM = 100_0000 const planeGeometry = new PlaneGeometry(hundredM, hundredM) const planeMaterial = new MeshBasicMaterial({ @@ -341,11 +334,12 @@ export class SceneEntities { transparent: true, opacity: 0.5, }) - this.intersectionPlane = new Mesh(planeGeometry, planeMaterial) - this.intersectionPlane.userData = { type: RAYCASTABLE_PLANE } - this.intersectionPlane.name = RAYCASTABLE_PLANE - this.intersectionPlane.layers.set(INTERSECTION_PLANE_LAYER) - this.scene.add(this.intersectionPlane) + const intersectionPlane = new Mesh(planeGeometry, planeMaterial) + intersectionPlane.userData = { type: RAYCASTABLE_PLANE } + intersectionPlane.name = RAYCASTABLE_PLANE + intersectionPlane.layers.set(INTERSECTION_PLANE_LAYER) + sceneInfra.scene.add(intersectionPlane) + return intersectionPlane } createSketchAxis( sketchPathToNode: PathToNode, @@ -424,10 +418,10 @@ export class SceneEntities { ) this.axisGroup.setRotationFromQuaternion(quat) sketchPosition && this.axisGroup.position.set(...sketchPosition) - this.scene.add(this.axisGroup) + sceneInfra.scene.add(this.axisGroup) } getDraftPoint() { - return this.scene.getObjectByName(DRAFT_POINT) + return sceneInfra.scene.getObjectByName(DRAFT_POINT) } createDraftPoint({ point, @@ -453,7 +447,7 @@ export class SceneEntities { new Vector3(...zAxis) ) draftPointGroup.setRotationFromQuaternion(currentSketchQuaternion) - this.scene.add(draftPointGroup) + sceneInfra.scene.add(draftPointGroup) const dummy = new Mesh() dummy.position.set(0, 0, 0) const scale = sceneInfra.getClientSceneScaleFactor(dummy) @@ -505,8 +499,8 @@ export class SceneEntities { ) // Position the click raycast plane - this.intersectionPlane!.setRotationFromQuaternion(quaternion) - this.intersectionPlane!.position.copy( + this.intersectionPlane.setRotationFromQuaternion(quaternion) + this.intersectionPlane.position.copy( new Vector3(...(sketchDetails?.origin || [0, 0, 0])) ) sceneInfra.setCallbacks({ @@ -658,8 +652,6 @@ export class SceneEntities { truncatedAst: Node variableDeclarationName: string }> { - this.createIntersectionPlane() - const prepared = this.prepareTruncatedAst(sketchNodePaths, maybeModdedAst) if (err(prepared)) return Promise.reject(prepared) const { truncatedAst, variableDeclarationName } = prepared @@ -847,14 +839,11 @@ export class SceneEntities { new Vector3(...forward) ) group.setRotationFromQuaternion(this.currentSketchQuaternion) - this.intersectionPlane && - this.intersectionPlane.setRotationFromQuaternion( - this.currentSketchQuaternion - ) - this.intersectionPlane && - position && - this.intersectionPlane.position.set(...position) - this.scene.add(group) + this.intersectionPlane.setRotationFromQuaternion( + this.currentSketchQuaternion + ) + position && this.intersectionPlane.position.set(...position) + sceneInfra.scene.add(group) sceneInfra.camControls.enableRotate = false sceneInfra.overlayCallbacks(callbacks) @@ -3059,18 +3048,18 @@ export class SceneEntities { }) } removeSketchGrid() { - if (this.axisGroup) this.scene.remove(this.axisGroup) + if (this.axisGroup) sceneInfra.scene.remove(this.axisGroup) } tearDownSketch({ removeAxis = true }: { removeAxis?: boolean }) { // Remove all draft groups this.draftPointGroups.forEach((draftPointGroup) => { - this.scene.remove(draftPointGroup) + sceneInfra.scene.remove(draftPointGroup) }) // Remove all sketch tools - if (this.axisGroup && removeAxis) this.scene.remove(this.axisGroup) - const sketchSegments = this.scene.children.find( + if (this.axisGroup && removeAxis) sceneInfra.scene.remove(this.axisGroup) + const sketchSegments = sceneInfra.scene.children.find( ({ userData }) => userData?.type === SKETCH_GROUP_SEGMENTS ) if (sketchSegments) { @@ -3082,7 +3071,7 @@ export class SceneEntities { object.remove() } }) - this.scene.remove(sketchSegments) + sceneInfra.scene.remove(sketchSegments) } sceneInfra.camControls.enableRotate = true this.activeSegments = {} diff --git a/src/clientSideScene/sceneInfra.ts b/src/clientSideScene/sceneInfra.ts index 04347ca2b..13b2643c8 100644 --- a/src/clientSideScene/sceneInfra.ts +++ b/src/clientSideScene/sceneInfra.ts @@ -110,18 +110,16 @@ interface OnMoveCallbackArgs { type Voidish = void | Promise export class SceneInfra { static instance: SceneInfra - scene: Scene - renderer: WebGLRenderer - labelRenderer: CSS2DRenderer - camControls: CameraControls - isPerspective = true - fov = 45 - fovBeforeAnimate = 45 + readonly scene: Scene + readonly renderer: WebGLRenderer + readonly labelRenderer: CSS2DRenderer + readonly camControls: CameraControls + private readonly fov = 45 isFovAnimationInProgress = false _baseUnit: BaseUnit = 'mm' _baseUnitMultiplier = 1 _theme: Themes = Themes.System - extraSegmentTexture: Texture + readonly extraSegmentTexture: Texture lastMouseState: MouseState = { type: 'idle' } onDragStartCallback: (arg: OnDragCallbackArgs) => Voidish = () => {} onDragEndCallback: (arg: OnDragCallbackArgs) => Voidish = () => {} diff --git a/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx b/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx index 9709b709d..1e598ad60 100644 --- a/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx +++ b/src/components/ModelingSidebar/ModelingPanes/MemoryPane.test.tsx @@ -16,13 +16,13 @@ describe('processMemory', () => { } otherVar = myFn(5) - theExtrude = startSketchOn('XY') + theExtrude = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-2.4, myVar]) |> line(endAbsolute = [-0.76, otherVar]) |> extrude(length = 4) - theSketch = startSketchOn('XY') + theSketch = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-3.35, 0.17]) |> line(endAbsolute = [0.98, 5.16]) diff --git a/src/hooks/useSetupEngineManager.ts b/src/hooks/useSetupEngineManager.ts index b1e6ae0b0..5092bc8bf 100644 --- a/src/hooks/useSetupEngineManager.ts +++ b/src/hooks/useSetupEngineManager.ts @@ -93,7 +93,12 @@ export function useSetupEngineManager( engineCommandManager.settings = settings const handleResize = deferExecution(() => { - engineCommandManager.handleResize(engineCommandManager.streamDimensions) + engineCommandManager.handleResize( + getDimensions( + streamRef?.current?.offsetWidth ?? 0, + streamRef?.current?.offsetHeight ?? 0 + ) + ) }, 500) const onOnline = () => { diff --git a/src/lang/KclSingleton.ts b/src/lang/KclSingleton.ts index 1f4d91ff3..b2fe7b99b 100644 --- a/src/lang/KclSingleton.ts +++ b/src/lang/KclSingleton.ts @@ -78,7 +78,7 @@ export class KclManager { private _isExecuting = false private _executeIsStale: ExecuteArgs | null = null private _wasmInitFailed = true - private _hasErrors = false + private _astParseFailed = false private _switchedFiles = false private _fileSettings: KclSettingsAnnotation = {} private _kclVersion: string | undefined = undefined @@ -167,7 +167,7 @@ export class KclManager { } hasErrors(): boolean { - return this._hasErrors + return this._astParseFailed || this._errors.length > 0 } setDiagnosticsForCurrentErrors() { @@ -278,7 +278,7 @@ export class KclManager { private async checkIfSwitchedFilesShouldClear() { // If we were switching files and we hit an error on parse we need to bust // the cache and clear the scene. - if (this._hasErrors && this._switchedFiles) { + if (this._astParseFailed && this._switchedFiles) { await rustContext.clearSceneAndBustCache( { settings: await jsAppSettings() }, codeManager.currentFilePath || undefined @@ -292,12 +292,12 @@ export class KclManager { async safeParse(code: string): Promise | null> { const result = parse(code) this.diagnostics = [] - this._hasErrors = false + this._astParseFailed = false if (err(result)) { const kclerror: KCLError = result as KCLError this.diagnostics = kclErrorsToDiagnostics([kclerror]) - this._hasErrors = true + this._astParseFailed = true await this.checkIfSwitchedFilesShouldClear() return null @@ -313,7 +313,7 @@ export class KclManager { this.addDiagnostics(complilationErrorsToDiagnostics(result.errors)) this.addDiagnostics(complilationErrorsToDiagnostics(result.warnings)) if (result.errors.length > 0) { - this._hasErrors = true + this._astParseFailed = true await this.checkIfSwitchedFilesShouldClear() return null diff --git a/src/lang/artifact.test.ts b/src/lang/artifact.test.ts index 868bc983f..3ac0a67af 100644 --- a/src/lang/artifact.test.ts +++ b/src/lang/artifact.test.ts @@ -9,7 +9,7 @@ describe('testing artifacts', () => { // Enable rotations #152 test('sketch artifacts', async () => { const code = ` -const mySketch001 = startSketchOn('XY') +const mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) @@ -67,7 +67,7 @@ const mySketch001 = startSketchOn('XY') test('extrude artifacts', async () => { // Enable rotations #152 const code = ` -const mySketch001 = startSketchOn('XY') +const mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-1.59, -1.54]) |> line(endAbsolute = [0.46, -5.82]) @@ -145,7 +145,7 @@ const mySketch001 = startSketchOn('XY') // Enable rotations #152 // 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') +const sk1 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-2.5, 0]) |> line(endAbsolute = [0, 10], tag = $p) @@ -155,7 +155,7 @@ const sk1 = startSketchOn('XY') // |> ry(5, %) const theExtrude = extrude(sk1, length = 2) // const theTransf = getExtrudeWallTransform('p', theExtrude) -const sk2 = startSketchOn('XY') +const sk2 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [-2.5, 0]) |> line(endAbsolute = [0, 3], tag = $o) @@ -187,8 +187,8 @@ const sk2 = startSketchOn('XY') type: 'extrudePlane', faceId: expect.any(String), tag: { - end: 140, - start: 138, + end: 138, + start: 136, commentStart: expect.any(Number), type: 'TagDeclarator', value: 'p', diff --git a/src/lang/executor.test.ts b/src/lang/executor.test.ts index b1283c5a7..1ca8e7c8c 100644 --- a/src/lang/executor.test.ts +++ b/src/lang/executor.test.ts @@ -50,7 +50,7 @@ const newVar = myVar + 1` expect(mem['magicNum']?.value).toBe(69) }) it('sketch declaration', async () => { - let code = `const mySketch = startSketchOn('XY') + let code = `const mySketch = startSketchOn(XY) |> startProfileAt([0,0], %) |> line(endAbsolute = [0,2], tag = $myPath) |> line(endAbsolute = [2,3]) @@ -77,8 +77,8 @@ const newVar = myVar + 1` id: expect.any(String), }, tag: { - end: 111, - start: 104, + end: 109, + start: 102, commentStart: expect.any(Number), type: 'TagDeclarator', value: 'myPath', @@ -105,8 +105,8 @@ const newVar = myVar + 1` id: expect.any(String), }, tag: { - end: 192, - start: 182, + end: 190, + start: 180, commentStart: expect.any(Number), type: 'TagDeclarator', value: 'rightPath', @@ -153,7 +153,7 @@ const newVar = myVar + 1` it('execute pipe sketch into call expression', async () => { // Enable rotations #152 const code = [ - "const mySk1 = startSketchOn('XY')", + 'const mySk1 = startSketchOn(XY)', ' |> startProfileAt([0,0], %)', ' |> line(endAbsolute = [1,1])', ' |> line(endAbsolute = [0, 1], tag = $myPath)', @@ -204,8 +204,8 @@ const newVar = myVar + 1` id: expect.any(String), }, tag: { - end: 140, - start: 133, + end: 138, + start: 131, commentStart: expect.any(Number), type: 'TagDeclarator', value: 'myPath', @@ -400,7 +400,7 @@ describe('testing math operators', () => { }) it('with unaryExpression in ArrayExpression in CallExpression, checking nothing funny happens when used in a sketch', async () => { const code = [ - "const part001 = startSketchOn('XY')", + 'const part001 = startSketchOn(XY)', ' |> startProfileAt([0, 0], %)', '|> line(end = [-2.21, -legLen(5, min(3, 999))])', ].join('\n') @@ -413,7 +413,7 @@ describe('testing math operators', () => { it('test that % substitution feeds down CallExp->ArrExp->UnaryExp->CallExp', async () => { const code = [ `const myVar = 3`, - `const part001 = startSketchOn('XY')`, + `const part001 = startSketchOn(XY)`, ` |> startProfileAt([0, 0], %)`, ` |> line(end = [3, 4], tag = $seg01)`, ` |> line(end = [`, @@ -455,7 +455,7 @@ describe('testing math operators', () => { describe('Testing Errors', () => { it('should throw an error when a variable is not defined', async () => { const code = `const myVar = 5 -const theExtrude = startSketchOn('XY') +const theExtrude = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [-2.4, 5]) |> line(end = myVarZ) diff --git a/src/lang/getNodePathFromSourceRange.test.ts b/src/lang/getNodePathFromSourceRange.test.ts index b985e527e..82374e14b 100644 --- a/src/lang/getNodePathFromSourceRange.test.ts +++ b/src/lang/getNodePathFromSourceRange.test.ts @@ -17,7 +17,7 @@ describe('testing getNodePathFromSourceRange', () => { it('test it gets the right path for a `lineTo` CallExpression within a SketchExpression', () => { const code = ` const myVar = 5 -const sk3 = startSketchOn('XY') +const sk3 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 2]) |> line(endAbsolute = [3, 4], tag = $yo) @@ -41,7 +41,7 @@ const sk3 = startSketchOn('XY') }) it('gets path right for function definition params', () => { const code = `fn cube = (pos, scale) => { - const sg = startSketchOn('XY') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) @@ -74,7 +74,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') + const sg = startSketchOn(XY) |> startProfileAt(pos, %) |> line(end = [0, scale]) |> line(end = [scale, 0]) diff --git a/src/lang/modifyAst.test.ts b/src/lang/modifyAst.test.ts index d302e2068..d53184227 100644 --- a/src/lang/modifyAst.test.ts +++ b/src/lang/modifyAst.test.ts @@ -243,7 +243,7 @@ describe('Testing addSketchTo', () => { 'yz' ) const str = recast(result.modifiedAst) - expect(str).toBe(`sketch001 = startSketchOn('YZ') + expect(str).toBe(`sketch001 = startSketchOn(YZ) |> startProfileAt('default', %) |> line(end = 'default') `) @@ -269,7 +269,7 @@ function giveSketchFnCallTagTestHelper( } describe('Testing giveSketchFnCallTag', () => { - const code = `part001 = startSketchOn('XY') + const code = `part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [-2.57, -0.13]) |> line(end = [0, 0.83]) @@ -321,7 +321,7 @@ fn ghi = (x) => { const abc = 3 const identifierGuy = 5 yo = 5 + 6 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-1.2, 4.83], %) |> line(end = [2.8, 0]) |> angledLine([100 + 100, 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') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) @@ -434,7 +434,7 @@ describe('testing sketchOnExtrudedFace', () => { const { modifiedAst } = extruded const newCode = recast(modifiedAst) - expect(newCode).toContain(`part001 = startSketchOn('-XZ') + expect(newCode).toContain(`part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19], tag = $seg01) |> line(end = [8.62, -9.57]) @@ -443,7 +443,7 @@ describe('testing sketchOnExtrudedFace', () => { sketch001 = startSketchOn(part001, seg01)`) }) test('it should be able to extrude on close segments', async () => { - const code = `part001 = startSketchOn('-XZ') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) @@ -472,7 +472,7 @@ sketch001 = startSketchOn(part001, seg01)`) const { modifiedAst } = extruded const newCode = recast(modifiedAst) - expect(newCode).toContain(`part001 = startSketchOn('-XZ') + expect(newCode).toContain(`part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) @@ -481,7 +481,7 @@ sketch001 = startSketchOn(part001, seg01)`) sketch001 = startSketchOn(part001, seg01)`) }) test('it should be able to extrude on start-end caps', async () => { - const code = `part001 = startSketchOn('-XZ') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) @@ -511,7 +511,7 @@ sketch001 = startSketchOn(part001, seg01)`) const { modifiedAst } = extruded const newCode = recast(modifiedAst) - expect(newCode).toContain(`part001 = startSketchOn('-XZ') + expect(newCode).toContain(`part001 = startSketchOn(-XZ) |> startProfileAt([3.58, 2.06], %) |> line(end = [9.7, 9.19]) |> line(end = [8.62, -9.57]) @@ -520,7 +520,7 @@ sketch001 = startSketchOn(part001, seg01)`) sketch001 = startSketchOn(part001, 'END')`) }) test('it should ensure that the new sketch is inserted after the extrude', async () => { - const code = `sketch001 = startSketchOn('-XZ') + const code = `sketch001 = startSketchOn(-XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) @@ -562,7 +562,7 @@ sketch002 = startSketchOn(part001, seg01)`) describe('Testing deleteSegmentFromPipeExpression', () => { it('Should delete a segment withOUT any dependent segments', async () => { - const code = `part001 = startSketchOn('-XZ') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([54.78, -95.91], %) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.85], tag = $a) @@ -584,7 +584,7 @@ describe('Testing deleteSegmentFromPipeExpression', () => { ) if (err(modifiedAst)) throw modifiedAst const newCode = recast(modifiedAst) - expect(newCode).toBe(`part001 = startSketchOn('-XZ') + expect(newCode).toBe(`part001 = startSketchOn(-XZ) |> startProfileAt([54.78, -95.91], %) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.87]) @@ -595,7 +595,7 @@ describe('Testing deleteSegmentFromPipeExpression', () => { line: string, replace1 = '', replace2 = '' - ) => `part001 = startSketchOn('-XZ') + ) => `part001 = startSketchOn(-XZ) |> startProfileAt([54.78, -95.91], %) |> line(end = [306.21, 198.82], tag = $b) ${!replace1 ? ` |> ${line}\n` : ''} |> angledLine([-65, ${ @@ -673,7 +673,7 @@ ${!replace1 ? ` |> ${line}\n` : ''} |> angledLine([-65, ${ describe('Testing removeSingleConstraintInfo', () => { describe('with mostly object notation', () => { - const code = `part001 = startSketchOn('-XZ') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> line(end = [3 + 0, 4 + 0]) |> angledLine({ angle = 3 + 0, length = 3.14 + 0 }, %) @@ -784,7 +784,7 @@ describe('Testing removeSingleConstraintInfo', () => { ) }) describe('with array notation', () => { - const code = `part001 = startSketchOn('-XZ') + const code = `part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> angledLine([3.14 + 0, 3.14 + 0], %) |> angledLineOfXLength([3 + 0, 3.14 + 0], %) @@ -840,7 +840,7 @@ describe('Testing deleteFromSelection', () => { 'basicCase', { codeBefore: `myVar = 5 -sketch003 = startSketchOn('XZ') +sketch003 = startSketchOn(XZ) |> startProfileAt([3.82, 13.6], %) |> line(end = [-2.94, 2.7]) |> line(end = [7.7, 0.16]) @@ -856,7 +856,7 @@ sketch003 = startSketchOn('XZ') // [ // 'delete extrude', // { - // codeBefore: `sketch001 = startSketchOn('XZ') + // codeBefore: `sketch001 = startSketchOn(XZ) // |> startProfileAt([3.29, 7.86], %) // |> line(end = [2.48, 2.44]) // |> line(end = [2.66, 1.17]) @@ -866,7 +866,7 @@ sketch003 = startSketchOn('XZ') // |> line(end = [-17.67, 0.85]) // |> close() // const extrude001 = extrude(sketch001, length = 10)`, - // codeAfter: `sketch001 = startSketchOn('XZ') + // codeAfter: `sketch001 = startSketchOn(XZ) // |> startProfileAt([3.29, 7.86], %) // |> line(end = [2.48, 2.44]) // |> line(end = [2.66, 1.17]) @@ -883,7 +883,7 @@ sketch003 = startSketchOn('XZ') // 'delete extrude with sketch on it', // { // codeBefore: `myVar = 5 - // sketch001 = startSketchOn('XZ') + // sketch001 = startSketchOn(XZ) // |> startProfileAt([4.46, 5.12], %, $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) @@ -904,7 +904,7 @@ sketch003 = startSketchOn('XZ') // |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) // |> close()`, // codeAfter: `myVar = 5 - // sketch001 = startSketchOn('XZ') + // sketch001 = startSketchOn(XZ) // |> startProfileAt([4.46, 5.12], %, $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) @@ -939,7 +939,7 @@ sketch003 = startSketchOn('XZ') // 'delete extrude with sketch on it 2', // { // codeBefore: `myVar = 5 - // sketch001 = startSketchOn('XZ') + // sketch001 = startSketchOn(XZ) // |> startProfileAt([4.46, 5.12], %, $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) @@ -960,7 +960,7 @@ sketch003 = startSketchOn('XZ') // |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) // |> close()`, // codeAfter: `myVar = 5 - // sketch001 = startSketchOn('XZ') + // sketch001 = startSketchOn(XZ) // |> startProfileAt([4.46, 5.12], %, $tag) // |> line(end = [0.08, myVar]) // |> line(end = [13.03, 2.02], tag = $seg01) @@ -1032,7 +1032,7 @@ sketch003 = startSketchOn('XZ') describe('Testing splitPipedProfile', () => { it('should split the pipe expression correctly', () => { - const codeBefore = `part001 = startSketchOn('XZ') + const codeBefore = `part001 = startSketchOn(XZ) |> startProfileAt([1, 2], %) |> line([3, 4], %) |> line([5, 6], %) @@ -1040,7 +1040,7 @@ describe('Testing splitPipedProfile', () => { extrude001 = extrude(5, part001) ` - const expectedCodeAfter = `sketch001 = startSketchOn('XZ') + const expectedCodeAfter = `sketch001 = startSketchOn(XZ) part001 = startProfileAt([1, 2], sketch001) |> line([3, 4], %) |> line([5, 6], %) @@ -1050,7 +1050,7 @@ extrude001 = extrude(5, part001) const ast = assertParse(codeBefore) - const codeOfInterest = `startSketchOn('XZ')` + const codeOfInterest = `startSketchOn(XZ)` const range: [number, number, number] = [ codeBefore.indexOf(codeOfInterest), codeBefore.indexOf(codeOfInterest) + codeOfInterest.length, @@ -1067,7 +1067,7 @@ extrude001 = extrude(5, part001) expect(newCode.trim()).toBe(expectedCodeAfter.trim()) }) it('should return error for already split pipe', () => { - const codeBefore = `sketch001 = startSketchOn('XZ') + const codeBefore = `sketch001 = startSketchOn(XZ) part001 = startProfileAt([1, 2], sketch001) |> line([3, 4], %) |> line([5, 6], %) diff --git a/src/lang/modifyAst.ts b/src/lang/modifyAst.ts index b2bfe06b1..d42a48d7c 100644 --- a/src/lang/modifyAst.ts +++ b/src/lang/modifyAst.ts @@ -515,30 +515,54 @@ export function addShell({ } } -export function addSweep( - node: Node, - profileDeclarator: VariableDeclarator, - pathDeclarator: VariableDeclarator -): { +export function addSweep({ + node, + targetDeclarator, + trajectoryDeclarator, + sectional, + variableName, + insertIndex, +}: { + node: Node + targetDeclarator: VariableDeclarator + trajectoryDeclarator: VariableDeclarator + sectional: boolean + variableName?: string + insertIndex?: number +}): { modifiedAst: Node pathToNode: PathToNode } { const modifiedAst = structuredClone(node) - const name = findUniqueName(node, KCL_DEFAULT_CONSTANT_PREFIXES.SWEEP) - const sweep = createCallExpressionStdLibKw( + const name = + variableName ?? findUniqueName(node, KCL_DEFAULT_CONSTANT_PREFIXES.SWEEP) + const call = createCallExpressionStdLibKw( 'sweep', - createIdentifier(profileDeclarator.id.name), - [createLabeledArg('path', createIdentifier(pathDeclarator.id.name))] + createIdentifier(targetDeclarator.id.name), + [ + createLabeledArg('path', createIdentifier(trajectoryDeclarator.id.name)), + createLabeledArg('sectional', createLiteral(sectional)), + ] ) - const declaration = createVariableDeclaration(name, sweep) - modifiedAst.body.push(declaration) + const variable = createVariableDeclaration(name, call) + const insertAt = + insertIndex !== undefined + ? insertIndex + : modifiedAst.body.length + ? modifiedAst.body.length + : 0 + + modifiedAst.body.length + ? modifiedAst.body.splice(insertAt, 0, variable) + : modifiedAst.body.push(variable) + const argIndex = 0 const pathToNode: PathToNode = [ ['body', ''], - [modifiedAst.body.length - 1, 'index'], + [insertAt, 'index'], ['declaration', 'VariableDeclaration'], ['init', 'VariableDeclarator'], ['arguments', 'CallExpressionKw'], - [0, ARG_INDEX_FIELD], + [argIndex, ARG_INDEX_FIELD], ['arg', LABELED_ARG_FIELD], ] @@ -1943,7 +1967,7 @@ export function updateSketchNodePathsWithInsertIndex({ * * Split the following pipe expression into * ```ts - * part001 = startSketchOn('XZ') + * part001 = startSketchOn(XZ) |> startProfileAt([1, 2], %) |> line([3, 4], %) |> line([5, 6], %) @@ -1952,7 +1976,7 @@ extrude001 = extrude(5, part001) ``` into ```ts -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) part001 = startProfileAt([1, 2], sketch001) |> line([3, 4], %) |> line([5, 6], %) diff --git a/src/lang/modifyAst/addEdgeTreatment.test.ts b/src/lang/modifyAst/addEdgeTreatment.test.ts index 9c1039d44..a4f387c6c 100644 --- a/src/lang/modifyAst/addEdgeTreatment.test.ts +++ b/src/lang/modifyAst/addEdgeTreatment.test.ts @@ -178,7 +178,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -195,7 +195,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -212,21 +212,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-30, 30], %) |> line(end = [15, 0]) |> line(end = [0, -15]) |> line(end = [-15, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) |> startProfileAt([30, 30], %) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch003 = startSketchOn('XY') +sketch003 = startSketchOn(XY) |> startProfileAt([30, -30], %) |> line(end = [25, 0]) |> line(end = [0, -25]) @@ -245,7 +245,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-25, -25], %) |> yLine(length = 50) |> xLine(length = 50) @@ -270,7 +270,7 @@ sketch002 = startSketchOn(sketch001, 'END') ) }) it('should return the correct paths for a (non-piped) extrude based on the other body (face)', async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-25, -25], %) |> yLine(length = 50) |> xLine(length = 50) @@ -295,21 +295,21 @@ extrude002 = extrude(sketch002, length = 30)` ) }) it('should not return any path for missing extrusion', async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-30, 30], %) |> line(end = [15, 0]) |> line(end = [0, -15]) |> line(end = [-15, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) |> startProfileAt([30, 30], %) |> line(end = [20, 0]) |> line(end = [0, -20]) |> line(end = [-20, 0]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() -sketch003 = startSketchOn('XY') +sketch003 = startSketchOn(XY) |> startProfileAt([30, -30], %) |> line(end = [25, 0]) |> line(end = [0, -25]) @@ -455,7 +455,7 @@ Object.values(EdgeTreatmentType).forEach( // run tests describe(`Testing modifyAstCloneWithEdgeTreatmentAndTag with ${edgeTreatmentType}s`, () => { it(`should add a ${edgeTreatmentType} to a specific segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -464,7 +464,7 @@ Object.values(EdgeTreatmentType).forEach( |> close() extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [0, -20])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) @@ -482,7 +482,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} to the sketch pipe`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -491,7 +491,7 @@ extrude001 = extrude(sketch001, length = -15) |> close() |> extrude(length = -15)` const segmentSnippets = ['line(end = [0, -20])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) @@ -509,7 +509,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} to an already tagged segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) @@ -518,7 +518,7 @@ extrude001 = extrude(sketch001, length = -15) |> close() extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [0, -20], tag = $seg01)'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20], tag = $seg01) @@ -536,7 +536,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} with existing tag on other segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -545,7 +545,7 @@ extrude001 = extrude(sketch001, length = -15) |> close() extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [-20, 0])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -563,7 +563,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} with existing fillet on other segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -573,7 +573,7 @@ extrude001 = extrude(sketch001, length = -15) extrude001 = extrude(sketch001, length = -15) |> fillet( radius = 5, tags = [seg01] )` const segmentSnippets = ['line(end = [-20, 0])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -592,7 +592,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} with existing chamfer on other segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -602,7 +602,7 @@ extrude001 = extrude(sketch001, length = -15) extrude001 = extrude(sketch001, length = -15) |> chamfer(length = 5, tags = [seg01])` const segmentSnippets = ['line(end = [-20, 0])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -621,7 +621,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add a ${edgeTreatmentType} to two segments of a single extrusion`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -630,7 +630,7 @@ extrude001 = extrude(sketch001, length = -15) |> close() extrude001 = extrude(sketch001, length = -15)` const segmentSnippets = ['line(end = [20, 0])', 'line(end = [-20, 0])'] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -648,7 +648,7 @@ extrude001 = extrude(sketch001, length = -15) ) }) it(`should add ${edgeTreatmentType}s to two bodies`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -656,7 +656,7 @@ extrude001 = extrude(sketch001, length = -15) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() extrude001 = extrude(sketch001, length = -15) -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) |> startProfileAt([30, 10], %) |> line(end = [15, 0]) |> line(end = [0, -15]) @@ -669,7 +669,7 @@ extrude002 = extrude(sketch002, length = -25)` // <--- body 2 'line(end = [-20, 0])', 'line(end = [0, -15])', ] - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -678,7 +678,7 @@ extrude002 = extrude(sketch002, length = -25)` // <--- body 2 |> close() extrude001 = extrude(sketch001, length = -15) |> ${edgeTreatmentType}(${parameterName} = 3, tags = [seg01, seg02]) -sketch002 = startSketchOn('XY') +sketch002 = startSketchOn(XY) |> startProfileAt([30, 10], %) |> line(end = [15, 0]) |> line(end = [0, -15], tag = $seg03) @@ -699,7 +699,7 @@ extrude002 = extrude(sketch002, length = -25) describe(`Testing deleteEdgeTreatment with ${edgeTreatmentType}s`, () => { // simple cases it(`should delete a piped ${edgeTreatmentType} from a single segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -709,7 +709,7 @@ extrude002 = extrude(sketch002, length = -25) extrude001 = extrude(sketch001, length = -15) |> ${edgeTreatmentType}(${parameterName} = 3, tags = [seg01])` const edgeTreatmentSnippet = `${edgeTreatmentType}(${parameterName} = 3, tags = [seg01])` - const expectedCode = `sketch001 = startSketchOn('XY') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -725,7 +725,7 @@ extrude001 = extrude(sketch001, length = -15)` ) }) it(`should delete a non-piped ${edgeTreatmentType} from a single segment`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -735,7 +735,7 @@ extrude001 = extrude(sketch001, length = -15)` 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') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -752,7 +752,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -762,7 +762,7 @@ extrude001 = extrude(sketch001, length = -15)` 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') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -778,7 +778,7 @@ extrude001 = extrude(sketch001, length = -15)` ) }) it(`should delete a non-piped ${edgeTreatmentType} tagged with getNextAdjacentEdge`, async () => { - const code = `sketch001 = startSketchOn('XY') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -788,7 +788,7 @@ extrude001 = extrude(sketch001, length = -15)` 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') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -805,7 +805,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -818,7 +818,7 @@ extrude001 = extrude(sketch001, length = -15) 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') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -837,7 +837,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') + const code = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -850,7 +850,7 @@ extrude001 = extrude(sketch001, length = -15) 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') + const expectedCode = `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0], tag = $seg01) |> line(end = [0, -20]) @@ -873,7 +873,7 @@ chamfer001 = chamfer(extrude001, length = 5, tags = [getOppositeEdge(seg01)])` ) describe('Testing isTagUsedInEdgeTreatment', () => { - const code = `sketch001 = startSketchOn('XZ') + const code = `sketch001 = startSketchOn(XZ) |> startProfileAt([7.72, 4.13], %) |> line(end = [7.11, 3.48], tag = $seg01) |> line(end = [-3.29, -13.85]) @@ -977,7 +977,7 @@ describe('Testing button states', () => { expect(buttonState).toEqual(expectedState) } const codeWithBody: string = ` - sketch001 = startSketchOn('XY') + sketch001 = startSketchOn(XY) |> startProfileAt([-20, -5], %) |> line(end = [0, 10]) |> line(end = [10, 0]) @@ -987,7 +987,7 @@ describe('Testing button states', () => { extrude001 = extrude(sketch001, length = -10) ` const codeWithoutBodies: string = ` - sketch001 = startSketchOn('XY') + sketch001 = startSketchOn(XY) |> startProfileAt([-20, -5], %) |> line(end = [0, 10]) |> line(end = [10, 0]) diff --git a/src/lang/queryAst.test.ts b/src/lang/queryAst.test.ts index 653bd6d9b..f88a42574 100644 --- a/src/lang/queryAst.test.ts +++ b/src/lang/queryAst.test.ts @@ -46,7 +46,7 @@ halfArmAngle = armAngle / 2 arrExpShouldNotBeIncluded = [1, 2, 3] objExpShouldNotBeIncluded = { a: 1, b: 2, c: 3 } -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> yLine(endAbsolute = 1) |> xLine(length = 3.84) // selection-range-7ish-before-this @@ -77,7 +77,7 @@ variableBelowShouldNotBeIncluded = 3 }) describe('testing argIsNotIdentifier', () => { - const code = `part001 = startSketchOn('XY') + const code = `part001 = startSketchOn(XY) |> startProfileAt([-1.2, 4.83], %) |> line(end = [2.8, 0]) |> angledLine([100 + 100, 3.09], %) @@ -237,7 +237,7 @@ yo2 = hmm([identifierGuy + 5])` }) describe('testing getNodePathFromSourceRange', () => { - const code = `part001 = startSketchOn('XY') + const code = `part001 = startSketchOn(XY) |> startProfileAt([0.39, -0.05], %) |> line(end = [0.94, 2.61]) |> line(end = [-0.21, -1.4])` @@ -381,7 +381,7 @@ describe('testing getNodePathFromSourceRange', () => { describe('testing hasExtrudeSketch', () => { it('find sketch', async () => { const exampleCode = `length001 = 2 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-1.41, 3.46], %) |> line(end = [19.49, 1.16], tag = $seg01) |> angledLine([-35, length001], %) @@ -401,7 +401,7 @@ part001 = startSketchOn('XY') }) it('find solid', async () => { const exampleCode = `length001 = 2 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-1.41, 3.46], %) |> line(end = [19.49, 1.16], tag = $seg01) |> angledLine([-35, length001], %) @@ -437,7 +437,7 @@ part001 = startSketchOn('XY') }) describe('Testing findUsesOfTagInPipe', () => { - const exampleCode = `part001 = startSketchOn('-XZ') + const exampleCode = `part001 = startSketchOn(-XZ) |> startProfileAt([68.12, 156.65], %) |> line(end = [306.21, 198.82]) |> line(end = [306.21, 198.85], tag = $seg01) @@ -476,7 +476,7 @@ describe('Testing findUsesOfTagInPipe', () => { }) describe('Testing hasSketchPipeBeenExtruded', () => { - const exampleCode = `sketch001 = startSketchOn('XZ') + const exampleCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [2.66, 1.17]) @@ -560,7 +560,7 @@ sketch003 = startSketchOn(extrude001, 'END') describe('Testing doesSceneHaveSweepableSketch', () => { it('finds sketch001 pipe to be extruded', async () => { - const exampleCode = `sketch001 = startSketchOn('XZ') + const exampleCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) @@ -579,9 +579,9 @@ sketch002 = startSketchOn(extrude001, $seg01) expect(extrudable).toBeTruthy() }) it('finds sketch001 and sketch002 pipes to be lofted', async () => { - const exampleCode = `sketch001 = startSketchOn('XZ') + const exampleCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) -plane001 = offsetPlane('XZ', offset = 2) +plane001 = offsetPlane(XZ, offset = 2) sketch002 = startSketchOn(plane001) |> circle(center = [0, 0], radius = 3) ` @@ -590,7 +590,7 @@ sketch002 = startSketchOn(plane001) expect(extrudable).toBeTruthy() }) it('should recognize that sketch001 has been extruded', async () => { - const exampleCode = `sketch001 = startSketchOn('XZ') + const exampleCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) @@ -606,7 +606,7 @@ extrude001 = extrude(sketch001, length = 10) describe('Testing doesSceneHaveExtrudedSketch', () => { it('finds extruded sketch as variable', async () => { - const exampleCode = `sketch001 = startSketchOn('XZ') + const exampleCode = `sketch001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) extrude001 = extrude(sketch001, length = 1) ` @@ -616,7 +616,7 @@ extrude001 = extrude(sketch001, length = 1) expect(extrudable).toBeTruthy() }) it('finds extruded sketch in pipe', async () => { - const exampleCode = `extrude001 = startSketchOn('XZ') + const exampleCode = `extrude001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) |> extrude(length = 1) ` @@ -626,7 +626,7 @@ extrude001 = extrude(sketch001, length = 1) expect(extrudable).toBeTruthy() }) it('finds no extrusion with sketch only', async () => { - const exampleCode = `extrude001 = startSketchOn('XZ') + const exampleCode = `extrude001 = startSketchOn(XZ) |> circle(center = [0, 0], radius = 1) ` const ast = assertParse(exampleCode) @@ -645,7 +645,7 @@ describe('Testing traverse and pathToNode', () => { ], ])('testing %s', async (testName, literalOfInterest) => { const code = `myVar = 5 -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([3.29, 7.86], %) |> line(end = [2.48, 2.44]) |> line(end = [-3.86, -2.73]) @@ -687,7 +687,7 @@ myNestedVar = [ describe('Testing specific sketch getNodeFromPath workflow', () => { it('should parse the code', () => { - const openSketch = `sketch001 = startSketchOn('XZ') + const openSketch = `sketch001 = startSketchOn(XZ) |> startProfileAt([0.02, 0.22], %) |> xLine(length = 0.39) |> line([0.02, -0.17], %) @@ -698,10 +698,10 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { |> line([-0.08, 0.05], %)` const ast = assertParse(openSketch) expect(ast.start).toEqual(0) - expect(ast.end).toEqual(245) + expect(ast.end).toEqual(243) }) it('should find the location to add new lineTo', () => { - const openSketch = `sketch001 = startSketchOn('XZ') + const openSketch = `sketch001 = startSketchOn(XZ) |> startProfileAt([0.02, 0.22], %) |> xLine(length = 0.39) |> line([0.02, -0.17], %) @@ -741,7 +741,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { }) if (err(modifiedAst)) throw modifiedAst const recasted = recast(modifiedAst) - const expectedCode = `sketch001 = startSketchOn('XZ') + const expectedCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([0.02, 0.22], %) |> xLine(length = 0.39) |> line([0.02, -0.17], %) @@ -755,7 +755,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { expect(recasted).toEqual(expectedCode) }) it('it should find the location to add close', () => { - const openSketch = `sketch001 = startSketchOn('XZ') + const openSketch = `sketch001 = startSketchOn(XZ) |> startProfileAt([0.02, 0.22], %) |> xLine(length = 0.39) |> line([0.02, -0.17], %) @@ -781,7 +781,7 @@ describe('Testing specific sketch getNodeFromPath workflow', () => { if (err(modifiedAst)) throw modifiedAst const recasted = recast(modifiedAst) - const expectedCode = `sketch001 = startSketchOn('XZ') + const expectedCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([0.02, 0.22], %) |> xLine(length = 0.39) |> line([0.02, -0.17], %) diff --git a/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts b/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts index 936df9742..d8a78ebb2 100644 --- a/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts +++ b/src/lang/queryAst/getTagDeclaratorsInProgram.test.ts @@ -30,14 +30,14 @@ describe(`getTagDeclaratorsInProgram`, () => { }) it(`finds a single tag declarators in a small program`, () => { const tagDeclarators = getTagDeclaratorsInProgram( - assertParse(`sketch001 = startSketchOn('XZ') + assertParse(`sketch001 = startSketchOn(XZ) profile001 = startProfileAt([0, 0], sketch001) |> angledLine([0, 11], %, $a)`) ) - expect(tagDeclarators).toEqual([tagDeclaratorWithIndex('a', 107, 109, 1)]) + expect(tagDeclarators).toEqual([tagDeclaratorWithIndex('a', 105, 107, 1)]) }) it(`finds multiple tag declarators in a small program`, () => { - const program = `sketch001 = startSketchOn('XZ') + const program = `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([0.07, 0], sketch001) |> angledLine([0, 11], %, $a) |> angledLine([segAng(a) + 90, 11.17], %, $b) @@ -46,13 +46,13 @@ profile001 = startProfileAt([0.07, 0], sketch001) |> close()` const tagDeclarators = getTagDeclaratorsInProgram(assertParse(program)) expect(tagDeclarators).toEqual([ - tagDeclaratorWithIndex('a', 110, 112, 1), - tagDeclaratorWithIndex('b', 158, 160, 1), - tagDeclaratorWithIndex('c', 206, 208, 1), + tagDeclaratorWithIndex('a', 108, 110, 1), + tagDeclaratorWithIndex('b', 156, 158, 1), + tagDeclaratorWithIndex('c', 204, 206, 1), ]) }) it(`finds tag declarators at different indices`, () => { - const program = `sketch001 = startSketchOn('XZ') + const program = `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([0.07, 0], sketch001) |> angledLine([0, 11], %, $a) profile002 = angledLine([segAng(a) + 90, 11.17], profile001, $b) @@ -61,9 +61,9 @@ profile002 = angledLine([segAng(a) + 90, 11.17], profile001, $b) |> close()` const tagDeclarators = getTagDeclaratorsInProgram(assertParse(program)) expect(tagDeclarators).toEqual([ - tagDeclaratorWithIndex('a', 110, 112, 1), - tagDeclaratorWithIndex('b', 175, 177, 2), - tagDeclaratorWithIndex('c', 223, 225, 2), + tagDeclaratorWithIndex('a', 108, 110, 1), + tagDeclaratorWithIndex('b', 173, 175, 2), + tagDeclaratorWithIndex('c', 221, 223, 2), ]) }) }) diff --git a/src/lang/recast.test.ts b/src/lang/recast.test.ts index 1cbb56766..38110f71b 100644 --- a/src/lang/recast.test.ts +++ b/src/lang/recast.test.ts @@ -75,7 +75,7 @@ log(5, myVar) expect(recasted.trim()).toBe(code) }) it('recast sketch declaration', () => { - let code = `mySketch = startSketchOn('XY') + let code = `mySketch = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [0, 1], tag = $myPath) |> line(endAbsolute = [1, 1]) @@ -89,7 +89,7 @@ log(5, myVar) }) it('sketch piped into callExpression', () => { const code = [ - "mySk1 = startSketchOn('XY')", + 'mySk1 = startSketchOn(XY)', ' |> startProfileAt([0, 0], %)', ' |> line(endAbsolute = [1, 1])', ' |> line(endAbsolute = [0, 1], tag = $myTag)', @@ -235,7 +235,7 @@ key = 'c' }) it('comments in a pipe expression', () => { const code = [ - "mySk1 = startSketchOn('XY')", + 'mySk1 = startSketchOn(XY)', ' |> startProfileAt([0, 0], %)', ' |> line(endAbsolute = [1, 1])', ' |> line(endAbsolute = [0, 1], tag = $myTag)', @@ -252,7 +252,7 @@ key = 'c' const code = ` /* comment at start */ -mySk1 = startSketchOn('XY') +mySk1 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) // comment here @@ -276,7 +276,7 @@ one more for good measure if (err(recasted)) throw recasted expect(recasted).toBe(`/* comment at start */ -mySk1 = startSketchOn('XY') +mySk1 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) // comment here @@ -317,7 +317,7 @@ describe('testing call Expressions in BinaryExpressions and UnaryExpressions', ( }) it('with unaryExpression in sketch situation', () => { const code = [ - "part001 = startSketchOn('XY')", + 'part001 = startSketchOn(XY)', ' |> startProfileAt([0, 0])', ' |> line(end = [-2.21, -legLen(5, min(3, 999))])', ].join('\n') @@ -330,7 +330,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') + const code = `part001 = startSketchOn(XY) |> startProfileAt([-0.01, -0.08], %) |> line(end = [0.62, 4.15], tag = $seg01) |> line(end = [2.77, -1.24]) diff --git a/src/lang/std/sketch.test.ts b/src/lang/std/sketch.test.ts index 47e25c4d8..0a47f2f86 100644 --- a/src/lang/std/sketch.test.ts +++ b/src/lang/std/sketch.test.ts @@ -110,7 +110,7 @@ describe('testing changeSketchArguments', () => { const lineAfterChange = 'line(endAbsolute = [2, 3])' test('changeSketchArguments', async () => { // Enable rotations #152 - const genCode = (line: string) => `mySketch001 = startSketchOn('XY') + const genCode = (line: string) => `mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> ${line} |> line(endAbsolute = [0.46, -5.82]) @@ -148,7 +148,7 @@ describe('testing addNewSketchLn', () => { test('addNewSketchLn', async () => { // Enable rotations #152 const code = ` -mySketch001 = startSketchOn('XY') +mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) @@ -157,7 +157,7 @@ mySketch001 = startSketchOn('XY') const execState = await enginelessExecutor(ast) const sourceStart = code.indexOf(lineToChange) - expect(sourceStart).toBe(89) + expect(sourceStart).toBe(87) const newSketchLnRetVal = addNewSketchLn({ node: ast, variables: execState.variables, @@ -177,7 +177,7 @@ mySketch001 = startSketchOn('XY') if (err(newSketchLnRetVal)) return newSketchLnRetVal // Enable rotations #152 - let expectedCode = `mySketch001 = startSketchOn('XY') + let expectedCode = `mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) @@ -200,7 +200,7 @@ mySketch001 = startSketchOn('XY') }) if (err(modifiedAst2)) return modifiedAst2 - expectedCode = `mySketch001 = startSketchOn('XY') + expectedCode = `mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) // |> rx(45, %) |> line(endAbsolute = [-1.59, -1.54]) @@ -215,7 +215,7 @@ describe('testing addTagForSketchOnFace', () => { it('needs to be in it', async () => { const originalLine = 'line(endAbsolute = [-1.59, -1.54])' // Enable rotations #152 - const genCode = (line: string) => `mySketch001 = startSketchOn('XY') + const genCode = (line: string) => `mySketch001 = startSketchOn(XY) |> startProfileAt([0, 0], %) // |> rx(45, %) |> ${line} @@ -275,7 +275,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') + const genCode = (insertCode: string) => `sketch001 = startSketchOn(XZ) |> startProfileAt([75.8, 317.2], %) // [$startCapTag, $EndCapTag] |> angledLine([0, 268.43], %, $rectangleSegmentA001) |> angledLine([ @@ -326,7 +326,7 @@ ${insertCode} describe('testing getConstraintInfo', () => { describe('object notation', () => { - const code = `const part001 = startSketchOn('-XZ') + const code = `const part001 = startSketchOn(-XZ) |> startProfileAt([0,0], %) |> line(end = [3, 4]) |> angledLine({ @@ -702,7 +702,7 @@ describe('testing getConstraintInfo', () => { }) }) describe('array notation', () => { - const code = `const part001 = startSketchOn('-XZ') + const code = `const part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> line(end = [3, 4]) |> angledLine([3.14, 3.14], %) @@ -859,7 +859,7 @@ describe('testing getConstraintInfo', () => { }) }) describe('constrained', () => { - const code = `const part001 = startSketchOn('-XZ') + const code = `const part001 = startSketchOn(-XZ) |> startProfileAt([0, 0], %) |> line(end = [3 + 0, 4 + 0]) |> angledLine({ angle = 3.14 + 0, length = 3.14 + 0 }, %) diff --git a/src/lang/std/sketchConstraints.test.ts b/src/lang/std/sketchConstraints.test.ts index ed938c548..67f091556 100644 --- a/src/lang/std/sketchConstraints.test.ts +++ b/src/lang/std/sketchConstraints.test.ts @@ -71,7 +71,7 @@ async function testingSwapSketchFnCall({ describe('testing swapping out sketch calls with xLine/xLineTo', () => { const bigExampleArr = [ - `part001 = startSketchOn('XY')`, + `part001 = startSketchOn(XY)`, ` |> startProfileAt([0, 0], %)`, ` |> line(endAbsolute = [1, 1], tag = $abc1)`, ` |> line(end = [-2.04, -0.7], tag = $abc2)`, @@ -269,7 +269,7 @@ describe('testing swapping out sketch calls with xLine/xLineTo while keeping var `angledLineOfYLengthY = 0.89`, `angledLineToXx = -1.86`, `angledLineToYy = -0.76`, - `part001 = startSketchOn('XY')`, + `part001 = startSketchOn(XY)`, ` |> startProfileAt([0, 0], %)`, // ` |> rx(90, %)`, ` |> line(endAbsolute = [1, 1])`, @@ -363,7 +363,7 @@ describe('testing swapping out sketch calls with xLine/xLineTo while keeping var describe('testing getSketchSegmentIndexFromSourceRange', () => { const code = ` -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0.04], %) // segment-in-start |> line(end = [0, 0.4]) |> xLine(length = 3.48) diff --git a/src/lang/std/sketchConstraints.ts b/src/lang/std/sketchConstraints.ts index 6386cc936..d3f369174 100644 --- a/src/lang/std/sketchConstraints.ts +++ b/src/lang/std/sketchConstraints.ts @@ -93,7 +93,7 @@ export function isSketchVariablesLinked( and will keep checking the second arguments recursively until it runs out of variable declarations 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') + const part001 = startSketchOn(XY) |> startProfileAt([0, 0],%) |> xLine(endAbsolute = 1.69) |> line(end = [myVar, 0.38]) // ❗️ <- cursor in this fn call (the primary) diff --git a/src/lang/std/sketchcombos.test.ts b/src/lang/std/sketchcombos.test.ts index 44a905052..7406b3da2 100644 --- a/src/lang/std/sketchcombos.test.ts +++ b/src/lang/std/sketchcombos.test.ts @@ -172,14 +172,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') + const inputScript = `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [5, 5]) |> line(end = [-2, 5]) |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close()` - const expectedModifiedScript = `sketch001 = startSketchOn('XZ') + const expectedModifiedScript = `sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> line(end = [5, 5], tag = $seg01) |> angledLine([112, segLen(seg01)], %) @@ -260,7 +260,7 @@ myVar2 = 5 myVar3 = 6 myAng = 40 myAng2 = 134 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82]) // ln-should-get-tag |> line(endAbsolute = [myVar, 1]) // ln-lineTo-xAbsolute should use angleToMatchLengthX helper @@ -296,7 +296,7 @@ myVar2 = 5 myVar3 = 6 myAng = 40 myAng2 = 134 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [1, 3.82], tag = $seg01) // ln-should-get-tag |> angledLineToX([ @@ -401,7 +401,7 @@ describe('testing transformAstForSketchLines for vertical and horizontal constra const inputScript = `myVar = 2 myVar2 = 12 myVar3 = -10 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) |> line(end = [-6.28, 1.4]) // select for horizontal constraint 1 @@ -429,7 +429,7 @@ part001 = startSketchOn('XY') const expectModifiedScript = `myVar = 2 myVar2 = 12 myVar3 = -10 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) |> xLine(length = -6.28) // select for horizontal constraint 1 @@ -489,7 +489,7 @@ part001 = startSketchOn('XY') const expectModifiedScript = `myVar = 2 myVar2 = 12 myVar3 = -10 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [1, 1]) |> line(end = [-6.28, 1.4]) // select for horizontal constraint 1 @@ -550,7 +550,7 @@ part001 = startSketchOn('XY') describe('testing transformAstForSketchLines for vertical and horizontal distance constraints', () => { describe('testing setHorzDistance for line', () => { const inputScript = `myVar = 1 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(end = [0.31, 1.67]) // base selection |> line(end = [0.45, 1.46]) @@ -656,7 +656,7 @@ baseThickHalf = baseThick / 2 halfHeight = totalHeight / 2 halfArmAngle = armAngle / 2 -part001 = startSketchOn('XY') +part001 = startSketchOn(XY) |> startProfileAt([-0.01, -0.05], %) |> line(end = [0.01, 0.94 + 0]) // partial |> xLine(length = 3.03) // partial diff --git a/src/lang/std/std.test.ts b/src/lang/std/std.test.ts index 3bc2e783c..f18183ab2 100644 --- a/src/lang/std/std.test.ts +++ b/src/lang/std/std.test.ts @@ -7,7 +7,7 @@ beforeAll(async () => { describe('testing angledLineThatIntersects', () => { it('angledLineThatIntersects should intersect with another line', async () => { - const code = (offset: string) => `part001 = startSketchOn('XY') + const code = (offset: string) => `part001 = startSketchOn(XY) |> startProfileAt([0, 0], %) |> line(endAbsolute = [2, 2], tag = $yo) |> line(endAbsolute = [3, 1]) diff --git a/src/lib/commandBarConfigs/modelingCommandConfig.ts b/src/lib/commandBarConfigs/modelingCommandConfig.ts index 6252e9965..3afa8764a 100644 --- a/src/lib/commandBarConfigs/modelingCommandConfig.ts +++ b/src/lib/commandBarConfigs/modelingCommandConfig.ts @@ -55,8 +55,12 @@ export type ModelingCommandSchema = { distance: KclCommandValue } Sweep: { + // Enables editing workflow + nodeToEdit?: PathToNode + // Arguments target: Selections trajectory: Selections + sectional: boolean } Loft: { selection: Selections @@ -357,22 +361,40 @@ export const modelingMachineCommandConfig: StateMachineCommandSetConfig< description: 'Create a 3D body by moving a sketch region along an arbitrary path.', icon: 'sweep', - needsReview: false, + needsReview: true, args: { + nodeToEdit: { + description: + 'Path to the node in the AST to edit. Never shown to the user.', + skip: true, + inputType: 'text', + required: false, + }, target: { inputType: 'selection', selectionTypes: ['solid2d'], required: true, skip: true, multiple: false, + hidden: (context) => Boolean(context.argumentsToSubmit.nodeToEdit), }, trajectory: { inputType: 'selection', - selectionTypes: ['segment', 'path'], + selectionTypes: ['segment'], required: true, - skip: false, + skip: true, multiple: false, validation: sweepValidator, + hidden: (context) => Boolean(context.argumentsToSubmit.nodeToEdit), + }, + sectional: { + inputType: 'options', + required: true, + options: [ + { name: 'False', value: false }, + { name: 'True', value: true }, + ], + // No validation possible here until we have rollback }, }, }, diff --git a/src/lib/exampleKcl.ts b/src/lib/exampleKcl.ts index 6c53d1bf8..abdf27ab8 100644 --- a/src/lib/exampleKcl.ts +++ b/src/lib/exampleKcl.ts @@ -19,7 +19,7 @@ filletRadius = .25 extFilletRadius = filletRadius + thickness mountingHoleDiameter = 0.5 -sketch001 = startSketchOn('XZ') +sketch001 = startSketchOn(XZ) |> startProfileAt([0, 0], %) |> xLine(length = shelfMountL - thickness, tag = $seg01) |> yLine(length = thickness, tag = $seg02) diff --git a/src/lib/operations.ts b/src/lib/operations.ts index fec432fb0..9b9b3014d 100644 --- a/src/lib/operations.ts +++ b/src/lib/operations.ts @@ -311,6 +311,143 @@ const prepareToEditOffsetPlane: PrepareToEditCallback = async ({ } } +const prepareToEditSweep: PrepareToEditCallback = async ({ + artifact, + operation, +}) => { + const baseCommand = { + name: 'Sweep', + groupId: 'modeling', + } + if ( + operation.type !== 'StdLibCall' || + !operation.labeledArgs || + !operation.unlabeledArg || + !('sectional' in operation.labeledArgs) || + !operation.labeledArgs.sectional + ) { + return baseCommand + } + if (!artifact || !('pathId' in artifact) || operation.type !== 'StdLibCall') { + return baseCommand + } + + // We have to go a little roundabout to get from the original artifact + // to the solid2DId that we need to pass to the Sweep command, just like Extrude. + const pathArtifact = getArtifactOfTypes( + { + key: artifact.pathId, + types: ['path'], + }, + engineCommandManager.artifactGraph + ) + + if ( + err(pathArtifact) || + pathArtifact.type !== 'path' || + !pathArtifact.solid2dId + ) { + return baseCommand + } + + const targetArtifact = getArtifactOfTypes( + { + key: pathArtifact.solid2dId, + types: ['solid2d'], + }, + engineCommandManager.artifactGraph + ) + + if (err(targetArtifact) || targetArtifact.type !== 'solid2d') { + return baseCommand + } + + const target = { + graphSelections: [ + { + artifact: targetArtifact, + codeRef: pathArtifact.codeRef, + }, + ], + otherSelections: [], + } + + // Same roundabout but twice for 'path' aka trajectory: sketch -> path -> segment + if (!('path' in operation.labeledArgs) || !operation.labeledArgs.path) { + return baseCommand + } + + if (operation.labeledArgs.path.value.type !== 'Sketch') { + return baseCommand + } + + const trajectoryPathArtifact = getArtifactOfTypes( + { + key: operation.labeledArgs.path.value.value.artifactId, + types: ['path'], + }, + engineCommandManager.artifactGraph + ) + + if (err(trajectoryPathArtifact) || trajectoryPathArtifact.type !== 'path') { + return baseCommand + } + + const trajectoryArtifact = getArtifactOfTypes( + { + key: trajectoryPathArtifact.segIds[0], + types: ['segment'], + }, + engineCommandManager.artifactGraph + ) + + if (err(trajectoryArtifact) || trajectoryArtifact.type !== 'segment') { + return baseCommand + } + + const trajectory = { + graphSelections: [ + { + artifact: trajectoryArtifact, + codeRef: trajectoryArtifact.codeRef, + }, + ], + otherSelections: [], + } + + // sectional options boolean arg + if ( + !('sectional' in operation.labeledArgs) || + !operation.labeledArgs.sectional + ) { + return baseCommand + } + + const sectional = + codeManager.code.slice( + operation.labeledArgs.sectional.sourceRange[0], + operation.labeledArgs.sectional.sourceRange[1] + ) === 'true' + + // Assemble the default argument values for the Offset Plane command, + // with `nodeToEdit` set, which will let the Offset Plane actor know + // to edit the node that corresponds to the StdLibCall. + const argDefaultValues: ModelingCommandSchema['Sweep'] = { + target: target, + trajectory, + sectional, + nodeToEdit: getNodePathFromSourceRange( + kclManager.ast, + sourceRangeFromRust(operation.sourceRange) + ), + } + + return { + ...baseCommand, + argDefaultValues, + } +} + const prepareToEditHelix: PrepareToEditCallback = async ({ operation }) => { const baseCommand = { name: 'Helix', @@ -511,6 +648,7 @@ export const stdLibMap: Record = { sweep: { label: 'Sweep', icon: 'sweep', + prepareToEdit: prepareToEditSweep, supportsAppearance: true, }, } diff --git a/src/lib/rectangleTool.test.ts b/src/lib/rectangleTool.test.ts index faf1f5deb..33010c130 100644 --- a/src/lib/rectangleTool.test.ts +++ b/src/lib/rectangleTool.test.ts @@ -20,7 +20,7 @@ describe('library rectangleTool helper functions', () => { // regression test for https://github.com/KittyCAD/modeling-app/issues/5157 test('should update AST and source code', async () => { // Base source code that will be edited in place - const sourceCode = `sketch001 = startSketchOn('XZ') + const sourceCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([120.37, 162.76], %) |> angledLine([0, 0], %, $rectangleSegmentA001) |> angledLine([segAng(rectangleSegmentA001) + 90, 0], %, $rectangleSegmentB001) @@ -73,7 +73,7 @@ segAng(rectangleSegmentA001), } // ast is edited in place from the updateCenterRectangleSketch - const expectedSourceCode = `sketch001 = startSketchOn('XZ') + const expectedSourceCode = `sketch001 = startSketchOn(XZ) |> startProfileAt([120.37, 80], %) |> angledLine([0, 0], %, $rectangleSegmentA001) |> angledLine([segAng(rectangleSegmentA001) + 90, 0], %, $rectangleSegmentB001) diff --git a/src/lib/rectangleTool.ts b/src/lib/rectangleTool.ts index c7b392f23..84b6e10a5 100644 --- a/src/lib/rectangleTool.ts +++ b/src/lib/rectangleTool.ts @@ -24,7 +24,7 @@ import { ARG_END_ABSOLUTE } from 'lang/std/sketch' /** * It does not create the startSketchOn and it does not create the startProfileAt. * Returns AST expressions for this KCL code: - * const yo = startSketchOn('XY') + * const yo = startSketchOn(XY) * |> startProfileAt([0, 0], %) * |> angledLine([0, 0], %, $a) * |> angledLine([segAng(a) - 90, 0], %, $b) diff --git a/src/lib/selections.test.ts b/src/lib/selections.test.ts index c7b49c01f..545dfd2d5 100644 --- a/src/lib/selections.test.ts +++ b/src/lib/selections.test.ts @@ -14,7 +14,7 @@ beforeAll(async () => { }) describe('testing source range to artifact conversion', () => { - const MY_CODE = `sketch001 = startSketchOn('XZ') + const MY_CODE = `sketch001 = startSketchOn(XZ) profile001 = startProfileAt([105.55, 105.55], sketch001) |> xLine(332.55, %, $seg01) |> yLine(-310.12, %, $seg02) @@ -1114,7 +1114,7 @@ profile004 = circle(sketch003, [ 'default plane selection', { - snippet: "sketch001 = startSketchOn('XZ')", + snippet: 'sketch001 = startSketchOn(XZ)', artifactDetails: { type: 'plane', range: [31, 31, 0], diff --git a/src/machines/modelingMachine.ts b/src/machines/modelingMachine.ts index 7bc3d35e2..044995a9d 100644 --- a/src/machines/modelingMachine.ts +++ b/src/machines/modelingMachine.ts @@ -78,7 +78,7 @@ import { import { ModelingCommandSchema } from 'lib/commandBarConfigs/modelingCommandConfig' import { err, reportRejection, trap } from 'lib/trap' import { DefaultPlaneStr } from 'lib/planes' -import { uuidv4 } from 'lib/utils' +import { isArray, uuidv4 } from 'lib/utils' import { Coords2d } from 'lang/std/sketch' import { deleteSegment } from 'clientSideScene/ClientSideSceneComp' import toast from 'react-hot-toast' @@ -484,6 +484,9 @@ export const modelingMachine = setup({ 'Selection is on face': () => false, 'Has exportable geometry': () => false, 'has valid selection for deletion': () => false, + 'no kcl errors': () => { + return !kclManager.hasErrors() + }, 'is editing existing sketch': ({ context: { sketchDetails } }) => isEditingExistingSketch({ sketchDetails }), 'Can make selection horizontal': ({ context: { selectionRanges } }) => { @@ -870,14 +873,14 @@ export const modelingMachine = setup({ ) // Position the click raycast plane - if (sceneEntitiesManager.intersectionPlane) { - sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( - quaternion - ) - sceneEntitiesManager.intersectionPlane.position.copy( - new Vector3(...(sketchDetails?.origin || [0, 0, 0])) - ) - } + + sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( + quaternion + ) + sceneEntitiesManager.intersectionPlane.position.copy( + new Vector3(...(sketchDetails?.origin || [0, 0, 0])) + ) + sceneInfra.setCallbacks({ onClick: (args) => { if (!args) return @@ -906,14 +909,14 @@ export const modelingMachine = setup({ ) // Position the click raycast plane - if (sceneEntitiesManager.intersectionPlane) { - sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( - quaternion - ) - sceneEntitiesManager.intersectionPlane.position.copy( - new Vector3(...(sketchDetails?.origin || [0, 0, 0])) - ) - } + + sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( + quaternion + ) + sceneEntitiesManager.intersectionPlane.position.copy( + new Vector3(...(sketchDetails?.origin || [0, 0, 0])) + ) + sceneInfra.setCallbacks({ onClick: (args) => { if (!args) return @@ -939,14 +942,14 @@ export const modelingMachine = setup({ ) // Position the click raycast plane - if (sceneEntitiesManager.intersectionPlane) { - sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( - quaternion - ) - sceneEntitiesManager.intersectionPlane.position.copy( - new Vector3(...(sketchDetails?.origin || [0, 0, 0])) - ) - } + + sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( + quaternion + ) + sceneEntitiesManager.intersectionPlane.position.copy( + new Vector3(...(sketchDetails?.origin || [0, 0, 0])) + ) + sceneInfra.setCallbacks({ onClick: (args) => { if (!args) return @@ -973,14 +976,14 @@ export const modelingMachine = setup({ ) // Position the click raycast plane - if (sceneEntitiesManager.intersectionPlane) { - sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( - quaternion - ) - sceneEntitiesManager.intersectionPlane.position.copy( - new Vector3(...(sketchDetails?.origin || [0, 0, 0])) - ) - } + + sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( + quaternion + ) + sceneEntitiesManager.intersectionPlane.position.copy( + new Vector3(...(sketchDetails?.origin || [0, 0, 0])) + ) + sceneInfra.setCallbacks({ onClick: (args) => { if (!args) return @@ -1011,14 +1014,13 @@ export const modelingMachine = setup({ ) // Position the click raycast plane - if (sceneEntitiesManager.intersectionPlane) { - sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( - quaternion - ) - sceneEntitiesManager.intersectionPlane.position.copy( - new Vector3(...(sketchDetails?.origin || [0, 0, 0])) - ) - } + + sceneEntitiesManager.intersectionPlane.setRotationFromQuaternion( + quaternion + ) + sceneEntitiesManager.intersectionPlane.position.copy( + new Vector3(...(sketchDetails?.origin || [0, 0, 0])) + ) const dummy = new Mesh() dummy.position.set(0, 0, 0) @@ -1994,55 +1996,88 @@ export const modelingMachine = setup({ if (!input) return new Error('No input provided') // Extract inputs const ast = kclManager.ast - const { target, trajectory } = input + const { target, trajectory, sectional, nodeToEdit } = input + let variableName: string | undefined = undefined + let insertIndex: number | undefined = undefined - // Find the profile declaration + // If this is an edit flow, first we're going to remove the old one + if (nodeToEdit !== undefined && typeof nodeToEdit[1][0] === 'number') { + // Extract the plane name from the node to edit + const variableNode = getNodeFromPath( + ast, + nodeToEdit, + 'VariableDeclaration' + ) + + if (err(variableNode)) { + console.error('Error extracting name') + } else { + variableName = variableNode.node.declaration.id.name + } + + // Removing the old statement + const newBody = [...ast.body] + newBody.splice(nodeToEdit[1][0], 1) + ast.body = newBody + insertIndex = nodeToEdit[1][0] + } + + // Find the target declaration const targetNodePath = getNodePathFromSourceRange( ast, target.graphSelections[0].codeRef.range ) - const targetNode = getNodeFromPath( - ast, - targetNodePath, - 'VariableDeclarator' - ) + // Gotchas, not sure why + // - it seems like in some cases we get a list on edit, especially the state that e2e hits + // - looking for a VariableDeclaration seems more robust than VariableDeclarator + const targetNode = getNodeFromPath< + VariableDeclaration | VariableDeclaration[] + >(ast, targetNodePath, 'VariableDeclaration') if (err(targetNode)) { return new Error("Couldn't parse profile selection") } - const targetDeclarator = targetNode.node - // Find the path declaration + const targetDeclarator = isArray(targetNode.node) + ? targetNode.node[0].declaration + : targetNode.node.declaration + + // Find the trajectory (or path) declaration const trajectoryNodePath = getNodePathFromSourceRange( ast, trajectory.graphSelections[0].codeRef.range ) - const trajectoryNode = getNodeFromPath( + // Also looking for VariableDeclaration for consistency here + const trajectoryNode = getNodeFromPath( ast, trajectoryNodePath, - 'VariableDeclarator' + 'VariableDeclaration' ) if (err(trajectoryNode)) { return new Error("Couldn't parse path selection") } - const trajectoryDeclarator = trajectoryNode.node + + const trajectoryDeclarator = trajectoryNode.node.declaration // Perform the sweep - const sweepRes = addSweep(ast, targetDeclarator, trajectoryDeclarator) - const updateAstResult = await kclManager.updateAst( - sweepRes.modifiedAst, - true, + const { modifiedAst, pathToNode } = addSweep({ + node: ast, + targetDeclarator, + trajectoryDeclarator, + sectional, + variableName, + insertIndex, + }) + await updateModelingState( + modifiedAst, { - focusPath: [sweepRes.pathToNode], + kclManager, + editorManager, + codeManager, + }, + { + focusPath: [pathToNode], } ) - - await codeManager.updateEditorWithAstAndWriteToFile( - updateAstResult.newAst - ) - - if (updateAstResult?.selections) { - editorManager.selectRange(updateAstResult?.selections) - } } ), loftAstMod: fromPromise( @@ -2662,7 +2697,10 @@ export const modelingMachine = setup({ states: { hidePlanes: { on: { - 'Artifact graph populated': 'showPlanes', + 'Artifact graph populated': { + target: 'showPlanes', + guard: 'no kcl errors', + }, }, entry: 'hide default planes', diff --git a/src/test-utils.test.ts b/src/test-utils.test.ts index 0370f4472..9f0266e9c 100644 --- a/src/test-utils.test.ts +++ b/src/test-utils.test.ts @@ -2,7 +2,7 @@ import { normaliseKclNumbers } from '../e2e/playwright/test-utils' test('normaliseKclNumbers', () => { expect( - normaliseKclNumbers(`sketch001 = startSketchOn('XY') + normaliseKclNumbers(`sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -10,7 +10,7 @@ test('normaliseKclNumbers', () => { |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) |> close() const extrude001 = extrude(sketch001, length = -15)`) - ).toBe(`sketch001 = startSketchOn('XY') + ).toBe(`sketch001 = startSketchOn(XY) |> startProfileAt([-12.34, 12.34], %) |> line(end = [12.34, 0]) |> line(end = [0, -12.34]) @@ -20,7 +20,7 @@ const extrude001 = extrude(sketch001, length = -15)`) const extrude001 = extrude(sketch001, length = -12.34)`) expect( normaliseKclNumbers( - `sketch001 = startSketchOn('XY') + `sketch001 = startSketchOn(XY) |> startProfileAt([-10, 10], %) |> line(end = [20, 0]) |> line(end = [0, -20]) @@ -30,7 +30,7 @@ const extrude001 = extrude(sketch001, length = -12.34)`) const extrude001 = extrude(sketch001, length = -15)`, false ) - ).toBe(`sketch001 = startSketchOn('XY') + ).toBe(`sketch001 = startSketchOn(XY) |> startProfileAt([-12.34, 12.34], %) |> line(end = [12.34, 12.34]) |> line(end = [12.34, -12.34])