From bfdf8babed009ee6c8c208dd2d5d9dd5718c77a7 Mon Sep 17 00:00:00 2001 From: Jess Frazelle Date: Fri, 4 Apr 2025 12:55:21 -0700 Subject: [PATCH] sketching on a mirror2d thats been extruded fixed! (#6149) * updates Signed-off-by: Jess Frazelle * snap Signed-off-by: Jess Frazelle * fixes Signed-off-by: Jess Frazelle * add sample Signed-off-by: Jess Frazelle * updates Signed-off-by: Jess Frazelle * updates Signed-off-by: Jess Frazelle * updates Signed-off-by: Jess Frazelle * fixes Signed-off-by: Jess Frazelle * snap Signed-off-by: Jess Frazelle --------- Signed-off-by: Jess Frazelle --- docs/kcl/std-sketch-mirror2d.md | 21 + public/kcl-samples/ball-bearing/main.kcl | 2 +- public/kcl-samples/makeup-mirror/main.kcl | 2 +- .../pipe-flange-assembly/1120t74-pipe.kcl | 1 - .../pipe-flange-assembly/68095k348-flange.kcl | 3 +- .../95479a127-hex-nut.kcl | 1 - .../pipe-flange-assembly/98017a257-washer.kcl | 2 +- .../kcl-samples/pipe-flange-assembly/main.kcl | 2 +- rust/kcl-lib/src/execution/geometry.rs | 3 + rust/kcl-lib/src/std/extrude.rs | 21 +- rust/kcl-lib/src/std/mirror.rs | 52 +- rust/kcl-lib/src/std/sketch.rs | 1 + rust/kcl-lib/std/sketch.kcl | 19 + .../kcl_samples/i-beam/artifact_commands.snap | 356 ++++++++ .../kcl_samples/i-beam/program_memory.snap | 4 +- .../tests/kcl_samples/makeup-mirror/ast.snap | 844 +++++++++--------- ...rial_test_example_std-sketch-mirror2d4.png | Bin 0 -> 79782 bytes 17 files changed, 891 insertions(+), 443 deletions(-) create mode 100644 rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d4.png diff --git a/docs/kcl/std-sketch-mirror2d.md b/docs/kcl/std-sketch-mirror2d.md index 5dd8595cb..41959fd8b 100644 --- a/docs/kcl/std-sketch-mirror2d.md +++ b/docs/kcl/std-sketch-mirror2d.md @@ -95,4 +95,25 @@ example = extrude(sketch001, length = 10) ![Rendered example of std::sketch::mirror2d 3]() +```js +// Sketch on the face of a mirrored sketch, that has been extruded. +sketch0011 = startSketchOn(XY) + |> startProfileAt([6.77, 0], %) + |> yLine(length = 1.27) + |> tangentialArcTo([5.96, 2.37], %) + |> tangentialArcTo([-6.2, 2.44], %) + |> tangentialArcTo([-6.6, 1.82], %) + |> yLine(length = -1.82) + |> mirror2d( axis = X ) + |> extrude(length = 10) + +sketch002 = startSketchOn(sketch0011, 'END') + |> circle( center = [-0.01, 1.58], radius = 1.2 ) + |> extrude(length = 1.2) + +shell([sketch002], faces = ['end'], thickness = .1 ) +``` + +![Rendered example of std::sketch::mirror2d 4]() + diff --git a/public/kcl-samples/ball-bearing/main.kcl b/public/kcl-samples/ball-bearing/main.kcl index 501f68383..c3373e04d 100644 --- a/public/kcl-samples/ball-bearing/main.kcl +++ b/public/kcl-samples/ball-bearing/main.kcl @@ -94,4 +94,4 @@ outsideWallSketch = startSketchOn(offsetPlane(XY, offset = -overallThickness / 2 |> circle(center = [0, 0], radius = outsideDiameter / 2) |> hole(circle(center = [0, 0], radius = shaftDia / 2 + wallThickness + sphereDia), %) -outsideWall = extrude(outsideWallSketch, length = overallThickness) \ No newline at end of file +outsideWall = extrude(outsideWallSketch, length = overallThickness) diff --git a/public/kcl-samples/makeup-mirror/main.kcl b/public/kcl-samples/makeup-mirror/main.kcl index 35fb44526..6262873e2 100644 --- a/public/kcl-samples/makeup-mirror/main.kcl +++ b/public/kcl-samples/makeup-mirror/main.kcl @@ -21,7 +21,7 @@ archThickness = 1 archRadius = mirrorRadius + archToMirrorGap // Geometry -// Add a function to create the hinge +// Add a function to create the hinge fn hingeFn(x, y, z) { hingeBody = startSketchOn(offsetPlane(XY, offset = z)) |> circle(center = [x, y], radius = hingeRadius) diff --git a/public/kcl-samples/pipe-flange-assembly/1120t74-pipe.kcl b/public/kcl-samples/pipe-flange-assembly/1120t74-pipe.kcl index 3bcbc133a..8871155d6 100644 --- a/public/kcl-samples/pipe-flange-assembly/1120t74-pipe.kcl +++ b/public/kcl-samples/pipe-flange-assembly/1120t74-pipe.kcl @@ -9,7 +9,6 @@ import pipeInnerDiameter, pipeOuterDiameter, pipeLength from "parameters.kcl" // Create a function to make the pipe. Export export fn pipe() { - // Create the pipe base pipeBase = startSketchOn(XZ) |> circle(%, center = [0, 0], radius = pipeOuterDiameter / 2) diff --git a/public/kcl-samples/pipe-flange-assembly/68095k348-flange.kcl b/public/kcl-samples/pipe-flange-assembly/68095k348-flange.kcl index d7c2ed0c2..fc99d12f8 100644 --- a/public/kcl-samples/pipe-flange-assembly/68095k348-flange.kcl +++ b/public/kcl-samples/pipe-flange-assembly/68095k348-flange.kcl @@ -9,7 +9,6 @@ import pipeDiameter, mountingHoleDiameter, mountingHolePlacementDiameter, flange // Create a function to create the flange. We must create a function since we are using multiple flanges. export fn flange() { - // Sketch the mounting hole pattern mountingHoles = startSketchOn(XY) |> circle(%, center = [0, mountingHolePlacementDiameter / 2], radius = mountingHoleDiameter / 2) @@ -42,4 +41,4 @@ export fn flange() { |> appearance(%, color = "#bab0b0") return pipeCut -} \ No newline at end of file +} diff --git a/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl b/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl index d2e5fc22b..c6d8bf5aa 100644 --- a/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl +++ b/public/kcl-samples/pipe-flange-assembly/95479a127-hex-nut.kcl @@ -9,7 +9,6 @@ import hexNutDiameter, hexNutFlatToFlat, hexNutThickness, hexNutFlatLength from // Create a function to make the hex nut. Must be a function since multiple hex nuts are used export fn hexNut() { - // Create the base of the hex nut hexNutBase = startSketchOn(XY) |> startProfileAt([ diff --git a/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl b/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl index 92a585da8..b00541af6 100644 --- a/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl +++ b/public/kcl-samples/pipe-flange-assembly/98017a257-washer.kcl @@ -7,7 +7,7 @@ // Import parameters import washerInnerDia, washerOuterDia, washerThickness from "parameters.kcl" -// Create a function to make the washer. Must be a function since multiple washers are used. +// Create a function to make the washer. Must be a function since multiple washers are used. export fn washer() { // Create the base of the washer washerBase = startSketchOn(XY) diff --git a/public/kcl-samples/pipe-flange-assembly/main.kcl b/public/kcl-samples/pipe-flange-assembly/main.kcl index e862eebd1..fd72cf973 100644 --- a/public/kcl-samples/pipe-flange-assembly/main.kcl +++ b/public/kcl-samples/pipe-flange-assembly/main.kcl @@ -8,7 +8,7 @@ import * from "parameters.kcl" // Import parts -import '9472k188-gasket.kcl' as gasket +import "9472k188-gasket.kcl" as gasket import flange from "68095k348-flange.kcl" import washer from "98017a257-washer.kcl" import bolt from "91251a404-bolt.kcl" diff --git a/rust/kcl-lib/src/execution/geometry.rs b/rust/kcl-lib/src/execution/geometry.rs index 7596661b2..cb7bb396c 100644 --- a/rust/kcl-lib/src/execution/geometry.rs +++ b/rust/kcl-lib/src/execution/geometry.rs @@ -418,6 +418,9 @@ pub struct Sketch { pub artifact_id: ArtifactId, #[ts(skip)] pub original_id: uuid::Uuid, + /// If the sketch includes a mirror. + #[serde(skip)] + pub mirror: Option, pub units: UnitLen, /// Metadata. #[serde(skip)] diff --git a/rust/kcl-lib/src/std/extrude.rs b/rust/kcl-lib/src/std/extrude.rs index 99279f6e3..4d9e36843 100644 --- a/rust/kcl-lib/src/std/extrude.rs +++ b/rust/kcl-lib/src/std/extrude.rs @@ -13,7 +13,7 @@ use kcmc::{ websocket::{ModelingCmdReq, OkWebSocketResponseData}, ModelingCmd, }; -use kittycad_modeling_cmds as kcmc; +use kittycad_modeling_cmds::{self as kcmc}; use uuid::Uuid; use crate::{ @@ -168,13 +168,18 @@ pub(crate) async fn do_post_extrude<'a>( ) .await?; - // The "get extrusion face info" API call requires *any* edge on the sketch being extruded. - // So, let's just use the first one. - let Some(any_edge_id) = sketch.paths.first().map(|edge| edge.get_base().geo_meta.id) else { - return Err(KclError::Type(KclErrorDetails { - message: "Expected a non-empty sketch".to_string(), - source_ranges: vec![args.source_range], - })); + let any_edge_id = if let Some(edge_id) = sketch.mirror { + edge_id + } else { + // The "get extrusion face info" API call requires *any* edge on the sketch being extruded. + // So, let's just use the first one. + let Some(any_edge_id) = sketch.paths.first().map(|edge| edge.get_base().geo_meta.id) else { + return Err(KclError::Type(KclErrorDetails { + message: "Expected a non-empty sketch".to_string(), + source_ranges: vec![args.source_range], + })); + }; + any_edge_id }; let mut sketch = sketch.clone(); diff --git a/rust/kcl-lib/src/std/mirror.rs b/rust/kcl-lib/src/std/mirror.rs index e22a1e10f..123e50e22 100644 --- a/rust/kcl-lib/src/std/mirror.rs +++ b/rust/kcl-lib/src/std/mirror.rs @@ -2,10 +2,13 @@ use anyhow::Result; use kcmc::{each_cmd as mcmd, ModelingCmd}; -use kittycad_modeling_cmds::{self as kcmc, length_unit::LengthUnit, shared::Point3d}; +use kittycad_modeling_cmds::{ + self as kcmc, length_unit::LengthUnit, ok_response::OkModelingCmdResponse, output::EntityGetAllChildUuids, + shared::Point3d, websocket::OkWebSocketResponseData, +}; use crate::{ - errors::KclError, + errors::{KclError, KclErrorDetails}, execution::{ types::{PrimitiveType, RuntimeType}, ExecState, KclValue, Sketch, @@ -31,13 +34,21 @@ pub async fn mirror_2d(exec_state: &mut ExecState, args: Args) -> Result, axis: Axis2dOrEdgeReference, exec_state: &mut ExecState, args: Args, ) -> Result, KclError> { - let starting_sketches = sketches; + let mut starting_sketches = sketches.clone(); + + // Update all to have a mirror. + starting_sketches.iter_mut().for_each(|sketch| { + sketch.mirror = Some(exec_state.next_uuid()); + }); if args.ctx.no_engine_commands().await { return Ok(starting_sketches); @@ -77,5 +88,40 @@ async fn inner_mirror_2d( } }; + // After the mirror, get the first child uuid for the path. + // The "get extrusion face info" API call requires *any* edge on the sketch being extruded. + // But if you mirror2d a sketch these IDs might change so we need to get the children versus + // using the IDs we already have. + // We only do this with mirrors because otherwise it is a waste of a websocket call. + for sketch in &mut starting_sketches { + let response = args + .send_modeling_cmd( + exec_state.next_uuid(), + ModelingCmd::from(mcmd::EntityGetAllChildUuids { entity_id: sketch.id }), + ) + .await?; + let OkWebSocketResponseData::Modeling { + modeling_response: + OkModelingCmdResponse::EntityGetAllChildUuids(EntityGetAllChildUuids { entity_ids: child_ids }), + } = response + else { + return Err(KclError::Internal(KclErrorDetails { + message: "Expected a successful response from EntityGetAllChildUuids".to_string(), + source_ranges: vec![args.source_range], + })); + }; + + if child_ids.len() >= 2 { + // The first child is the original sketch, the second is the mirrored sketch. + let child_id = child_ids[1]; + sketch.mirror = Some(child_id); + } else { + return Err(KclError::Type(KclErrorDetails { + message: "Expected child uuids to be >= 2".to_string(), + source_ranges: vec![args.source_range], + })); + } + } + Ok(starting_sketches) } diff --git a/rust/kcl-lib/src/std/sketch.rs b/rust/kcl-lib/src/std/sketch.rs index 0ac7f87b2..998460d37 100644 --- a/rust/kcl-lib/src/std/sketch.rs +++ b/rust/kcl-lib/src/std/sketch.rs @@ -1343,6 +1343,7 @@ pub(crate) async fn inner_start_profile_at( on: sketch_surface.clone(), paths: vec![], units: sketch_surface.units(), + mirror: Default::default(), meta: vec![args.source_range.into()], tags: if let Some(tag) = &tag { let mut tag_identifier: TagIdentifier = tag.into(); diff --git a/rust/kcl-lib/std/sketch.kcl b/rust/kcl-lib/std/sketch.kcl index 4a85f6c85..761171d0e 100644 --- a/rust/kcl-lib/std/sketch.kcl +++ b/rust/kcl-lib/std/sketch.kcl @@ -96,6 +96,25 @@ export fn circle( /// /// example = extrude(sketch001, length = 10) /// ``` +/// +/// ``` +/// // Sketch on the face of a mirrored sketch, that has been extruded. +/// sketch0011 = startSketchOn(XY) +/// |> startProfileAt([6.77, 0], %) +/// |> yLine(length = 1.27) +/// |> tangentialArcTo([5.96, 2.37], %) +/// |> tangentialArcTo([-6.2, 2.44], %) +/// |> tangentialArcTo([-6.6, 1.82], %) +/// |> yLine(length = -1.82) +/// |> mirror2d( axis = X ) +/// |> extrude(length = 10) +/// +/// sketch002 = startSketchOn(sketch0011, 'END') +/// |> circle( center = [-0.01, 1.58], radius = 1.2 ) +/// |> extrude(length = 1.2) +/// +/// shell([sketch002], faces = ['end'], thickness = .1 ) +/// ``` @(impl = std_rust) export fn mirror2d( /// The sketch or sketches to be reflected. diff --git a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap index 82ddc2934..7e6f3108a 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/artifact_commands.snap @@ -209,6 +209,14 @@ description: Artifact commands i-beam.kcl } } }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "entity_get_all_child_uuids", + "entity_id": "[uuid]" + } + }, { "cmdId": "[uuid]", "range": [], @@ -229,6 +237,14 @@ description: Artifact commands i-beam.kcl } } }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "entity_get_all_child_uuids", + "entity_id": "[uuid]" + } + }, { "cmdId": "[uuid]", "range": [], @@ -278,5 +294,345 @@ description: Artifact commands i-beam.kcl "object_id": "[uuid]", "edge_id": "[uuid]" } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_opposite_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } + }, + { + "cmdId": "[uuid]", + "range": [], + "command": { + "type": "solid3d_get_next_adjacent_edge", + "object_id": "[uuid]", + "edge_id": "[uuid]", + "face_id": "[uuid]" + } } ] diff --git a/rust/kcl-lib/tests/kcl_samples/i-beam/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/i-beam/program_memory.snap index 08fc20534..a764460ad 100644 --- a/rust/kcl-lib/tests/kcl_samples/i-beam/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/i-beam/program_memory.snap @@ -215,8 +215,8 @@ description: Variables in memory after executing i-beam.kcl } }, "height": 72.00000000000001, - "startCapId": null, - "endCapId": null, + "startCapId": "[uuid]", + "endCapId": "[uuid]", "units": { "type": "Inches" } diff --git a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap index 0790ef76e..0da9dc682 100644 --- a/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/makeup-mirror/ast.snap @@ -423,10 +423,10 @@ description: Result of parsing makeup-mirror.kcl { "commentStart": 445, "declaration": { - "commentStart": 501, + "commentStart": 500, "end": 0, "id": { - "commentStart": 501, + "commentStart": 500, "end": 0, "name": "hingeFn", "start": 0, @@ -436,12 +436,12 @@ description: Result of parsing makeup-mirror.kcl "body": { "body": [ { - "commentStart": 522, + "commentStart": 521, "declaration": { - "commentStart": 522, + "commentStart": 521, "end": 0, "id": { - "commentStart": 522, + "commentStart": 521, "end": 0, "name": "hingeBody", "start": 0, @@ -456,7 +456,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 564, + "commentStart": 563, "end": 0, "name": "offset", "start": 0, @@ -464,10 +464,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 573, + "commentStart": 572, "end": 0, "name": { - "commentStart": 573, + "commentStart": 572, "end": 0, "name": "z", "start": 0, @@ -482,10 +482,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 548, + "commentStart": 547, "end": 0, "name": { - "commentStart": 548, + "commentStart": 547, "end": 0, "name": "offsetPlane", "start": 0, @@ -495,17 +495,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 548, + "commentStart": 547, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 560, + "commentStart": 559, "end": 0, "name": { - "commentStart": 560, + "commentStart": 559, "end": 0, "name": "XY", "start": 0, @@ -520,10 +520,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 534, + "commentStart": 533, "end": 0, "name": { - "commentStart": 534, + "commentStart": 533, "end": 0, "name": "startSketchOn", "start": 0, @@ -533,7 +533,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 534, + "commentStart": 533, "end": 0, "start": 0, "type": "CallExpression", @@ -544,21 +544,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 591, + "commentStart": 590, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 600, + "commentStart": 599, "elements": [ { "abs_path": false, - "commentStart": 601, + "commentStart": 600, "end": 0, "name": { - "commentStart": 601, + "commentStart": 600, "end": 0, "name": "x", "start": 0, @@ -571,10 +571,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 604, + "commentStart": 603, "end": 0, "name": { - "commentStart": 604, + "commentStart": 603, "end": 0, "name": "y", "start": 0, @@ -595,7 +595,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 608, + "commentStart": 607, "end": 0, "name": "radius", "start": 0, @@ -603,10 +603,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 617, + "commentStart": 616, "end": 0, "name": { - "commentStart": 617, + "commentStart": 616, "end": 0, "name": "hingeRadius", "start": 0, @@ -621,10 +621,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 584, + "commentStart": 583, "end": 0, "name": { - "commentStart": 584, + "commentStart": 583, "end": 0, "name": "circle", "start": 0, @@ -634,7 +634,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 584, + "commentStart": 583, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -646,7 +646,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 645, + "commentStart": 644, "end": 0, "name": "length", "start": 0, @@ -654,10 +654,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 654, + "commentStart": 653, "end": 0, "name": { - "commentStart": 654, + "commentStart": 653, "end": 0, "name": "hingeHeight", "start": 0, @@ -672,10 +672,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 637, + "commentStart": 636, "end": 0, "name": { - "commentStart": 637, + "commentStart": 636, "end": 0, "name": "extrude", "start": 0, @@ -685,7 +685,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 637, + "commentStart": 636, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -693,7 +693,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 534, + "commentStart": 533, "end": 0, "start": 0, "type": "PipeExpression", @@ -711,10 +711,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 676, + "commentStart": 675, "end": 0, "name": { - "commentStart": 676, + "commentStart": 675, "end": 0, "name": "hingeBody", "start": 0, @@ -725,24 +725,24 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 669, + "commentStart": 668, "end": 0, "start": 0, "type": "ReturnStatement", "type": "ReturnStatement" } ], - "commentStart": 518, + "commentStart": 517, "end": 0, "start": 0 }, - "commentStart": 508, + "commentStart": 507, "end": 0, "params": [ { "type": "Parameter", "identifier": { - "commentStart": 509, + "commentStart": 508, "end": 0, "name": "x", "start": 0, @@ -752,7 +752,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 512, + "commentStart": 511, "end": 0, "name": "y", "start": 0, @@ -762,7 +762,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 515, + "commentStart": 514, "end": 0, "name": "z", "start": 0, @@ -790,12 +790,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 687, + "commentStart": 686, "declaration": { - "commentStart": 689, + "commentStart": 688, "end": 0, "id": { - "commentStart": 689, + "commentStart": 688, "end": 0, "name": "hingePartA1", "start": 0, @@ -804,7 +804,7 @@ description: Result of parsing makeup-mirror.kcl "init": { "arguments": [ { - "commentStart": 711, + "commentStart": 710, "end": 0, "raw": "0", "start": 0, @@ -816,7 +816,7 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 714, + "commentStart": 713, "end": 0, "raw": "0", "start": 0, @@ -828,7 +828,7 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 717, + "commentStart": 716, "end": 0, "raw": "0", "start": 0, @@ -842,10 +842,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 703, + "commentStart": 702, "end": 0, "name": { - "commentStart": 703, + "commentStart": 702, "end": 0, "name": "hingeFn", "start": 0, @@ -855,7 +855,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 703, + "commentStart": 702, "end": 0, "start": 0, "type": "CallExpression", @@ -871,12 +871,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 720, + "commentStart": 719, "declaration": { - "commentStart": 720, + "commentStart": 719, "end": 0, "id": { - "commentStart": 720, + "commentStart": 719, "end": 0, "name": "hingePartA2", "start": 0, @@ -885,7 +885,7 @@ description: Result of parsing makeup-mirror.kcl "init": { "arguments": [ { - "commentStart": 742, + "commentStart": 741, "end": 0, "raw": "0", "start": 0, @@ -897,7 +897,7 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 745, + "commentStart": 744, "end": 0, "raw": "0", "start": 0, @@ -909,14 +909,14 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 748, + "commentStart": 747, "end": 0, "left": { "abs_path": false, - "commentStart": 748, + "commentStart": 747, "end": 0, "name": { - "commentStart": 748, + "commentStart": 747, "end": 0, "name": "hingeHeight", "start": 0, @@ -930,10 +930,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 762, + "commentStart": 761, "end": 0, "name": { - "commentStart": 762, + "commentStart": 761, "end": 0, "name": "hingeGap", "start": 0, @@ -951,10 +951,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 734, + "commentStart": 733, "end": 0, "name": { - "commentStart": 734, + "commentStart": 733, "end": 0, "name": "hingeFn", "start": 0, @@ -964,7 +964,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 734, + "commentStart": 733, "end": 0, "start": 0, "type": "CallExpression", @@ -980,12 +980,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 772, + "commentStart": 771, "declaration": { - "commentStart": 772, + "commentStart": 771, "end": 0, "id": { - "commentStart": 772, + "commentStart": 771, "end": 0, "name": "hingePartA3", "start": 0, @@ -994,7 +994,7 @@ description: Result of parsing makeup-mirror.kcl "init": { "arguments": [ { - "commentStart": 794, + "commentStart": 793, "end": 0, "raw": "0", "start": 0, @@ -1006,7 +1006,7 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 797, + "commentStart": 796, "end": 0, "raw": "0", "start": 0, @@ -1018,17 +1018,17 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 800, + "commentStart": 799, "end": 0, "left": { - "commentStart": 800, + "commentStart": 799, "end": 0, "left": { "abs_path": false, - "commentStart": 800, + "commentStart": 799, "end": 0, "name": { - "commentStart": 800, + "commentStart": 799, "end": 0, "name": "hingeHeight", "start": 0, @@ -1041,7 +1041,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 814, + "commentStart": 813, "end": 0, "raw": "2", "start": 0, @@ -1058,14 +1058,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 818, + "commentStart": 817, "end": 0, "left": { "abs_path": false, - "commentStart": 818, + "commentStart": 817, "end": 0, "name": { - "commentStart": 818, + "commentStart": 817, "end": 0, "name": "hingeGap", "start": 0, @@ -1078,7 +1078,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 829, + "commentStart": 828, "end": 0, "raw": "2", "start": 0, @@ -1100,10 +1100,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 786, + "commentStart": 785, "end": 0, "name": { - "commentStart": 786, + "commentStart": 785, "end": 0, "name": "hingeFn", "start": 0, @@ -1113,7 +1113,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 786, + "commentStart": 785, "end": 0, "start": 0, "type": "CallExpression", @@ -1129,12 +1129,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 831, + "commentStart": 830, "declaration": { - "commentStart": 833, + "commentStart": 832, "end": 0, "id": { - "commentStart": 833, + "commentStart": 832, "end": 0, "name": "hingePartB2", "start": 0, @@ -1144,10 +1144,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 855, + "commentStart": 854, "end": 0, "name": { - "commentStart": 855, + "commentStart": 854, "end": 0, "name": "armLength", "start": 0, @@ -1159,7 +1159,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 866, + "commentStart": 865, "end": 0, "raw": "0", "start": 0, @@ -1171,14 +1171,14 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 869, + "commentStart": 868, "end": 0, "left": { "abs_path": false, - "commentStart": 869, + "commentStart": 868, "end": 0, "name": { - "commentStart": 869, + "commentStart": 868, "end": 0, "name": "hingeHeight", "start": 0, @@ -1192,10 +1192,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 883, + "commentStart": 882, "end": 0, "name": { - "commentStart": 883, + "commentStart": 882, "end": 0, "name": "hingeGap", "start": 0, @@ -1213,10 +1213,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 847, + "commentStart": 846, "end": 0, "name": { - "commentStart": 847, + "commentStart": 846, "end": 0, "name": "hingeFn", "start": 0, @@ -1226,7 +1226,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 847, + "commentStart": 846, "end": 0, "start": 0, "type": "CallExpression", @@ -1242,12 +1242,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 893, + "commentStart": 892, "declaration": { - "commentStart": 893, + "commentStart": 892, "end": 0, "id": { - "commentStart": 893, + "commentStart": 892, "end": 0, "name": "hingePartB3", "start": 0, @@ -1257,10 +1257,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 915, + "commentStart": 914, "end": 0, "name": { - "commentStart": 915, + "commentStart": 914, "end": 0, "name": "armLength", "start": 0, @@ -1272,7 +1272,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 926, + "commentStart": 925, "end": 0, "raw": "0", "start": 0, @@ -1284,17 +1284,17 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 929, + "commentStart": 928, "end": 0, "left": { - "commentStart": 929, + "commentStart": 928, "end": 0, "left": { "abs_path": false, - "commentStart": 929, + "commentStart": 928, "end": 0, "name": { - "commentStart": 929, + "commentStart": 928, "end": 0, "name": "hingeHeight", "start": 0, @@ -1307,7 +1307,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 943, + "commentStart": 942, "end": 0, "raw": "2", "start": 0, @@ -1324,14 +1324,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 947, + "commentStart": 946, "end": 0, "left": { "abs_path": false, - "commentStart": 947, + "commentStart": 946, "end": 0, "name": { - "commentStart": 947, + "commentStart": 946, "end": 0, "name": "hingeGap", "start": 0, @@ -1344,7 +1344,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 958, + "commentStart": 957, "end": 0, "raw": "2", "start": 0, @@ -1366,10 +1366,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 907, + "commentStart": 906, "end": 0, "name": { - "commentStart": 907, + "commentStart": 906, "end": 0, "name": "hingeFn", "start": 0, @@ -1379,7 +1379,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 907, + "commentStart": 906, "end": 0, "start": 0, "type": "CallExpression", @@ -1395,12 +1395,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 960, + "commentStart": 959, "declaration": { - "commentStart": 962, + "commentStart": 961, "end": 0, "id": { - "commentStart": 962, + "commentStart": 961, "end": 0, "name": "hingePartC2", "start": 0, @@ -1410,10 +1410,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 984, + "commentStart": 983, "end": 0, "name": { - "commentStart": 984, + "commentStart": 983, "end": 0, "name": "armLength", "start": 0, @@ -1427,10 +1427,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 996, + "commentStart": 995, "end": 0, "name": { - "commentStart": 996, + "commentStart": 995, "end": 0, "name": "armLength", "start": 0, @@ -1441,7 +1441,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 995, + "commentStart": 994, "end": 0, "operator": "-", "start": 0, @@ -1449,17 +1449,17 @@ description: Result of parsing makeup-mirror.kcl "type": "UnaryExpression" }, { - "commentStart": 1007, + "commentStart": 1006, "end": 0, "left": { - "commentStart": 1007, + "commentStart": 1006, "end": 0, "left": { "abs_path": false, - "commentStart": 1007, + "commentStart": 1006, "end": 0, "name": { - "commentStart": 1007, + "commentStart": 1006, "end": 0, "name": "hingeHeight", "start": 0, @@ -1472,7 +1472,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1021, + "commentStart": 1020, "end": 0, "raw": "2", "start": 0, @@ -1489,14 +1489,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 1025, + "commentStart": 1024, "end": 0, "left": { "abs_path": false, - "commentStart": 1025, + "commentStart": 1024, "end": 0, "name": { - "commentStart": 1025, + "commentStart": 1024, "end": 0, "name": "hingeGap", "start": 0, @@ -1509,7 +1509,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1036, + "commentStart": 1035, "end": 0, "raw": "2", "start": 0, @@ -1531,10 +1531,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 976, + "commentStart": 975, "end": 0, "name": { - "commentStart": 976, + "commentStart": 975, "end": 0, "name": "hingeFn", "start": 0, @@ -1544,7 +1544,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 976, + "commentStart": 975, "end": 0, "start": 0, "type": "CallExpression", @@ -1560,12 +1560,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1039, + "commentStart": 1038, "declaration": { - "commentStart": 1039, + "commentStart": 1038, "end": 0, "id": { - "commentStart": 1039, + "commentStart": 1038, "end": 0, "name": "hingePartC3", "start": 0, @@ -1575,10 +1575,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 1061, + "commentStart": 1060, "end": 0, "name": { - "commentStart": 1061, + "commentStart": 1060, "end": 0, "name": "armLength", "start": 0, @@ -1592,10 +1592,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 1073, + "commentStart": 1072, "end": 0, "name": { - "commentStart": 1073, + "commentStart": 1072, "end": 0, "name": "armLength", "start": 0, @@ -1606,7 +1606,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 1072, + "commentStart": 1071, "end": 0, "operator": "-", "start": 0, @@ -1614,17 +1614,17 @@ description: Result of parsing makeup-mirror.kcl "type": "UnaryExpression" }, { - "commentStart": 1084, + "commentStart": 1083, "end": 0, "left": { - "commentStart": 1084, + "commentStart": 1083, "end": 0, "left": { "abs_path": false, - "commentStart": 1084, + "commentStart": 1083, "end": 0, "name": { - "commentStart": 1084, + "commentStart": 1083, "end": 0, "name": "hingeHeight", "start": 0, @@ -1637,7 +1637,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1098, + "commentStart": 1097, "end": 0, "raw": "3", "start": 0, @@ -1654,14 +1654,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 1102, + "commentStart": 1101, "end": 0, "left": { "abs_path": false, - "commentStart": 1102, + "commentStart": 1101, "end": 0, "name": { - "commentStart": 1102, + "commentStart": 1101, "end": 0, "name": "hingeGap", "start": 0, @@ -1674,7 +1674,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1113, + "commentStart": 1112, "end": 0, "raw": "3", "start": 0, @@ -1696,10 +1696,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1053, + "commentStart": 1052, "end": 0, "name": { - "commentStart": 1053, + "commentStart": 1052, "end": 0, "name": "hingeFn", "start": 0, @@ -1709,7 +1709,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1053, + "commentStart": 1052, "end": 0, "start": 0, "type": "CallExpression", @@ -1725,12 +1725,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1115, + "commentStart": 1114, "declaration": { - "commentStart": 1156, + "commentStart": 1155, "end": 0, "id": { - "commentStart": 1156, + "commentStart": 1155, "end": 0, "name": "armFn", "start": 0, @@ -1740,12 +1740,12 @@ description: Result of parsing makeup-mirror.kcl "body": { "body": [ { - "commentStart": 1191, + "commentStart": 1190, "declaration": { - "commentStart": 1191, + "commentStart": 1190, "end": 0, "id": { - "commentStart": 1191, + "commentStart": 1190, "end": 0, "name": "armBody", "start": 0, @@ -1757,10 +1757,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 1215, + "commentStart": 1214, "end": 0, "name": { - "commentStart": 1215, + "commentStart": 1214, "end": 0, "name": "plane", "start": 0, @@ -1774,10 +1774,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1201, + "commentStart": 1200, "end": 0, "name": { - "commentStart": 1201, + "commentStart": 1200, "end": 0, "name": "startSketchOn", "start": 0, @@ -1787,7 +1787,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1201, + "commentStart": 1200, "end": 0, "start": 0, "type": "CallExpression", @@ -1798,21 +1798,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1236, + "commentStart": 1235, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1245, + "commentStart": 1244, "elements": [ { "abs_path": false, - "commentStart": 1246, + "commentStart": 1245, "end": 0, "name": { - "commentStart": 1246, + "commentStart": 1245, "end": 0, "name": "offset", "start": 0, @@ -1825,10 +1825,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1254, + "commentStart": 1253, "end": 0, "name": { - "commentStart": 1254, + "commentStart": 1253, "end": 0, "name": "altitude", "start": 0, @@ -1849,7 +1849,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1265, + "commentStart": 1264, "end": 0, "name": "radius", "start": 0, @@ -1857,10 +1857,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1274, + "commentStart": 1273, "end": 0, "name": { - "commentStart": 1274, + "commentStart": 1273, "end": 0, "name": "armRadius", "start": 0, @@ -1875,10 +1875,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1229, + "commentStart": 1228, "end": 0, "name": { - "commentStart": 1229, + "commentStart": 1228, "end": 0, "name": "circle", "start": 0, @@ -1888,7 +1888,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1229, + "commentStart": 1228, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1900,7 +1900,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1300, + "commentStart": 1299, "end": 0, "name": "length", "start": 0, @@ -1908,10 +1908,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1309, + "commentStart": 1308, "end": 0, "name": { - "commentStart": 1309, + "commentStart": 1308, "end": 0, "name": "armLength", "start": 0, @@ -1926,10 +1926,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1292, + "commentStart": 1291, "end": 0, "name": { - "commentStart": 1292, + "commentStart": 1291, "end": 0, "name": "extrude", "start": 0, @@ -1939,7 +1939,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1292, + "commentStart": 1291, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -1947,7 +1947,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 1201, + "commentStart": 1200, "end": 0, "start": 0, "type": "PipeExpression", @@ -1965,10 +1965,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 1329, + "commentStart": 1328, "end": 0, "name": { - "commentStart": 1329, + "commentStart": 1328, "end": 0, "name": "armBody", "start": 0, @@ -1979,24 +1979,24 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 1322, + "commentStart": 1321, "end": 0, "start": 0, "type": "ReturnStatement", "type": "ReturnStatement" } ], - "commentStart": 1187, + "commentStart": 1186, "end": 0, "start": 0 }, - "commentStart": 1161, + "commentStart": 1160, "end": 0, "params": [ { "type": "Parameter", "identifier": { - "commentStart": 1162, + "commentStart": 1161, "end": 0, "name": "plane", "start": 0, @@ -2006,7 +2006,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1169, + "commentStart": 1168, "end": 0, "name": "offset", "start": 0, @@ -2016,7 +2016,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1177, + "commentStart": 1176, "end": 0, "name": "altitude", "start": 0, @@ -2043,12 +2043,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1338, + "commentStart": 1337, "declaration": { - "commentStart": 1340, + "commentStart": 1339, "end": 0, "id": { - "commentStart": 1340, + "commentStart": 1339, "end": 0, "name": "armPartA", "start": 0, @@ -2058,10 +2058,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 1357, + "commentStart": 1356, "end": 0, "name": { - "commentStart": 1357, + "commentStart": 1356, "end": 0, "name": "YZ", "start": 0, @@ -2073,7 +2073,7 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 1361, + "commentStart": 1360, "end": 0, "raw": "0", "start": 0, @@ -2085,17 +2085,17 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 1364, + "commentStart": 1363, "end": 0, "left": { - "commentStart": 1364, + "commentStart": 1363, "end": 0, "left": { "abs_path": false, - "commentStart": 1364, + "commentStart": 1363, "end": 0, "name": { - "commentStart": 1364, + "commentStart": 1363, "end": 0, "name": "hingeHeight", "start": 0, @@ -2108,7 +2108,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1378, + "commentStart": 1377, "end": 0, "raw": "1.5", "start": 0, @@ -2126,10 +2126,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1384, + "commentStart": 1383, "end": 0, "name": { - "commentStart": 1384, + "commentStart": 1383, "end": 0, "name": "hingeGap", "start": 0, @@ -2147,10 +2147,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1351, + "commentStart": 1350, "end": 0, "name": { - "commentStart": 1351, + "commentStart": 1350, "end": 0, "name": "armFn", "start": 0, @@ -2160,7 +2160,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1351, + "commentStart": 1350, "end": 0, "start": 0, "type": "CallExpression", @@ -2176,12 +2176,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1394, + "commentStart": 1393, "declaration": { - "commentStart": 1394, + "commentStart": 1393, "end": 0, "id": { - "commentStart": 1394, + "commentStart": 1393, "end": 0, "name": "armPartB", "start": 0, @@ -2191,10 +2191,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 1411, + "commentStart": 1410, "end": 0, "name": { - "commentStart": 1411, + "commentStart": 1410, "end": 0, "name": "XZ", "start": 0, @@ -2207,10 +2207,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1415, + "commentStart": 1414, "end": 0, "name": { - "commentStart": 1415, + "commentStart": 1414, "end": 0, "name": "armLength", "start": 0, @@ -2222,17 +2222,17 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 1426, + "commentStart": 1425, "end": 0, "left": { - "commentStart": 1426, + "commentStart": 1425, "end": 0, "left": { "abs_path": false, - "commentStart": 1426, + "commentStart": 1425, "end": 0, "name": { - "commentStart": 1426, + "commentStart": 1425, "end": 0, "name": "hingeHeight", "start": 0, @@ -2245,7 +2245,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1440, + "commentStart": 1439, "end": 0, "raw": "2.5", "start": 0, @@ -2262,14 +2262,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 1446, + "commentStart": 1445, "end": 0, "left": { "abs_path": false, - "commentStart": 1446, + "commentStart": 1445, "end": 0, "name": { - "commentStart": 1446, + "commentStart": 1445, "end": 0, "name": "hingeGap", "start": 0, @@ -2282,7 +2282,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 1457, + "commentStart": 1456, "end": 0, "raw": "2", "start": 0, @@ -2304,10 +2304,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1405, + "commentStart": 1404, "end": 0, "name": { - "commentStart": 1405, + "commentStart": 1404, "end": 0, "name": "armFn", "start": 0, @@ -2317,7 +2317,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1405, + "commentStart": 1404, "end": 0, "start": 0, "type": "CallExpression", @@ -2333,12 +2333,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1459, + "commentStart": 1458, "declaration": { - "commentStart": 1503, + "commentStart": 1502, "end": 0, "id": { - "commentStart": 1503, + "commentStart": 1502, "end": 0, "name": "mirrorFn", "start": 0, @@ -2348,12 +2348,12 @@ description: Result of parsing makeup-mirror.kcl "body": { "body": [ { - "commentStart": 1586, + "commentStart": 1585, "declaration": { - "commentStart": 1586, + "commentStart": 1585, "end": 0, "id": { - "commentStart": 1586, + "commentStart": 1585, "end": 0, "name": "armPlane", "start": 0, @@ -2366,21 +2366,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1632, + "commentStart": 1631, "end": 0, "name": "offset", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1641, + "commentStart": 1640, "end": 0, "left": { "abs_path": false, - "commentStart": 1641, + "commentStart": 1640, "end": 0, "name": { - "commentStart": 1641, + "commentStart": 1640, "end": 0, "name": "offsetY", "start": 0, @@ -2393,14 +2393,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "-", "right": { - "commentStart": 1652, + "commentStart": 1651, "end": 0, "left": { "abs_path": false, - "commentStart": 1652, + "commentStart": 1651, "end": 0, "name": { - "commentStart": 1652, + "commentStart": 1651, "end": 0, "name": "tiefe", "start": 0, @@ -2413,7 +2413,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "/", "right": { - "commentStart": 1660, + "commentStart": 1659, "end": 0, "raw": "2", "start": 0, @@ -2436,10 +2436,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1613, + "commentStart": 1612, "end": 0, "name": { - "commentStart": 1613, + "commentStart": 1612, "end": 0, "name": "offsetPlane", "start": 0, @@ -2449,17 +2449,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1613, + "commentStart": 1612, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1625, + "commentStart": 1624, "end": 0, "name": { - "commentStart": 1625, + "commentStart": 1624, "end": 0, "name": "plane", "start": 0, @@ -2474,10 +2474,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1597, + "commentStart": 1596, "end": 0, "name": { - "commentStart": 1597, + "commentStart": 1596, "end": 0, "name": "startSketchOn", "start": 0, @@ -2487,7 +2487,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1597, + "commentStart": 1596, "end": 0, "start": 0, "type": "CallExpression", @@ -2503,12 +2503,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1667, + "commentStart": 1666, "declaration": { - "commentStart": 1667, + "commentStart": 1666, "end": 0, "id": { - "commentStart": 1667, + "commentStart": 1666, "end": 0, "name": "armBody", "start": 0, @@ -2521,21 +2521,21 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1694, + "commentStart": 1693, "end": 0, "name": "center", "start": 0, "type": "Identifier" }, "arg": { - "commentStart": 1703, + "commentStart": 1702, "elements": [ { "abs_path": false, - "commentStart": 1704, + "commentStart": 1703, "end": 0, "name": { - "commentStart": 1704, + "commentStart": 1703, "end": 0, "name": "offsetX", "start": 0, @@ -2548,10 +2548,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1713, + "commentStart": 1712, "end": 0, "name": { - "commentStart": 1713, + "commentStart": 1712, "end": 0, "name": "altitude", "start": 0, @@ -2572,7 +2572,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1724, + "commentStart": 1723, "end": 0, "name": "radius", "start": 0, @@ -2580,10 +2580,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1733, + "commentStart": 1732, "end": 0, "name": { - "commentStart": 1733, + "commentStart": 1732, "end": 0, "name": "radius", "start": 0, @@ -2598,10 +2598,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1677, + "commentStart": 1676, "end": 0, "name": { - "commentStart": 1677, + "commentStart": 1676, "end": 0, "name": "circle", "start": 0, @@ -2611,17 +2611,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1677, + "commentStart": 1676, "end": 0, "start": 0, "type": "CallExpressionKw", "type": "CallExpressionKw", "unlabeled": { "abs_path": false, - "commentStart": 1684, + "commentStart": 1683, "end": 0, "name": { - "commentStart": 1684, + "commentStart": 1683, "end": 0, "name": "armPlane", "start": 0, @@ -2638,7 +2638,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1756, + "commentStart": 1755, "end": 0, "name": "length", "start": 0, @@ -2646,10 +2646,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1765, + "commentStart": 1764, "end": 0, "name": { - "commentStart": 1765, + "commentStart": 1764, "end": 0, "name": "tiefe", "start": 0, @@ -2664,10 +2664,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1748, + "commentStart": 1747, "end": 0, "name": { - "commentStart": 1748, + "commentStart": 1747, "end": 0, "name": "extrude", "start": 0, @@ -2677,7 +2677,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1748, + "commentStart": 1747, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2685,7 +2685,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 1677, + "commentStart": 1676, "end": 0, "start": 0, "type": "PipeExpression", @@ -2701,12 +2701,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 1771, + "commentStart": 1770, "declaration": { - "commentStart": 1775, + "commentStart": 1774, "end": 0, "id": { - "commentStart": 1775, + "commentStart": 1774, "end": 0, "name": "archBody", "start": 0, @@ -2717,17 +2717,17 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 1801, + "commentStart": 1800, "elements": [ { - "commentStart": 1802, + "commentStart": 1801, "end": 0, "left": { "abs_path": false, - "commentStart": 1802, + "commentStart": 1801, "end": 0, "name": { - "commentStart": 1802, + "commentStart": 1801, "end": 0, "name": "offsetX", "start": 0, @@ -2741,10 +2741,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1812, + "commentStart": 1811, "end": 0, "name": { - "commentStart": 1812, + "commentStart": 1811, "end": 0, "name": "gestellR", "start": 0, @@ -2761,10 +2761,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1822, + "commentStart": 1821, "end": 0, "name": { - "commentStart": 1822, + "commentStart": 1821, "end": 0, "name": "altitude", "start": 0, @@ -2783,10 +2783,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1833, + "commentStart": 1832, "end": 0, "name": { - "commentStart": 1833, + "commentStart": 1832, "end": 0, "name": "armPlane", "start": 0, @@ -2800,10 +2800,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1786, + "commentStart": 1785, "end": 0, "name": { - "commentStart": 1786, + "commentStart": 1785, "end": 0, "name": "startProfileAt", "start": 0, @@ -2813,7 +2813,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1786, + "commentStart": 1785, "end": 0, "start": 0, "type": "CallExpression", @@ -2824,7 +2824,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 1856, + "commentStart": 1855, "end": 0, "name": "length", "start": 0, @@ -2832,10 +2832,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 1865, + "commentStart": 1864, "end": 0, "name": { - "commentStart": 1865, + "commentStart": 1864, "end": 0, "name": "gestellD", "start": 0, @@ -2850,10 +2850,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1850, + "commentStart": 1849, "end": 0, "name": { - "commentStart": 1850, + "commentStart": 1849, "end": 0, "name": "xLine", "start": 0, @@ -2863,7 +2863,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1850, + "commentStart": 1849, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -2873,14 +2873,14 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 1888, + "commentStart": 1887, "end": 0, "properties": [ { - "commentStart": 1899, + "commentStart": 1898, "end": 0, "key": { - "commentStart": 1899, + "commentStart": 1898, "end": 0, "name": "interior", "start": 0, @@ -2889,14 +2889,14 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1910, + "commentStart": 1909, "elements": [ { "abs_path": false, - "commentStart": 1911, + "commentStart": 1910, "end": 0, "name": { - "commentStart": 1911, + "commentStart": 1910, "end": 0, "name": "offsetX", "start": 0, @@ -2908,14 +2908,14 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 1920, + "commentStart": 1919, "end": 0, "left": { "abs_path": false, - "commentStart": 1920, + "commentStart": 1919, "end": 0, "name": { - "commentStart": 1920, + "commentStart": 1919, "end": 0, "name": "altitude", "start": 0, @@ -2929,10 +2929,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 1931, + "commentStart": 1930, "end": 0, "name": { - "commentStart": 1931, + "commentStart": 1930, "end": 0, "name": "gestellR", "start": 0, @@ -2955,10 +2955,10 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 1951, + "commentStart": 1950, "end": 0, "key": { - "commentStart": 1951, + "commentStart": 1950, "end": 0, "name": "end", "start": 0, @@ -2967,17 +2967,17 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 1957, + "commentStart": 1956, "elements": [ { - "commentStart": 1958, + "commentStart": 1957, "end": 0, "left": { "abs_path": false, - "commentStart": 1958, + "commentStart": 1957, "end": 0, "name": { - "commentStart": 1958, + "commentStart": 1957, "end": 0, "name": "offsetX", "start": 0, @@ -2991,10 +2991,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 1968, + "commentStart": 1967, "end": 0, "name": { - "commentStart": 1968, + "commentStart": 1967, "end": 0, "name": "gestellR", "start": 0, @@ -3011,10 +3011,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 1978, + "commentStart": 1977, "end": 0, "name": { - "commentStart": 1978, + "commentStart": 1977, "end": 0, "name": "altitude", "start": 0, @@ -3038,7 +3038,7 @@ description: Result of parsing makeup-mirror.kcl "type": "ObjectExpression" }, { - "commentStart": 1998, + "commentStart": 1997, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3047,10 +3047,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 1882, + "commentStart": 1881, "end": 0, "name": { - "commentStart": 1882, + "commentStart": 1881, "end": 0, "name": "arcTo", "start": 0, @@ -3060,7 +3060,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 1882, + "commentStart": 1881, "end": 0, "start": 0, "type": "CallExpression", @@ -3071,7 +3071,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 2014, + "commentStart": 2013, "end": 0, "name": "length", "start": 0, @@ -3079,10 +3079,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 2023, + "commentStart": 2022, "end": 0, "name": { - "commentStart": 2023, + "commentStart": 2022, "end": 0, "name": "gestellD", "start": 0, @@ -3097,10 +3097,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2008, + "commentStart": 2007, "end": 0, "name": { - "commentStart": 2008, + "commentStart": 2007, "end": 0, "name": "xLine", "start": 0, @@ -3110,7 +3110,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2008, + "commentStart": 2007, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3120,14 +3120,14 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 2046, + "commentStart": 2045, "end": 0, "properties": [ { - "commentStart": 2057, + "commentStart": 2056, "end": 0, "key": { - "commentStart": 2057, + "commentStart": 2056, "end": 0, "name": "interior", "start": 0, @@ -3136,14 +3136,14 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 2068, + "commentStart": 2067, "elements": [ { "abs_path": false, - "commentStart": 2081, + "commentStart": 2080, "end": 0, "name": { - "commentStart": 2081, + "commentStart": 2080, "end": 0, "name": "offsetX", "start": 0, @@ -3155,17 +3155,17 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 2101, + "commentStart": 2100, "end": 0, "left": { - "commentStart": 2101, + "commentStart": 2100, "end": 0, "left": { "abs_path": false, - "commentStart": 2101, + "commentStart": 2100, "end": 0, "name": { - "commentStart": 2101, + "commentStart": 2100, "end": 0, "name": "altitude", "start": 0, @@ -3179,10 +3179,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 2112, + "commentStart": 2111, "end": 0, "name": { - "commentStart": 2112, + "commentStart": 2111, "end": 0, "name": "gestellR", "start": 0, @@ -3200,10 +3200,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "-", "right": { "abs_path": false, - "commentStart": 2123, + "commentStart": 2122, "end": 0, "name": { - "commentStart": 2123, + "commentStart": 2122, "end": 0, "name": "gestellD", "start": 0, @@ -3226,10 +3226,10 @@ description: Result of parsing makeup-mirror.kcl } }, { - "commentStart": 2153, + "commentStart": 2152, "end": 0, "key": { - "commentStart": 2153, + "commentStart": 2152, "end": 0, "name": "end", "start": 0, @@ -3238,12 +3238,12 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "ObjectProperty", "value": { - "commentStart": 2159, + "commentStart": 2158, "elements": [ { "arguments": [ { - "commentStart": 2174, + "commentStart": 2173, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3252,10 +3252,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2160, + "commentStart": 2159, "end": 0, "name": { - "commentStart": 2160, + "commentStart": 2159, "end": 0, "name": "profileStartX", "start": 0, @@ -3265,7 +3265,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2160, + "commentStart": 2159, "end": 0, "start": 0, "type": "CallExpression", @@ -3274,7 +3274,7 @@ description: Result of parsing makeup-mirror.kcl { "arguments": [ { - "commentStart": 2192, + "commentStart": 2191, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3283,10 +3283,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2178, + "commentStart": 2177, "end": 0, "name": { - "commentStart": 2178, + "commentStart": 2177, "end": 0, "name": "profileStartY", "start": 0, @@ -3296,7 +3296,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2178, + "commentStart": 2177, "end": 0, "start": 0, "type": "CallExpression", @@ -3315,7 +3315,7 @@ description: Result of parsing makeup-mirror.kcl "type": "ObjectExpression" }, { - "commentStart": 2206, + "commentStart": 2205, "end": 0, "start": 0, "type": "PipeSubstitution", @@ -3324,10 +3324,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2040, + "commentStart": 2039, "end": 0, "name": { - "commentStart": 2040, + "commentStart": 2039, "end": 0, "name": "arcTo", "start": 0, @@ -3337,7 +3337,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2040, + "commentStart": 2039, "end": 0, "start": 0, "type": "CallExpression", @@ -3347,10 +3347,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [], "callee": { "abs_path": false, - "commentStart": 2216, + "commentStart": 2215, "end": 0, "name": { - "commentStart": 2216, + "commentStart": 2215, "end": 0, "name": "close", "start": 0, @@ -3360,7 +3360,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2216, + "commentStart": 2215, "end": 0, "start": 0, "type": "CallExpression", @@ -3371,7 +3371,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "LabeledArg", "label": { - "commentStart": 2239, + "commentStart": 2238, "end": 0, "name": "length", "start": 0, @@ -3379,10 +3379,10 @@ description: Result of parsing makeup-mirror.kcl }, "arg": { "abs_path": false, - "commentStart": 2248, + "commentStart": 2247, "end": 0, "name": { - "commentStart": 2248, + "commentStart": 2247, "end": 0, "name": "tiefe", "start": 0, @@ -3397,10 +3397,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2231, + "commentStart": 2230, "end": 0, "name": { - "commentStart": 2231, + "commentStart": 2230, "end": 0, "name": "extrude", "start": 0, @@ -3410,7 +3410,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2231, + "commentStart": 2230, "end": 0, "start": 0, "type": "CallExpressionKw", @@ -3418,7 +3418,7 @@ description: Result of parsing makeup-mirror.kcl "unlabeled": null } ], - "commentStart": 1786, + "commentStart": 1785, "end": 0, "start": 0, "type": "PipeExpression", @@ -3436,10 +3436,10 @@ description: Result of parsing makeup-mirror.kcl { "argument": { "abs_path": false, - "commentStart": 2264, + "commentStart": 2263, "end": 0, "name": { - "commentStart": 2264, + "commentStart": 2263, "end": 0, "name": "armBody", "start": 0, @@ -3450,20 +3450,20 @@ description: Result of parsing makeup-mirror.kcl "type": "Name", "type": "Name" }, - "commentStart": 2257, + "commentStart": 2256, "end": 0, "start": 0, "type": "ReturnStatement", "type": "ReturnStatement" } ], - "commentStart": 1582, + "commentStart": 1581, "end": 0, "nonCodeMeta": { "nonCodeNodes": { "1": [ { - "commentStart": 1771, + "commentStart": 1770, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3477,13 +3477,13 @@ description: Result of parsing makeup-mirror.kcl }, "start": 0 }, - "commentStart": 1511, + "commentStart": 1510, "end": 0, "params": [ { "type": "Parameter", "identifier": { - "commentStart": 1512, + "commentStart": 1511, "end": 0, "name": "plane", "start": 0, @@ -3493,7 +3493,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1519, + "commentStart": 1518, "end": 0, "name": "offsetX", "start": 0, @@ -3503,7 +3503,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1528, + "commentStart": 1527, "end": 0, "name": "offsetY", "start": 0, @@ -3513,7 +3513,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1537, + "commentStart": 1536, "end": 0, "name": "altitude", "start": 0, @@ -3523,7 +3523,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1547, + "commentStart": 1546, "end": 0, "name": "radius", "start": 0, @@ -3533,7 +3533,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1555, + "commentStart": 1554, "end": 0, "name": "tiefe", "start": 0, @@ -3543,7 +3543,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1562, + "commentStart": 1561, "end": 0, "name": "gestellR", "start": 0, @@ -3553,7 +3553,7 @@ description: Result of parsing makeup-mirror.kcl { "type": "Parameter", "identifier": { - "commentStart": 1572, + "commentStart": 1571, "end": 0, "name": "gestellD", "start": 0, @@ -3580,12 +3580,12 @@ description: Result of parsing makeup-mirror.kcl "type": "VariableDeclaration" }, { - "commentStart": 2273, + "commentStart": 2272, "declaration": { - "commentStart": 2275, + "commentStart": 2274, "end": 0, "id": { - "commentStart": 2275, + "commentStart": 2274, "end": 0, "name": "mirror", "start": 0, @@ -3595,10 +3595,10 @@ description: Result of parsing makeup-mirror.kcl "arguments": [ { "abs_path": false, - "commentStart": 2293, + "commentStart": 2292, "end": 0, "name": { - "commentStart": 2293, + "commentStart": 2292, "end": 0, "name": "XZ", "start": 0, @@ -3611,10 +3611,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2297, + "commentStart": 2296, "end": 0, "name": { - "commentStart": 2297, + "commentStart": 2296, "end": 0, "name": "armLength", "start": 0, @@ -3627,10 +3627,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2308, + "commentStart": 2307, "end": 0, "name": { - "commentStart": 2308, + "commentStart": 2307, "end": 0, "name": "armLength", "start": 0, @@ -3642,26 +3642,26 @@ description: Result of parsing makeup-mirror.kcl "type": "Name" }, { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "left": { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "left": { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "left": { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "left": { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "left": { "abs_path": false, - "commentStart": 2319, + "commentStart": 2318, "end": 0, "name": { - "commentStart": 2319, + "commentStart": 2318, "end": 0, "name": "hingeHeight", "start": 0, @@ -3674,7 +3674,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 2333, + "commentStart": 2332, "end": 0, "raw": "4", "start": 0, @@ -3691,14 +3691,14 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "+", "right": { - "commentStart": 2337, + "commentStart": 2336, "end": 0, "left": { "abs_path": false, - "commentStart": 2337, + "commentStart": 2336, "end": 0, "name": { - "commentStart": 2337, + "commentStart": 2336, "end": 0, "name": "hingeGap", "start": 0, @@ -3711,7 +3711,7 @@ description: Result of parsing makeup-mirror.kcl }, "operator": "*", "right": { - "commentStart": 2348, + "commentStart": 2347, "end": 0, "raw": "3", "start": 0, @@ -3733,10 +3733,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2352, + "commentStart": 2351, "end": 0, "name": { - "commentStart": 2352, + "commentStart": 2351, "end": 0, "name": "mirrorRadius", "start": 0, @@ -3754,10 +3754,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2367, + "commentStart": 2366, "end": 0, "name": { - "commentStart": 2367, + "commentStart": 2366, "end": 0, "name": "archToMirrorGap", "start": 0, @@ -3775,10 +3775,10 @@ description: Result of parsing makeup-mirror.kcl "operator": "+", "right": { "abs_path": false, - "commentStart": 2385, + "commentStart": 2384, "end": 0, "name": { - "commentStart": 2385, + "commentStart": 2384, "end": 0, "name": "archThickness", "start": 0, @@ -3795,10 +3795,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2400, + "commentStart": 2399, "end": 0, "name": { - "commentStart": 2400, + "commentStart": 2399, "end": 0, "name": "mirrorRadius", "start": 0, @@ -3811,10 +3811,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2414, + "commentStart": 2413, "end": 0, "name": { - "commentStart": 2414, + "commentStart": 2413, "end": 0, "name": "mirrorThickness", "start": 0, @@ -3827,10 +3827,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2431, + "commentStart": 2430, "end": 0, "name": { - "commentStart": 2431, + "commentStart": 2430, "end": 0, "name": "archRadius", "start": 0, @@ -3843,10 +3843,10 @@ description: Result of parsing makeup-mirror.kcl }, { "abs_path": false, - "commentStart": 2443, + "commentStart": 2442, "end": 0, "name": { - "commentStart": 2443, + "commentStart": 2442, "end": 0, "name": "archThickness", "start": 0, @@ -3860,10 +3860,10 @@ description: Result of parsing makeup-mirror.kcl ], "callee": { "abs_path": false, - "commentStart": 2284, + "commentStart": 2283, "end": 0, "name": { - "commentStart": 2284, + "commentStart": 2283, "end": 0, "name": "mirrorFn", "start": 0, @@ -3873,7 +3873,7 @@ description: Result of parsing makeup-mirror.kcl "start": 0, "type": "Name" }, - "commentStart": 2284, + "commentStart": 2283, "end": 0, "start": 0, "type": "CallExpression", @@ -3948,7 +3948,7 @@ description: Result of parsing makeup-mirror.kcl "nonCodeNodes": { "10": [ { - "commentStart": 687, + "commentStart": 686, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3959,7 +3959,7 @@ description: Result of parsing makeup-mirror.kcl ], "13": [ { - "commentStart": 831, + "commentStart": 830, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3970,7 +3970,7 @@ description: Result of parsing makeup-mirror.kcl ], "15": [ { - "commentStart": 960, + "commentStart": 959, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3981,7 +3981,7 @@ description: Result of parsing makeup-mirror.kcl ], "18": [ { - "commentStart": 1338, + "commentStart": 1337, "end": 0, "start": 0, "type": "NonCodeNode", @@ -3992,7 +3992,7 @@ description: Result of parsing makeup-mirror.kcl ], "21": [ { - "commentStart": 2273, + "commentStart": 2272, "end": 0, "start": 0, "type": "NonCodeNode", diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d4.png b/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d4.png new file mode 100644 index 0000000000000000000000000000000000000000..a7d238da759bde879a5ddc60538e720397280b0f GIT binary patch literal 79782 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%0DJu^|-K(V^?&GH39C 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 literal 0 HcmV?d00001