From f99e44e3717f19f28269ceca4d5a32279a78c52b Mon Sep 17 00:00:00 2001 From: Adam Chalmers Date: Tue, 22 Apr 2025 12:44:52 -0500 Subject: [PATCH] Kwargs: assert functions (#6406) Closes https://github.com/KittyCAD/modeling-app/issues/6408 --- docs/kcl/assert.md | 40 +- docs/kcl/assertIs.md | 40 + docs/kcl/index.md | 6 +- docs/kcl/int.md | 2 +- docs/kcl/pop.md | 21 +- docs/kcl/push.md | 7 +- docs/kcl/reduce.md | 18 +- docs/kcl/rem.md | 12 +- docs/kcl/std.json | 567 +++---- public/kcl-samples/bracket/main.kcl | 8 +- public/kcl-samples/flange/main.kcl | 2 +- public/kcl-samples/lego/main.kcl | 4 +- .../e2e/executor/inputs/computed_var.kcl | 4 +- .../inputs/no_visuals/import_simple.kcl | 12 +- rust/kcl-lib/src/execution/mod.rs | 18 +- rust/kcl-lib/src/std/array.rs | 16 +- rust/kcl-lib/src/std/assert.rs | 260 +-- rust/kcl-lib/src/std/convert.rs | 2 +- rust/kcl-lib/src/std/math.rs | 12 +- rust/kcl-lib/src/std/mod.rs | 6 +- rust/kcl-lib/tests/add_lots/ast.snap | 90 +- rust/kcl-lib/tests/add_lots/input.kcl | 2 +- rust/kcl-lib/tests/add_lots/unparsed.snap | 2 +- rust/kcl-lib/tests/array_elem_pop/ast.snap | 362 ++-- rust/kcl-lib/tests/array_elem_pop/input.kcl | 6 +- .../tests/array_elem_pop/unparsed.snap | 6 +- rust/kcl-lib/tests/array_elem_push/ast.snap | 1482 +++++++++-------- rust/kcl-lib/tests/array_elem_push/input.kcl | 18 +- .../tests/array_elem_push/unparsed.snap | 18 +- .../array_elem_push_fail/execution_error.snap | 2 +- rust/kcl-lib/tests/array_range_expr/ast.snap | 858 +++++----- rust/kcl-lib/tests/array_range_expr/input.kcl | 14 +- .../tests/array_range_expr/unparsed.snap | 14 +- .../tests/array_range_negative_expr/ast.snap | 126 +- .../tests/array_range_negative_expr/input.kcl | 2 +- .../array_range_negative_expr/unparsed.snap | 2 +- .../tests/boolean_logical_and/ast.snap | 280 ++-- .../tests/boolean_logical_and/input.kcl | 8 +- .../tests/boolean_logical_and/unparsed.snap | 8 +- .../tests/boolean_logical_multiple/ast.snap | 140 +- .../tests/boolean_logical_multiple/input.kcl | 4 +- .../boolean_logical_multiple/unparsed.snap | 4 +- .../kcl-lib/tests/boolean_logical_or/ast.snap | 280 ++-- .../tests/boolean_logical_or/input.kcl | 8 +- .../tests/boolean_logical_or/unparsed.snap | 8 +- rust/kcl-lib/tests/comparisons/ast.snap | 774 +++++---- rust/kcl-lib/tests/comparisons/input.kcl | 22 +- rust/kcl-lib/tests/comparisons/unparsed.snap | 22 +- .../tests/comparisons_multiple/ast.snap | 114 +- .../comparisons_multiple/execution_error.snap | 4 +- .../tests/comparisons_multiple/input.kcl | 2 +- .../tests/comparisons_multiple/unparsed.snap | 2 +- rust/kcl-lib/tests/computed_var/ast.snap | 407 +++-- rust/kcl-lib/tests/computed_var/input.kcl | 9 +- rust/kcl-lib/tests/computed_var/unparsed.snap | 19 +- rust/kcl-lib/tests/if_else/ast.snap | 270 +-- rust/kcl-lib/tests/if_else/input.kcl | 6 +- rust/kcl-lib/tests/if_else/unparsed.snap | 6 +- rust/kcl-lib/tests/index_of_array/ast.snap | 320 ++-- rust/kcl-lib/tests/index_of_array/input.kcl | 8 +- .../tests/index_of_array/unparsed.snap | 8 +- .../bracket/artifact_graph_flowchart.snap.md | 56 +- .../tests/kcl_samples/bracket/ast.snap | 464 +++--- .../kcl_samples/bracket/program_memory.snap | 504 +++--- .../flange/artifact_graph_flowchart.snap.md | 38 +- .../kcl-lib/tests/kcl_samples/flange/ast.snap | 80 +- .../lego/artifact_graph_flowchart.snap.md | 56 +- rust/kcl-lib/tests/kcl_samples/lego/ast.snap | 160 +- .../serial_test_example_assert_is0.png | Bin 0 -> 19651 bytes .../serial_test_example_assert_order0.png | Bin 0 -> 19651 bytes .../kcl-lib/tests/property_of_object/ast.snap | 640 ++++--- .../tests/property_of_object/input.kcl | 16 +- .../tests/property_of_object/unparsed.snap | 16 +- 73 files changed, 4790 insertions(+), 4034 deletions(-) create mode 100644 docs/kcl/assertIs.md create mode 100644 rust/kcl-lib/tests/outputs/serial_test_example_assert_is0.png create mode 100644 rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png diff --git a/docs/kcl/assert.md b/docs/kcl/assert.md index c319340fd..fc08dbeac 100644 --- a/docs/kcl/assert.md +++ b/docs/kcl/assert.md @@ -1,17 +1,23 @@ --- title: "assert" -excerpt: "Check a value at runtime, and raise an error if the argument provided is false." +excerpt: "Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. If you provide multiple conditions, they will all be checked and all must be met." layout: manual --- -Check a value at runtime, and raise an error if the argument provided is false. +Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. If you provide multiple conditions, they will all be checked and all must be met. ```js assert( - data: bool, - message: string, + actual: number, + isGreaterThan?: number, + isLessThan?: number, + isGreaterThanOrEqual?: number, + isLessThanOrEqual?: number, + isEqualTo?: number, + tolerance?: number, + error?: String, ): () ``` @@ -20,8 +26,14 @@ assert( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `data` | [`bool`](/docs/kcl/types/bool) | | Yes | -| `message` | [`string`](/docs/kcl/types/string) | | Yes | +| `actual` | [`number`](/docs/kcl/types/number) | Value to check. It will be compared with one of the comparison arguments. | Yes | +| `isGreaterThan` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is greater than this. | No | +| `isLessThan` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than this. | No | +| `isGreaterThanOrEqual` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is greater than or equal to this. | No | +| `isLessThanOrEqual` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | +| `isEqualTo` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | +| `tolerance` | [`number`](/docs/kcl/types/number) | If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places. | No | +| `error` | `String` | If the value was false, the program will terminate with this error message | No | ### Returns @@ -31,8 +43,20 @@ assert( ### Examples ```js -myVar = true -assert(myVar, "should always be true") +n = 10 +assert(n, isEqualTo = 10) +assert( + n, + isGreaterThanOrEqual = 0, + isLessThan = 100, + error = "number should be between 0 and 100", +) +assert( + 1.0000000000012, + isEqualTo = 1, + tolerance = 0.0001, + error = "number should be almost exactly 1", +) ``` ![Rendered example of assert 0]() diff --git a/docs/kcl/assertIs.md b/docs/kcl/assertIs.md new file mode 100644 index 000000000..923c171a8 --- /dev/null +++ b/docs/kcl/assertIs.md @@ -0,0 +1,40 @@ +--- +title: "assertIs" +excerpt: "Asserts that a value is the boolean value true." +layout: manual +--- + +Asserts that a value is the boolean value true. + + + +```js +assertIs( + actual: bool, + error?: String, +): () +``` + + +### Arguments + +| Name | Type | Description | Required | +|----------|------|-------------|----------| +| `actual` | [`bool`](/docs/kcl/types/bool) | Value to check. If this is the boolean value true, assert passes. Otherwise it fails. | Yes | +| `error` | `String` | If the value was false, the program will terminate with this error message | No | + +### Returns + +`()` + + +### Examples + +```js +kclIsFun = true +assertIs(kclIsFun) +``` + +![Rendered example of assertIs 0]() + + diff --git a/docs/kcl/index.md b/docs/kcl/index.md index efba58b13..3ab5319e8 100644 --- a/docs/kcl/index.md +++ b/docs/kcl/index.md @@ -40,11 +40,7 @@ layout: manual * [`arc`](kcl/arc) * [`asin`](kcl/asin) * [`assert`](kcl/assert) - * [`assertEqual`](kcl/assertEqual) - * [`assertGreaterThan`](kcl/assertGreaterThan) - * [`assertGreaterThanOrEq`](kcl/assertGreaterThanOrEq) - * [`assertLessThan`](kcl/assertLessThan) - * [`assertLessThanOrEq`](kcl/assertLessThanOrEq) + * [`assertIs`](kcl/assertIs) * [`atan`](kcl/atan) * [`atan2`](kcl/atan2) * [`bezierCurve`](kcl/bezierCurve) diff --git a/docs/kcl/int.md b/docs/kcl/int.md index 600b2a456..1ff85f72b 100644 --- a/docs/kcl/int.md +++ b/docs/kcl/int.md @@ -34,7 +34,7 @@ int(num: number): number ```js n = int(ceil(5 / 2)) -assertEqual(n, 3, 0.0001, "5/2 = 2.5, rounded up makes 3") +assert(n, isEqualTo = 3, error = "5/2 = 2.5, rounded up makes 3") // Draw n cylinders. startSketchOn(XZ) |> circle(center = [0, 0], radius = 2) diff --git a/docs/kcl/pop.md b/docs/kcl/pop.md index db4829f42..4a1c3eac8 100644 --- a/docs/kcl/pop.md +++ b/docs/kcl/pop.md @@ -29,9 +29,24 @@ pop(array: [KclValue]): KclValue ```js arr = [1, 2, 3, 4] new_arr = pop(arr) -assertEqual(new_arr[0], 1, 0.00001, "1 is the first element of the array") -assertEqual(new_arr[1], 2, 0.00001, "2 is the second element of the array") -assertEqual(new_arr[2], 3, 0.00001, "3 is the third element of the array") +assert( + new_arr[0], + isEqualTo = 1, + tolerance = 0.00001, + error = "1 is the first element of the array", +) +assert( + new_arr[1], + isEqualTo = 2, + tolerance = 0.00001, + error = "2 is the second element of the array", +) +assert( + new_arr[2], + isEqualTo = 3, + tolerance = 0.00001, + error = "3 is the third element of the array", +) ``` ![Rendered example of pop 0]() diff --git a/docs/kcl/push.md b/docs/kcl/push.md index 23666bd3a..d169e6f24 100644 --- a/docs/kcl/push.md +++ b/docs/kcl/push.md @@ -33,7 +33,12 @@ push( ```js arr = [1, 2, 3] new_arr = push(arr, 4) -assertEqual(new_arr[3], 4, 0.00001, "4 was added to the end of the array") +assert( + new_arr[3], + isEqualTo = 4, + tolerance = 0.1, + error = "4 was added to the end of the array", +) ``` ![Rendered example of push 0]() diff --git a/docs/kcl/reduce.md b/docs/kcl/reduce.md index da46f47a0..72daa620d 100644 --- a/docs/kcl/reduce.md +++ b/docs/kcl/reduce.md @@ -52,9 +52,14 @@ fn sum(arr): sumSoFar = add(sumSoFar, i) return sumSoFar */ -// We use `assertEqual` to check that our `sum` function gives the +// We use `assert` to check that our `sum` function gives the // expected result. It's good to check your work! -assertEqual(sum([1, 2, 3]), 6, 0.00001, "1 + 2 + 3 summed is 6") +assert( + sum([1, 2, 3]), + isEqualTo = 6, + tolerance = 0.1, + error = "1 + 2 + 3 summed is 6", +) ``` ![Rendered example of reduce 0]() @@ -68,9 +73,14 @@ sum = reduce(arr, 0, fn(i, result_so_far) { return i + result_so_far }) -// We use `assertEqual` to check that our `sum` function gives the +// We use `assert` to check that our `sum` function gives the // expected result. It's good to check your work! -assertEqual(sum, 6, 0.00001, "1 + 2 + 3 summed is 6") +assert( + sum, + isEqualTo = 6, + tolerance = 0.1, + error = "1 + 2 + 3 summed is 6", +) ``` ![Rendered example of reduce 1]() diff --git a/docs/kcl/rem.md b/docs/kcl/rem.md index d7b74ccab..229bc4a13 100644 --- a/docs/kcl/rem.md +++ b/docs/kcl/rem.md @@ -35,12 +35,12 @@ rem( ### Examples ```js -assertEqual(rem(7, divisor = 4), 3, 0.01, "remainder is 3") -assertEqual(rem(-7, divisor = 4), -3, 0.01, "remainder is -3") -assertEqual(rem(7, divisor = -4), 3, 0.01, "remainder is 3") -assertEqual(rem(6, divisor = 2.5), 1, 0.01, "remainder is 1") -assertEqual(rem(6.5, divisor = 2.5), 1.5, 0.01, "remainder is 1.5") -assertEqual(rem(6.5, divisor = 2), 0.5, 0.01, "remainder is 0.5") +assert(rem(7, divisor = 4), isEqualTo = 3, error = "remainder is 3") +assert(rem(-7, divisor = 4), isEqualTo = -3, error = "remainder is -3") +assert(rem(7, divisor = -4), isEqualTo = 3, error = "remainder is 3") +assert(rem(6, divisor = 2.5), isEqualTo = 1, error = "remainder is 1") +assert(rem(6.5, divisor = 2.5), isEqualTo = 1.5, error = "remainder is 1.5") +assert(rem(6.5, divisor = 2), isEqualTo = 0.5, error = "remainder is 0.5") ``` ![Rendered example of rem 0]() diff --git a/docs/kcl/std.json b/docs/kcl/std.json index 629cb6ab9..faf136241 100644 --- a/docs/kcl/std.json +++ b/docs/kcl/std.json @@ -49435,13 +49435,211 @@ }, { "name": "assert", - "summary": "Check a value at runtime, and raise an error if the argument provided is false.", + "summary": "Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. If you provide multiple conditions, they will all be checked and all must be met.", "description": "", "tags": [], - "keywordArguments": false, + "keywordArguments": true, "args": [ { - "name": "data", + "name": "actual", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "TyF64", + "type": "number", + "format": "double" + }, + "required": true, + "includeInSnippet": true, + "description": "Value to check. It will be compared with one of the comparison arguments.", + "labelRequired": false + }, + { + "name": "isGreaterThan", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "Comparison argument. If given, checks the `actual` value is greater than this.", + "labelRequired": true + }, + { + "name": "isLessThan", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "Comparison argument. If given, checks the `actual` value is less than this.", + "labelRequired": true + }, + { + "name": "isGreaterThanOrEqual", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "Comparison argument. If given, checks the `actual` value is greater than or equal to this.", + "labelRequired": true + }, + { + "name": "isLessThanOrEqual", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "Comparison argument. If given, checks the `actual` value is less than or equal to this.", + "labelRequired": true + }, + { + "name": "isEqualTo", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "includeInSnippet": true, + "description": "Comparison argument. If given, checks the `actual` value is less than or equal to this.", + "labelRequired": true + }, + { + "name": "tolerance", + "type": "number", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_TyF64", + "allOf": [ + { + "$ref": "#/components/schemas/TyF64" + } + ], + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places.", + "labelRequired": true + }, + { + "name": "error", + "type": "String", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Nullable_String", + "type": "string", + "nullable": true, + "definitions": { + "TyF64": { + "type": "number", + "format": "double" + } + } + }, + "required": false, + "description": "If the value was false, the program will terminate with this error message", + "labelRequired": true + } + ], + "returnValue": { + "name": "", + "type": "()", + "schema": { + "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", + "title": "Null", + "type": "null" + }, + "required": true, + "includeInSnippet": true, + "labelRequired": true + }, + "unpublished": false, + "deprecated": false, + "examples": [ + "n = 10\nassert(n, isEqualTo = 10)\nassert(\n n,\n isGreaterThanOrEqual = 0,\n isLessThan = 100,\n error = \"number should be between 0 and 100\",\n)\nassert(\n 1.0000000000012,\n isEqualTo = 1,\n tolerance = 0.0001,\n error = \"number should be almost exactly 1\",\n)" + ] + }, + { + "name": "assertIs", + "summary": "Asserts that a value is the boolean value true.", + "description": "", + "tags": [], + "keywordArguments": true, + "args": [ + { + "name": "actual", "type": "bool", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", @@ -49450,18 +49648,20 @@ }, "required": true, "includeInSnippet": true, - "labelRequired": true + "description": "Value to check. If this is the boolean value true, assert passes. Otherwise it fails.", + "labelRequired": false }, { - "name": "message", - "type": "string", + "name": "error", + "type": "String", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" + "title": "Nullable_String", + "type": "string", + "nullable": true }, - "required": true, - "includeInSnippet": true, + "required": false, + "description": "If the value was false, the program will terminate with this error message", "labelRequired": true } ], @@ -49480,340 +49680,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "myVar = true\nassert(myVar, \"should always be true\")" - ] - }, - { - "name": "assertEqual", - "summary": "Check that a numerical value equals another at runtime, otherwise raise an error.", - "description": "", - "tags": [], - "keywordArguments": false, - "args": [ - { - "name": "left", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "right", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "epsilon", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "message", - "type": "string", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - } - ], - "returnValue": { - "name": "", - "type": "()", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Null", - "type": "null" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - "unpublished": false, - "deprecated": false, - "examples": [ - "n = 1.0285\no = 1.0286\nassertEqual(n, o, 0.01, \"n is within the given tolerance for o\")" - ] - }, - { - "name": "assertGreaterThan", - "summary": "Check that a numerical value is greater than another at runtime, otherwise raise an error.", - "description": "", - "tags": [], - "keywordArguments": false, - "args": [ - { - "name": "left", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "right", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "message", - "type": "string", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - } - ], - "returnValue": { - "name": "", - "type": "()", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Null", - "type": "null" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - "unpublished": false, - "deprecated": false, - "examples": [ - "assertGreaterThan(2, 1, \"2 is greater than 1\")" - ] - }, - { - "name": "assertGreaterThanOrEq", - "summary": "Check that a numerical value is greater than or equal to another at runtime, otherwise raise an error.", - "description": "", - "tags": [], - "keywordArguments": false, - "args": [ - { - "name": "left", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "right", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "message", - "type": "string", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - } - ], - "returnValue": { - "name": "", - "type": "()", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Null", - "type": "null" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - "unpublished": false, - "deprecated": false, - "examples": [ - "assertGreaterThanOrEq(2, 1, \"2 is greater than 1\")\nassertGreaterThanOrEq(1, 1, \"1 is equal to 1\")" - ] - }, - { - "name": "assertLessThan", - "summary": "Check that a numerical value is less than to another at runtime, otherwise raise an error.", - "description": "", - "tags": [], - "keywordArguments": false, - "args": [ - { - "name": "left", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "right", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "message", - "type": "string", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - } - ], - "returnValue": { - "name": "", - "type": "()", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Null", - "type": "null" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - "unpublished": false, - "deprecated": false, - "examples": [ - "assertLessThan(1, 2, \"1 is less than 2\")" - ] - }, - { - "name": "assertLessThanOrEq", - "summary": "Check that a numerical value is less than or equal to another at runtime, otherwise raise an error.", - "description": "", - "tags": [], - "keywordArguments": false, - "args": [ - { - "name": "left", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "right", - "type": "number", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "double", - "type": "number", - "format": "double" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - { - "name": "message", - "type": "string", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "String", - "type": "string" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - } - ], - "returnValue": { - "name": "", - "type": "()", - "schema": { - "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", - "title": "Null", - "type": "null" - }, - "required": true, - "includeInSnippet": true, - "labelRequired": true - }, - "unpublished": false, - "deprecated": false, - "examples": [ - "assertLessThanOrEq(1, 2, \"1 is less than 2\")\nassertLessThanOrEq(1, 1, \"1 is equal to 1\")" + "kclIsFun = true\nassertIs(kclIsFun)" ] }, { @@ -113042,7 +112909,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))\nassert(n, isEqualTo = 3, error = \"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 )" ] }, { @@ -237871,7 +237738,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "arr = [1, 2, 3, 4]\nnew_arr = pop(arr)\nassertEqual(new_arr[0], 1, 0.00001, \"1 is the first element of the array\")\nassertEqual(new_arr[1], 2, 0.00001, \"2 is the second element of the array\")\nassertEqual(new_arr[2], 3, 0.00001, \"3 is the third element of the array\")" + "arr = [1, 2, 3, 4]\nnew_arr = pop(arr)\nassert(\n new_arr[0],\n isEqualTo = 1,\n tolerance = 0.00001,\n error = \"1 is the first element of the array\",\n)\nassert(\n new_arr[1],\n isEqualTo = 2,\n tolerance = 0.00001,\n error = \"2 is the second element of the array\",\n)\nassert(\n new_arr[2],\n isEqualTo = 3,\n tolerance = 0.00001,\n error = \"3 is the third element of the array\",\n)" ] }, { @@ -251362,7 +251229,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "arr = [1, 2, 3]\nnew_arr = push(arr, 4)\nassertEqual(new_arr[3], 4, 0.00001, \"4 was added to the end of the array\")" + "arr = [1, 2, 3]\nnew_arr = push(arr, 4)\nassert(\n new_arr[3],\n isEqualTo = 4,\n tolerance = 0.1,\n error = \"4 was added to the end of the array\",\n)" ] }, { @@ -262197,8 +262064,8 @@ "unpublished": false, "deprecated": false, "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\")", + "// This function adds two numbers.\nfn add(a, b) {\n return a + b\n}\n\n// This function adds an array of numbers.\n// It uses the `reduce` function, to call the `add` function on every\n// element of the `arr` parameter. The starting value is 0.\nfn sum(arr) {\n return reduce(arr, 0, add)\n}\n\n/* The above is basically like this pseudo-code:\nfn sum(arr):\n sumSoFar = 0\n for i in arr:\n sumSoFar = add(sumSoFar, i)\n return sumSoFar */\n\n// We use `assert` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassert(\n sum([1, 2, 3]),\n isEqualTo = 6,\n tolerance = 0.1,\n error = \"1 + 2 + 3 summed is 6\",\n)", + "// This example works just like the previous example above, but it uses\n// an anonymous `add` function as its parameter, instead of declaring a\n// named function outside.\narr = [1, 2, 3]\nsum = reduce(arr, 0, fn(i, result_so_far) {\n return i + result_so_far\n})\n\n// We use `assert` to check that our `sum` function gives the\n// expected result. It's good to check your work!\nassert(\n sum,\n isEqualTo = 6,\n tolerance = 0.1,\n error = \"1 + 2 + 3 summed is 6\",\n)", "// Declare a function that sketches a decagon.\nfn decagon(radius) {\n // Each side of the decagon is turned this many radians from the previous angle.\n stepAngle = 1 / 10 * TAU\n\n // Start the decagon sketch at this point.\n startOfDecagonSketch = startSketchOn(XY)\n |> startProfileAt([cos(0) * radius, sin(0) * radius], %)\n\n // Use a `reduce` to draw the remaining decagon sides.\n // For each number in the array 1..10, run the given function,\n // which takes a partially-sketched decagon and adds one more edge to it.\n fullDecagon = reduce([1..10], startOfDecagonSketch, fn(i, partialDecagon) {\n // Draw one edge of the decagon.\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n return line(partialDecagon, end = [x, y])\n })\n\n return fullDecagon\n}\n\n/* The `decagon` above is basically like this pseudo-code:\nfn decagon(radius):\n stepAngle = (1/10) * TAU\n plane = startSketchOn('XY')\n startOfDecagonSketch = startProfileAt([(cos(0)*radius), (sin(0) * radius)], plane)\n\n // Here's the reduce part.\n partialDecagon = startOfDecagonSketch\n for i in [1..10]:\n x = cos(stepAngle * i) * radius\n y = sin(stepAngle * i) * radius\n partialDecagon = line(partialDecagon, end = [x, y])\n fullDecagon = partialDecagon // it's now full\n return fullDecagon */\n\n// Use the `decagon` function declared above, to sketch a decagon with radius 5.\ndecagon(5.0)\n |> close()" ] }, @@ -262256,7 +262123,7 @@ "unpublished": false, "deprecated": false, "examples": [ - "assertEqual(rem(7, divisor = 4), 3, 0.01, \"remainder is 3\")\nassertEqual(rem(-7, divisor = 4), -3, 0.01, \"remainder is -3\")\nassertEqual(rem(7, divisor = -4), 3, 0.01, \"remainder is 3\")\nassertEqual(rem(6, divisor = 2.5), 1, 0.01, \"remainder is 1\")\nassertEqual(rem(6.5, divisor = 2.5), 1.5, 0.01, \"remainder is 1.5\")\nassertEqual(rem(6.5, divisor = 2), 0.5, 0.01, \"remainder is 0.5\")" + "assert(rem(7, divisor = 4), isEqualTo = 3, error = \"remainder is 3\")\nassert(rem(-7, divisor = 4), isEqualTo = -3, error = \"remainder is -3\")\nassert(rem(7, divisor = -4), isEqualTo = 3, error = \"remainder is 3\")\nassert(rem(6, divisor = 2.5), isEqualTo = 1, error = \"remainder is 1\")\nassert(rem(6.5, divisor = 2.5), isEqualTo = 1.5, error = \"remainder is 1.5\")\nassert(rem(6.5, divisor = 2), isEqualTo = 0.5, error = \"remainder is 0.5\")" ] }, { diff --git a/public/kcl-samples/bracket/main.kcl b/public/kcl-samples/bracket/main.kcl index 7c5b93e7f..20759eec6 100644 --- a/public/kcl-samples/bracket/main.kcl +++ b/public/kcl-samples/bracket/main.kcl @@ -25,10 +25,10 @@ shelfMountingHolePlacementOffset = shelfMountingHoleDiameter * 1.5 wallMountingHolePlacementOffset = wallMountingHoleDiameter * 1.5 // Add checks to ensure bracket is possible. These make sure that there is adequate distance between holes and edges. -assertGreaterThanOrEq(wallMountLength, wallMountingHoleDiameter * 3, "Holes not possible. Either decrease hole diameter or increase wallMountLength") -assertGreaterThanOrEq(shelfMountLength, shelfMountingHoleDiameter * 5.5, "wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength") -assertGreaterThanOrEq(width, shelfMountingHoleDiameter * 5.5, "Holes not possible. Either decrease hole diameter or increase width") -assertGreaterThanOrEq(width, wallMountingHoleDiameter * 5.5, "Holes not possible. Either decrease hole diameter or increase width") +assert(wallMountLength, isGreaterThanOrEqual = wallMountingHoleDiameter * 3, error = "Holes not possible. Either decrease hole diameter or increase wallMountLength") +assert(shelfMountLength, isGreaterThanOrEqual = shelfMountingHoleDiameter * 5.5, error = "wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength") +assert(width, isGreaterThanOrEqual = shelfMountingHoleDiameter * 5.5, error = "Holes not possible. Either decrease hole diameter or increase width") +assert(width, isGreaterThanOrEqual = wallMountingHoleDiameter * 5.5, error = "Holes not possible. Either decrease hole diameter or increase width") // Create the body of the bracket bracketBody = startSketchOn(XZ) diff --git a/public/kcl-samples/flange/main.kcl b/public/kcl-samples/flange/main.kcl index a6880d7a6..5304a1688 100644 --- a/public/kcl-samples/flange/main.kcl +++ b/public/kcl-samples/flange/main.kcl @@ -18,7 +18,7 @@ topTotalThickness = totalThickness - (bottomThickness + baseThickness) nHoles = 4 // Add assertion so nHoles are always greater than 1 -assertGreaterThan(nHoles, 1, "nHoles must be greater than 1") +assert(nHoles, isGreaterThan = 1, error = "nHoles must be greater than 1") // Create the circular pattern for the mounting holes circles = startSketchOn(XY) diff --git a/public/kcl-samples/lego/main.kcl b/public/kcl-samples/lego/main.kcl index 578ce4ff2..79edf94b1 100644 --- a/public/kcl-samples/lego/main.kcl +++ b/public/kcl-samples/lego/main.kcl @@ -22,8 +22,8 @@ lSegments = totalLength / lbumps wSegments = totalWidth / wbumps // Add assertions to ensure that the number of bumps are greater than 1 -assertGreaterThan(lbumps, 1, "lbumps must be greater than 1") -assertGreaterThan(wbumps, 1, "wbumps must be greater than 1") +assert(lbumps, isGreaterThan = 1, error = "lbumps must be greater than 1") +assert(wbumps, isGreaterThan = 1, error = "wbumps must be greater than 1") // Make the base base = startSketchOn(XY) diff --git a/rust/kcl-lib/e2e/executor/inputs/computed_var.kcl b/rust/kcl-lib/e2e/executor/inputs/computed_var.kcl index 78e668015..9b72f1960 100644 --- a/rust/kcl-lib/e2e/executor/inputs/computed_var.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/computed_var.kcl @@ -4,7 +4,7 @@ const arr = [0, 0, 0, 10] const i = 3 const ten = arr[i] -assertEqual(ten, 10, 0.000001, "oops") +assert(ten, isEqualTo = 10, error = "oops") const p = "foo" const obj = { @@ -13,4 +13,4 @@ const obj = { } const one = obj[p] -assertEqual(one, 1, 0.0000001, "oops") +assert(one, isEqualTo = 1, error = "oops") diff --git a/rust/kcl-lib/e2e/executor/inputs/no_visuals/import_simple.kcl b/rust/kcl-lib/e2e/executor/inputs/no_visuals/import_simple.kcl index 2ee77568a..de0b5944a 100644 --- a/rust/kcl-lib/e2e/executor/inputs/no_visuals/import_simple.kcl +++ b/rust/kcl-lib/e2e/executor/inputs/no_visuals/import_simple.kcl @@ -1,25 +1,25 @@ import identity from "identity.kcl" answer = identity(42) -assertEqual(answer, 42, 0.0001, "identity") +assert(answer, isEqualTo = 42, error = "identity") import identity as id from "identity.kcl" answer43 = id(43) -assertEqual(answer43, 43, 0.0001, "identity") +assert(answer43, isEqualTo = 43, error = "identity") import increment, decrement from "numbers.kcl" answer3 = increment(2) -assertEqual(answer3, 3, 0.0001, "increment") +assert(answer3, isEqualTo = 3, error = "increment") answer5 = decrement(6) -assertEqual(answer5, 5, 0.0001, "decrement") +assert(answer5, isEqualTo = 5, error = "decrement") import increment as inc, decrement as dec from "numbers.kcl" answer4 = inc(3) -assertEqual(answer4, 4, 0.0001, "inc") +assert(answer4, isEqualTo = 4, error = "inc") answer6 = dec(7) -assertEqual(answer6, 6, 0.0001, "dec") +assert(answer6, isEqualTo = 6, error = "dec") diff --git a/rust/kcl-lib/src/execution/mod.rs b/rust/kcl-lib/src/execution/mod.rs index 31a2a309e..11a1556d1 100644 --- a/rust/kcl-lib/src/execution/mod.rs +++ b/rust/kcl-lib/src/execution/mod.rs @@ -1830,18 +1830,18 @@ const bracket = startSketchOn(XY) #[tokio::test(flavor = "multi_thread")] async fn test_unary_operator_not_succeeds() { let ast = r#" -fn returnTrue = () => { return !false } -const t = true -const f = false -let notTrue = !t -let notFalse = !f -let c = !!true -let d = !returnTrue() +fn returnTrue() { return !false } +t = true +f = false +notTrue = !t +notFalse = !f +c = !!true +d = !returnTrue() -assert(!false, "expected to pass") +assertIs(!false, error = "expected to pass") fn check = (x) => { - assert(!x, "expected argument to be false") + assertIs(!x, error = "expected argument to be false") return true } check(false) diff --git a/rust/kcl-lib/src/std/array.rs b/rust/kcl-lib/src/std/array.rs index 7d86033b4..28f2b65a0 100644 --- a/rust/kcl-lib/src/std/array.rs +++ b/rust/kcl-lib/src/std/array.rs @@ -115,9 +115,9 @@ pub async fn reduce(exec_state: &mut ExecState, args: Args) -> Result Result { return i + result_so_far }) /// -/// // We use `assertEqual` to check that our `sum` function gives the +/// // We use `assert` to check that our `sum` function gives the /// // expected result. It's good to check your work! -/// assertEqual(sum, 6, 0.00001, "1 + 2 + 3 summed is 6") +/// assert(sum, isEqualTo = 6, tolerance = 0.1, error = "1 + 2 + 3 summed is 6") /// ``` /// ```no_run /// // Declare a function that sketches a decagon. @@ -224,7 +224,7 @@ async fn call_reduce_closure( /// ```no_run /// arr = [1, 2, 3] /// new_arr = push(arr, 4) -/// assertEqual(new_arr[3], 4, 0.00001, "4 was added to the end of the array") +/// assert(new_arr[3], isEqualTo = 4, tolerance = 0.1, error = "4 was added to the end of the array") /// ``` #[stdlib { name = "push", @@ -260,9 +260,9 @@ pub async fn push(_exec_state: &mut ExecState, args: Args) -> Result Result<(), KclError Ok(()) } +pub async fn assert_is(_exec_state: &mut ExecState, args: Args) -> Result { + let actual = args.get_unlabeled_kw_arg("actual")?; + let error = args.get_kw_arg_opt("error")?; + inner_assert_is(actual, error, &args).await?; + Ok(KclValue::none()) +} + /// Check that the provided value is true, or raise a [KclError] /// with the provided description. pub async fn assert(_exec_state: &mut ExecState, args: Args) -> Result { - let (data, description): (bool, String) = args.get_data()?; - inner_assert(data, &description, &args).await?; + let actual = args.get_unlabeled_kw_arg("actual")?; + let gt = args.get_kw_arg_opt("isGreaterThan")?; + let lt = args.get_kw_arg_opt("isLessThan")?; + let gte = args.get_kw_arg_opt("isGreaterThanOrEqual")?; + let lte = args.get_kw_arg_opt("isLessThanOrEqual")?; + let eq = args.get_kw_arg_opt("isEqualTo")?; + let tolerance = args.get_kw_arg_opt("tolerance")?; + let error = args.get_kw_arg_opt("error")?; + inner_assert(actual, gt, lt, gte, lte, eq, tolerance, error, &args).await?; Ok(KclValue::none()) } -/// Check a value at runtime, and raise an error if the argument provided -/// is false. +/// Asserts that a value is the boolean value true. +/// ```no_run +/// kclIsFun = true +/// assertIs(kclIsFun) +/// ``` +#[stdlib{ + name = "assertIs", + keywords = true, + unlabeled_first = true, + args = { + actual = { docs = "Value to check. If this is the boolean value true, assert passes. Otherwise it fails." }, + error = { docs = "If the value was false, the program will terminate with this error message" }, + } +}] +async fn inner_assert_is(actual: bool, error: Option, args: &Args) -> Result<(), KclError> { + let error_msg = match &error { + Some(x) => x, + None => "should have been true, but it was not", + }; + _assert(actual, error_msg, args).await +} + +/// Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. +/// If you provide multiple conditions, they will all be checked and all must be met. /// /// ```no_run -/// myVar = true -/// assert(myVar, "should always be true") +/// n = 10 +/// assert(n, isEqualTo = 10) +/// assert(n, isGreaterThanOrEqual = 0, isLessThan = 100, error = "number should be between 0 and 100") +/// assert(1.0000000000012, isEqualTo = 1, tolerance = 0.0001, error = "number should be almost exactly 1") /// ``` #[stdlib { name = "assert", -}] -async fn inner_assert(data: bool, message: &str, args: &Args) -> Result<(), KclError> { - _assert(data, message, args).await -} - -pub async fn assert_lt(_exec_state: &mut ExecState, args: Args) -> Result { - let (left, right, description): (TyF64, TyF64, String) = args.get_data()?; - inner_assert_lt(left.n, right.n, &description, &args).await?; - Ok(KclValue::none()) -} - -/// Check that a numerical value is less than to another at runtime, -/// otherwise raise an error. -/// -/// ```no_run -/// assertLessThan(1, 2, "1 is less than 2") -/// ``` -#[stdlib { - name = "assertLessThan", -}] -async fn inner_assert_lt(left: f64, right: f64, message: &str, args: &Args) -> Result<(), KclError> { - _assert(left < right, message, args).await -} - -pub async fn assert_gt(_exec_state: &mut ExecState, args: Args) -> Result { - let (left, right, description): (TyF64, TyF64, String) = args.get_data()?; - inner_assert_gt(left.n, right.n, &description, &args).await?; - Ok(KclValue::none()) -} - -/// Check that a numerical value equals another at runtime, -/// otherwise raise an error. -/// -/// ```no_run -/// n = 1.0285 -/// o = 1.0286 -/// assertEqual(n, o, 0.01, "n is within the given tolerance for o") -/// ``` -#[stdlib { - name = "assertEqual", -}] -async fn inner_assert_equal(left: f64, right: f64, epsilon: f64, message: &str, args: &Args) -> Result<(), KclError> { - if epsilon <= 0.0 { - Err(KclError::Type(KclErrorDetails { - message: "assertEqual epsilon must be greater than zero".to_owned(), - source_ranges: vec![args.source_range], - })) - } else if (right - left).abs() < epsilon { - Ok(()) - } else { - Err(KclError::Type(KclErrorDetails { - message: format!("assert failed because {left} != {right}: {message}"), - source_ranges: vec![args.source_range], - })) + keywords = true, + unlabeled_first = true, + args = { + actual = { docs = "Value to check. It will be compared with one of the comparison arguments." }, + is_greater_than = { docs = "Comparison argument. If given, checks the `actual` value is greater than this." }, + is_less_than = { docs = "Comparison argument. If given, checks the `actual` value is less than this." }, + is_greater_than_or_equal = { docs = "Comparison argument. If given, checks the `actual` value is greater than or equal to this." }, + is_less_than_or_equal = { docs = "Comparison argument. If given, checks the `actual` value is less than or equal to this." }, + is_equal_to = { docs = "Comparison argument. If given, checks the `actual` value is less than or equal to this.", include_in_snippet = true }, + tolerance = { docs = "If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places." }, + error = { docs = "If the value was false, the program will terminate with this error message" }, } -} - -pub async fn assert_equal(_exec_state: &mut ExecState, args: Args) -> Result { - let (left, right, epsilon, description): (TyF64, TyF64, TyF64, String) = args.get_data()?; - inner_assert_equal(left.n, right.n, epsilon.n, &description, &args).await?; - Ok(KclValue::none()) -} - -/// Check that a numerical value is greater than another at runtime, -/// otherwise raise an error. -/// -/// ```no_run -/// assertGreaterThan(2, 1, "2 is greater than 1") -/// ``` -#[stdlib { - name = "assertGreaterThan", }] -async fn inner_assert_gt(left: f64, right: f64, message: &str, args: &Args) -> Result<(), KclError> { - _assert(left > right, message, args).await -} +#[allow(clippy::too_many_arguments)] +async fn inner_assert( + actual: TyF64, + is_greater_than: Option, + is_less_than: Option, + is_greater_than_or_equal: Option, + is_less_than_or_equal: Option, + is_equal_to: Option, + tolerance: Option, + error: Option, + args: &Args, +) -> Result<(), KclError> { + // Validate the args + let no_condition_given = [ + &is_greater_than, + &is_less_than, + &is_greater_than_or_equal, + &is_less_than_or_equal, + &is_equal_to, + ] + .iter() + .all(|cond| cond.is_none()); + if no_condition_given { + return Err(KclError::Type(KclErrorDetails { + message: "You must provide at least one condition in this assert (for example, isEqualTo)".to_owned(), + source_ranges: vec![args.source_range], + })); + } -pub async fn assert_lte(_exec_state: &mut ExecState, args: Args) -> Result { - let (left, right, description): (TyF64, TyF64, String) = args.get_data()?; - inner_assert_lte(left.n, right.n, &description, &args).await?; - Ok(KclValue::none()) -} + if tolerance.is_some() && is_equal_to.is_none() { + return Err(KclError::Type(KclErrorDetails { + message: + "The `tolerance` arg is only used with `isEqualTo`. Either remove `tolerance` or add an `isEqualTo` arg." + .to_owned(), + source_ranges: vec![args.source_range], + })); + } -/// Check that a numerical value is less than or equal to another at runtime, -/// otherwise raise an error. -/// -/// ```no_run -/// assertLessThanOrEq(1, 2, "1 is less than 2") -/// assertLessThanOrEq(1, 1, "1 is equal to 1") -/// ``` -#[stdlib { - name = "assertLessThanOrEq", -}] -async fn inner_assert_lte(left: f64, right: f64, message: &str, args: &Args) -> Result<(), KclError> { - _assert(left <= right, message, args).await -} + let suffix = if let Some(err_string) = error { + format!(": {err_string}") + } else { + Default::default() + }; + let actual = actual.n; -pub async fn assert_gte(_exec_state: &mut ExecState, args: Args) -> Result { - let (left, right, description): (TyF64, TyF64, String) = args.get_data()?; - inner_assert_gte(left.n, right.n, &description, &args).await?; - Ok(KclValue::none()) -} - -/// Check that a numerical value is greater than or equal to another at runtime, -/// otherwise raise an error. -/// -/// ```no_run -/// assertGreaterThanOrEq(2, 1, "2 is greater than 1") -/// assertGreaterThanOrEq(1, 1, "1 is equal to 1") -/// ``` -#[stdlib { - name = "assertGreaterThanOrEq", -}] -async fn inner_assert_gte(left: f64, right: f64, message: &str, args: &Args) -> Result<(), KclError> { - _assert(left >= right, message, args).await + // Run the checks. + if let Some(exp) = is_greater_than { + let exp = exp.n; + _assert( + actual > exp, + &format!("Expected {actual} to be greater than {exp} but it wasn't{suffix}"), + args, + ) + .await?; + } + if let Some(exp) = is_less_than { + let exp = exp.n; + _assert( + actual < exp, + &format!("Expected {actual} to be less than {exp} but it wasn't{suffix}"), + args, + ) + .await?; + } + if let Some(exp) = is_greater_than_or_equal { + let exp = exp.n; + _assert( + actual >= exp, + &format!("Expected {actual} to be greater than or equal to {exp} but it wasn't{suffix}"), + args, + ) + .await?; + } + if let Some(exp) = is_less_than_or_equal { + let exp = exp.n; + _assert( + actual <= exp, + &format!("Expected {actual} to be less than or equal to {exp} but it wasn't{suffix}"), + args, + ) + .await?; + } + if let Some(exp) = is_equal_to { + let exp = exp.n; + let tolerance = tolerance.map(|e| e.n).unwrap_or(0.0000000001); + _assert( + (actual - exp).abs() < tolerance, + &format!("Expected {actual} to be equal to {exp} but it wasn't{suffix}"), + args, + ) + .await?; + } + Ok(()) } diff --git a/rust/kcl-lib/src/std/convert.rs b/rust/kcl-lib/src/std/convert.rs index 2788774de..4bf208277 100644 --- a/rust/kcl-lib/src/std/convert.rs +++ b/rust/kcl-lib/src/std/convert.rs @@ -22,7 +22,7 @@ pub async fn int(_exec_state: &mut ExecState, args: Args) -> Result circle(center = [0, 0], radius = 2 ) diff --git a/rust/kcl-lib/src/std/math.rs b/rust/kcl-lib/src/std/math.rs index 2e860e591..dee5bfc63 100644 --- a/rust/kcl-lib/src/std/math.rs +++ b/rust/kcl-lib/src/std/math.rs @@ -36,12 +36,12 @@ pub async fn rem(exec_state: &mut ExecState, args: Args) -> Result", - "right": { + "arg": { "commentStart": 0, "end": 0, "raw": "3", @@ -541,19 +450,26 @@ description: Result of parsing comparisons.kcl "value": 3.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"gt\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "gt" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"gt\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "gt" + } } ], "callee": { @@ -574,8 +490,20 @@ description: Result of parsing comparisons.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "raw": "4", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.0, + "suffix": "None" + } + } }, "start": 0, "type": "ExpressionStatement", @@ -587,22 +515,15 @@ description: Result of parsing comparisons.kcl "expression": { "arguments": [ { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "raw": "4", + "name": "isGreaterThanOrEqual", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.0, - "suffix": "None" - } + "type": "Identifier" }, - "operator": ">=", - "right": { + "arg": { "commentStart": 0, "end": 0, "raw": "3", @@ -613,19 +534,26 @@ description: Result of parsing comparisons.kcl "value": 3.0, "suffix": "None" } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"gte but actually gt\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "gte but actually gt" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"gte but actually gt\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "gte but actually gt" + } } ], "callee": { @@ -646,8 +574,20 @@ description: Result of parsing comparisons.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "raw": "4", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.0, + "suffix": "None" + } + } }, "start": 0, "type": "ExpressionStatement", @@ -659,9 +599,15 @@ description: Result of parsing comparisons.kcl "expression": { "arguments": [ { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "isGreaterThanOrEqual", + "start": 0, + "type": "Identifier" + }, + "arg": { "commentStart": 0, "end": 0, "raw": "3", @@ -672,32 +618,26 @@ description: Result of parsing comparisons.kcl "value": 3.0, "suffix": "None" } - }, - "operator": ">=", - "right": { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"gte but actually eq\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "gte but actually eq" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"gte but actually eq\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "gte but actually eq" + } } ], "callee": { @@ -718,8 +658,20 @@ description: Result of parsing comparisons.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + } }, "start": 0, "type": "ExpressionStatement", @@ -731,9 +683,15 @@ description: Result of parsing comparisons.kcl "expression": { "arguments": [ { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "isEqualTo", + "start": 0, + "type": "Identifier" + }, + "arg": { "commentStart": 0, "end": 0, "raw": "0.0", @@ -744,32 +702,26 @@ description: Result of parsing comparisons.kcl "value": 0.0, "suffix": "None" } - }, - "operator": "==", - "right": { + } + }, + { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "raw": "0.0", + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"equality of zero\"", "start": 0, "type": "Literal", "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"equality of zero\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "equality of zero" + "value": "equality of zero" + } } ], "callee": { @@ -790,8 +742,20 @@ description: Result of parsing comparisons.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } }, "start": 0, "type": "ExpressionStatement", @@ -803,22 +767,15 @@ description: Result of parsing comparisons.kcl "expression": { "arguments": [ { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "raw": "0.0", + "name": "isEqualTo", "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0, - "suffix": "None" - } + "type": "Identifier" }, - "operator": "==", - "right": { + "arg": { "argument": { "commentStart": 0, "end": 0, @@ -837,19 +794,26 @@ description: Result of parsing comparisons.kcl "start": 0, "type": "UnaryExpression", "type": "UnaryExpression" - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"equality of zero and neg zero\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "equality of zero and neg zero" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"equality of zero and neg zero\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "equality of zero and neg zero" + } } ], "callee": { @@ -870,8 +834,20 @@ description: Result of parsing comparisons.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "raw": "0.0", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.0, + "suffix": "None" + } + } }, "start": 0, "type": "ExpressionStatement", @@ -882,7 +858,7 @@ description: Result of parsing comparisons.kcl "end": 0, "nonCodeMeta": { "nonCodeNodes": { - "9": [ + "7": [ { "commentStart": 0, "end": 0, diff --git a/rust/kcl-lib/tests/comparisons/input.kcl b/rust/kcl-lib/tests/comparisons/input.kcl index b6363425a..0310d5351 100644 --- a/rust/kcl-lib/tests/comparisons/input.kcl +++ b/rust/kcl-lib/tests/comparisons/input.kcl @@ -1,13 +1,11 @@ -assert(3 == 3, "equality") -assert(3.0 == 3.0, "equality of floats") -assert(3 != 4, "non-equality") -assert(3.0 != 4.0, "non-equality of floats") -assert(3 < 4, "lt") -assert(3 <= 4, "lte but actually lt") -assert(4 <= 4, "lte but actually eq") -assert(4 > 3, "gt") -assert(4 >= 3, "gte but actually gt") -assert(3 >= 3, "gte but actually eq") +assert(3, isEqualTo = 3, error = "equality") +assert(3.0, isEqualTo = 3.0, error = "equality of floats") +assert(3, isLessThan = 4, error = "lt") +assert(3, isLessThanOrEqual = 4, error = "lte but actually lt") +assert(4, isLessThanOrEqual = 4, error = "lte but actually eq") +assert(4, isGreaterThan = 3, error = "gt") +assert(4, isGreaterThanOrEqual = 3, error = "gte but actually gt") +assert(3, isGreaterThanOrEqual = 3, error = "gte but actually eq") -assert(0.0 == 0.0, "equality of zero") -assert(0.0 == -0.0, "equality of zero and neg zero") +assert(0.0, isEqualTo = 0.0, error = "equality of zero") +assert(0.0, isEqualTo = -0.0, error = "equality of zero and neg zero") diff --git a/rust/kcl-lib/tests/comparisons/unparsed.snap b/rust/kcl-lib/tests/comparisons/unparsed.snap index eb61edecd..5ec1a35be 100644 --- a/rust/kcl-lib/tests/comparisons/unparsed.snap +++ b/rust/kcl-lib/tests/comparisons/unparsed.snap @@ -2,16 +2,14 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing comparisons.kcl --- -assert(3 == 3, "equality") -assert(3.0 == 3.0, "equality of floats") -assert(3 != 4, "non-equality") -assert(3.0 != 4.0, "non-equality of floats") -assert(3 < 4, "lt") -assert(3 <= 4, "lte but actually lt") -assert(4 <= 4, "lte but actually eq") -assert(4 > 3, "gt") -assert(4 >= 3, "gte but actually gt") -assert(3 >= 3, "gte but actually eq") +assert(3, isEqualTo = 3, error = "equality") +assert(3.0, isEqualTo = 3.0, error = "equality of floats") +assert(3, isLessThan = 4, error = "lt") +assert(3, isLessThanOrEqual = 4, error = "lte but actually lt") +assert(4, isLessThanOrEqual = 4, error = "lte but actually eq") +assert(4, isGreaterThan = 3, error = "gt") +assert(4, isGreaterThanOrEqual = 3, error = "gte but actually gt") +assert(3, isGreaterThanOrEqual = 3, error = "gte but actually eq") -assert(0.0 == 0.0, "equality of zero") -assert(0.0 == -0.0, "equality of zero and neg zero") +assert(0.0, isEqualTo = 0.0, error = "equality of zero") +assert(0.0, isEqualTo = -0.0, error = "equality of zero and neg zero") diff --git a/rust/kcl-lib/tests/comparisons_multiple/ast.snap b/rust/kcl-lib/tests/comparisons_multiple/ast.snap index 595c2b833..a47b28ec7 100644 --- a/rust/kcl-lib/tests/comparisons_multiple/ast.snap +++ b/rust/kcl-lib/tests/comparisons_multiple/ast.snap @@ -11,65 +11,23 @@ description: Result of parsing comparisons_multiple.kcl "expression": { "arguments": [ { - "commentStart": 0, - "end": 0, - "left": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "left": { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } - }, - "operator": "==", - "right": { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } - }, + "name": "error", "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "Identifier" }, - "operator": "==", - "right": { + "arg": { "commentStart": 0, "end": 0, - "raw": "3", + "raw": "\"this should not compile\"", "start": 0, "type": "Literal", "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"this should not compile\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "this should not compile" + "value": "this should not compile" + } } ], "callee": { @@ -90,8 +48,60 @@ description: Result of parsing comparisons_multiple.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "left": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + "operator": "==", + "right": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + }, + "operator": "==", + "right": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } + }, + "start": 0, + "type": "BinaryExpression", + "type": "BinaryExpression" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/comparisons_multiple/execution_error.snap b/rust/kcl-lib/tests/comparisons_multiple/execution_error.snap index b7f189650..05edcbf03 100644 --- a/rust/kcl-lib/tests/comparisons_multiple/execution_error.snap +++ b/rust/kcl-lib/tests/comparisons_multiple/execution_error.snap @@ -1,12 +1,12 @@ --- -source: kcl/src/simulation_tests.rs +source: kcl-lib/src/simulation_tests.rs description: Error from executing comparisons_multiple.kcl --- KCL Semantic error × semantic: Expected a number, but found a boolean (true/false value) ╭──── - 1 │ assert(3 == 3 == 3, "this should not compile") + 1 │ assert(3 == 3 == 3, error = "this should not compile") · ───┬── · ╰── tests/comparisons_multiple/input.kcl ╰──── diff --git a/rust/kcl-lib/tests/comparisons_multiple/input.kcl b/rust/kcl-lib/tests/comparisons_multiple/input.kcl index 23492e838..525028e0a 100644 --- a/rust/kcl-lib/tests/comparisons_multiple/input.kcl +++ b/rust/kcl-lib/tests/comparisons_multiple/input.kcl @@ -1 +1 @@ -assert(3 == 3 == 3, "this should not compile") +assert(3 == 3 == 3, error = "this should not compile") diff --git a/rust/kcl-lib/tests/comparisons_multiple/unparsed.snap b/rust/kcl-lib/tests/comparisons_multiple/unparsed.snap index 39b980e8e..213ade8de 100644 --- a/rust/kcl-lib/tests/comparisons_multiple/unparsed.snap +++ b/rust/kcl-lib/tests/comparisons_multiple/unparsed.snap @@ -2,4 +2,4 @@ source: kcl-lib/src/simulation_tests.rs description: Result of unparsing comparisons_multiple.kcl --- -assert(3 == 3 == 3, "this should not compile") +assert(3 == 3 == 3, error = "this should not compile") diff --git a/rust/kcl-lib/tests/computed_var/ast.snap b/rust/kcl-lib/tests/computed_var/ast.snap index d7589b155..b07aabe69 100644 --- a/rust/kcl-lib/tests/computed_var/ast.snap +++ b/rust/kcl-lib/tests/computed_var/ast.snap @@ -167,53 +167,45 @@ description: Result of parsing computed_var.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "ten", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "10", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 10.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "10", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 10.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.000001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.000001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"oops\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "oops" } - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"oops\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "oops" } ], "callee": { @@ -223,7 +215,7 @@ description: Result of parsing computed_var.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -234,8 +226,24 @@ description: Result of parsing computed_var.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "ten", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -402,53 +410,45 @@ description: Result of parsing computed_var.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.0000001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.0000001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"oops\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "oops" } - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"oops\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "oops" } ], "callee": { @@ -458,7 +458,7 @@ description: Result of parsing computed_var.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -469,8 +469,24 @@ description: Result of parsing computed_var.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -482,53 +498,67 @@ description: Result of parsing computed_var.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "PI", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.2", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.2, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "0.2", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.2, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"oops pi\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "oops pi" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"oops pi\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "oops pi" + } } ], "callee": { @@ -538,7 +568,7 @@ description: Result of parsing computed_var.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -549,8 +579,24 @@ description: Result of parsing computed_var.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "PI", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -643,53 +689,67 @@ description: Result of parsing computed_var.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "x", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.000001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.000001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "tolerance", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "0.000001", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 0.000001, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"oops cos\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "oops cos" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"oops cos\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "oops cos" + } } ], "callee": { @@ -699,7 +759,7 @@ description: Result of parsing computed_var.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -710,8 +770,24 @@ description: Result of parsing computed_var.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "x", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -765,6 +841,17 @@ description: Result of parsing computed_var.kcl "type": "newLine" } } + ], + "8": [ + { + "commentStart": 0, + "end": 0, + "start": 0, + "type": "NonCodeNode", + "value": { + "type": "newLine" + } + } ] }, "startNodes": [ diff --git a/rust/kcl-lib/tests/computed_var/input.kcl b/rust/kcl-lib/tests/computed_var/input.kcl index 40b84b6bf..8ff44b48d 100644 --- a/rust/kcl-lib/tests/computed_var/input.kcl +++ b/rust/kcl-lib/tests/computed_var/input.kcl @@ -5,14 +5,15 @@ arr = [0, 0, 0, 10] i = 3 ten = arr[i] -assertEqual(ten, 10, 0.000001, "oops") +assert(ten, isEqualTo = 10, error = "oops") p = "foo" obj = { foo = 1, bar = 0 } one = obj[p] -assertEqual(one, 1, 0.0000001, "oops") +assert(one, isEqualTo = 1, error = "oops") + +assert(PI, isEqualTo = 3, tolerance = 0.2, error = "oops pi") -assertEqual(PI, 3, 0.2, "oops pi") x = cos(2 * PI) -assertEqual(x, 1, 0.000001, "oops cos") +assert(x, isEqualTo = 1, tolerance = 0.000001, error = "oops cos") diff --git a/rust/kcl-lib/tests/computed_var/unparsed.snap b/rust/kcl-lib/tests/computed_var/unparsed.snap index 275a01b1d..41fb8b4e6 100644 --- a/rust/kcl-lib/tests/computed_var/unparsed.snap +++ b/rust/kcl-lib/tests/computed_var/unparsed.snap @@ -9,14 +9,25 @@ arr = [0, 0, 0, 10] i = 3 ten = arr[i] -assertEqual(ten, 10, 0.000001, "oops") +assert(ten, isEqualTo = 10, error = "oops") p = "foo" obj = { foo = 1, bar = 0 } one = obj[p] -assertEqual(one, 1, 0.0000001, "oops") +assert(one, isEqualTo = 1, error = "oops") + +assert( + PI, + isEqualTo = 3, + tolerance = 0.2, + error = "oops pi", +) -assertEqual(PI, 3, 0.2, "oops pi") x = cos(2 * PI) -assertEqual(x, 1, 0.000001, "oops cos") +assert( + x, + isEqualTo = 1, + tolerance = 0.000001, + error = "oops cos", +) diff --git a/rust/kcl-lib/tests/if_else/ast.snap b/rust/kcl-lib/tests/if_else/ast.snap index 0406ae60c..4bfe18779 100644 --- a/rust/kcl-lib/tests/if_else/ast.snap +++ b/rust/kcl-lib/tests/if_else/ast.snap @@ -145,53 +145,45 @@ description: Result of parsing if_else.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "a", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"the 'if' branch gets returned\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "the 'if' branch gets returned" } - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"the 'if' branch gets returned\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "the 'if' branch gets returned" } ], "callee": { @@ -201,7 +193,7 @@ description: Result of parsing if_else.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -212,8 +204,24 @@ description: Result of parsing if_else.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "a", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -359,53 +367,45 @@ description: Result of parsing if_else.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "b", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "4", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 4.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "4", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 4.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"the 'else if' branch gets returned\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "the 'else if' branch gets returned" } - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"the 'else if' branch gets returned\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "the 'else if' branch gets returned" } ], "callee": { @@ -415,7 +415,7 @@ description: Result of parsing if_else.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -426,8 +426,24 @@ description: Result of parsing if_else.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "b", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -573,53 +589,45 @@ description: Result of parsing if_else.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "c", + "name": "isEqualTo", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "0.001", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 0.001, - "suffix": "None" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"the 'else' branch gets returned\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "the 'else' branch gets returned" } - }, - { - "commentStart": 0, - "end": 0, - "raw": "\"the 'else' branch gets returned\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "the 'else' branch gets returned" } ], "callee": { @@ -629,7 +637,7 @@ description: Result of parsing if_else.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertEqual", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -640,8 +648,24 @@ description: Result of parsing if_else.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "c", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/if_else/input.kcl b/rust/kcl-lib/tests/if_else/input.kcl index e57aede34..305f6724c 100644 --- a/rust/kcl-lib/tests/if_else/input.kcl +++ b/rust/kcl-lib/tests/if_else/input.kcl @@ -8,7 +8,7 @@ a = if true { } else { 5 } -assertEqual(a, 3, 0.001, "the 'if' branch gets returned") +assert(a, isEqualTo = 3, error = "the 'if' branch gets returned") b = if false { 3 @@ -17,7 +17,7 @@ b = if false { } else { 5 } -assertEqual(b, 4, 0.001, "the 'else if' branch gets returned") +assert(b, isEqualTo = 4, error = "the 'else if' branch gets returned") c = if false { 3 @@ -26,4 +26,4 @@ c = if false { } else { 5 } -assertEqual(c, 5, 0.001, "the 'else' branch gets returned") +assert(c, isEqualTo = 5, error = "the 'else' branch gets returned") diff --git a/rust/kcl-lib/tests/if_else/unparsed.snap b/rust/kcl-lib/tests/if_else/unparsed.snap index 912efebf5..25a0e9d1c 100644 --- a/rust/kcl-lib/tests/if_else/unparsed.snap +++ b/rust/kcl-lib/tests/if_else/unparsed.snap @@ -12,7 +12,7 @@ a = if true { } else { 5 } -assertEqual(a, 3, 0.001, "the 'if' branch gets returned") +assert(a, isEqualTo = 3, error = "the 'if' branch gets returned") b = if false { 3 @@ -21,7 +21,7 @@ b = if false { } else { 5 } -assertEqual(b, 4, 0.001, "the 'else if' branch gets returned") +assert(b, isEqualTo = 4, error = "the 'else if' branch gets returned") c = if false { 3 @@ -30,4 +30,4 @@ c = if false { } else { 5 } -assertEqual(c, 5, 0.001, "the 'else' branch gets returned") +assert(c, isEqualTo = 5, error = "the 'else' branch gets returned") diff --git a/rust/kcl-lib/tests/index_of_array/ast.snap b/rust/kcl-lib/tests/index_of_array/ast.snap index 3083ff859..74a5c0c01 100644 --- a/rust/kcl-lib/tests/index_of_array/ast.snap +++ b/rust/kcl-lib/tests/index_of_array/ast.snap @@ -126,41 +126,45 @@ description: Result of parsing index_of_array.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "result0", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "91", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 91.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "91", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 91.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -170,7 +174,7 @@ description: Result of parsing index_of_array.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -181,8 +185,24 @@ description: Result of parsing index_of_array.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "result0", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -194,41 +214,45 @@ description: Result of parsing index_of_array.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "result0", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "91", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 91.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "91", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 91.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -238,7 +262,7 @@ description: Result of parsing index_of_array.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -249,8 +273,24 @@ description: Result of parsing index_of_array.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "result0", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -384,41 +424,45 @@ description: Result of parsing index_of_array.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "result1", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "91", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 91.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "91", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 91.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -428,7 +472,7 @@ description: Result of parsing index_of_array.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -439,8 +483,24 @@ description: Result of parsing index_of_array.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "result1", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -452,41 +512,45 @@ description: Result of parsing index_of_array.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "result1", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "91", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 91.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "91", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 91.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -496,7 +560,7 @@ description: Result of parsing index_of_array.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -507,8 +571,24 @@ description: Result of parsing index_of_array.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "result1", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/index_of_array/input.kcl b/rust/kcl-lib/tests/index_of_array/input.kcl index a52c5c90a..c9f2faf00 100644 --- a/rust/kcl-lib/tests/index_of_array/input.kcl +++ b/rust/kcl-lib/tests/index_of_array/input.kcl @@ -8,8 +8,8 @@ arr = [90, 91, 92] result0 = arr[1] -assertLessThanOrEq(result0, 91, "Literal property lookup") -assertGreaterThanOrEq(result0, 91, "Literal property lookup") +assert(result0, isLessThanOrEqual = 91, error = "Literal property lookup") +assert(result0, isGreaterThanOrEqual = 91, error = "Literal property lookup") // Test: computed index. @@ -17,5 +17,5 @@ assertGreaterThanOrEq(result0, 91, "Literal property lookup") i = int(1 + 0) result1 = arr[i] -assertLessThanOrEq(result1, 91, "Computed property lookup") -assertGreaterThanOrEq(result1, 91, "Computed property lookup") +assert(result1, isLessThanOrEqual = 91, error = "Computed property lookup") +assert(result1, isGreaterThanOrEqual = 91, error = "Computed property lookup") diff --git a/rust/kcl-lib/tests/index_of_array/unparsed.snap b/rust/kcl-lib/tests/index_of_array/unparsed.snap index c7247f56e..c35238119 100644 --- a/rust/kcl-lib/tests/index_of_array/unparsed.snap +++ b/rust/kcl-lib/tests/index_of_array/unparsed.snap @@ -12,8 +12,8 @@ arr = [90, 91, 92] result0 = arr[1] -assertLessThanOrEq(result0, 91, "Literal property lookup") -assertGreaterThanOrEq(result0, 91, "Literal property lookup") +assert(result0, isLessThanOrEqual = 91, error = "Literal property lookup") +assert(result0, isGreaterThanOrEqual = 91, error = "Literal property lookup") // Test: computed index. @@ -21,5 +21,5 @@ assertGreaterThanOrEq(result0, 91, "Literal property lookup") i = int(1 + 0) result1 = arr[i] -assertLessThanOrEq(result1, 91, "Computed property lookup") -assertGreaterThanOrEq(result1, 91, "Computed property lookup") +assert(result1, isLessThanOrEqual = 91, error = "Computed property lookup") +assert(result1, isGreaterThanOrEqual = 91, error = "Computed property lookup") diff --git a/rust/kcl-lib/tests/kcl_samples/bracket/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/bracket/artifact_graph_flowchart.snap.md index 0cdc96878..f07464617 100644 --- a/rust/kcl-lib/tests/kcl_samples/bracket/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/bracket/artifact_graph_flowchart.snap.md @@ -1,28 +1,28 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[2001, 2026, 0]"] - 3["Segment
[2032, 2090, 0]"] - 4["Segment
[2096, 2135, 0]"] - 5["Segment
[2141, 2188, 0]"] - 6["Segment
[2194, 2240, 0]"] - 7["Segment
[2246, 2285, 0]"] - 8["Segment
[2291, 2361, 0]"] - 9["Segment
[2367, 2374, 0]"] + 2["Path
[2065, 2090, 0]"] + 3["Segment
[2096, 2154, 0]"] + 4["Segment
[2160, 2199, 0]"] + 5["Segment
[2205, 2252, 0]"] + 6["Segment
[2258, 2304, 0]"] + 7["Segment
[2310, 2349, 0]"] + 8["Segment
[2355, 2425, 0]"] + 9["Segment
[2431, 2438, 0]"] 10[Solid2d] end subgraph path32 [Path] - 32["Path
[2519, 2709, 0]"] - 33["Segment
[2519, 2709, 0]"] + 32["Path
[2583, 2773, 0]"] + 33["Segment
[2583, 2773, 0]"] 34[Solid2d] end subgraph path42 [Path] - 42["Path
[3143, 3345, 0]"] - 43["Segment
[3143, 3345, 0]"] + 42["Path
[3207, 3409, 0]"] + 43["Segment
[3207, 3409, 0]"] 44[Solid2d] end - 1["Plane
[1978, 1995, 0]"] - 11["Sweep Extrusion
[2380, 2406, 0]"] + 1["Plane
[2042, 2059, 0]"] + 11["Sweep Extrusion
[2444, 2470, 0]"] 12[Wall] 13[Wall] 14[Wall] @@ -43,26 +43,26 @@ flowchart LR 29["SweepEdge Adjacent"] 30["SweepEdge Opposite"] 31["SweepEdge Adjacent"] - 35["Sweep Extrusion
[2995, 3032, 0]"] + 35["Sweep Extrusion
[3059, 3096, 0]"] 36[Wall] 37["SweepEdge Opposite"] 38["SweepEdge Adjacent"] - 39["Sweep Extrusion
[2995, 3032, 0]"] - 40["Sweep Extrusion
[2995, 3032, 0]"] - 41["Sweep Extrusion
[2995, 3032, 0]"] - 45["Sweep Extrusion
[3460, 3497, 0]"] + 39["Sweep Extrusion
[3059, 3096, 0]"] + 40["Sweep Extrusion
[3059, 3096, 0]"] + 41["Sweep Extrusion
[3059, 3096, 0]"] + 45["Sweep Extrusion
[3524, 3561, 0]"] 46[Wall] 47["SweepEdge Opposite"] 48["SweepEdge Adjacent"] - 49["Sweep Extrusion
[3460, 3497, 0]"] - 50["EdgeCut Fillet
[3514, 3594, 0]"] - 51["EdgeCut Fillet
[3595, 3672, 0]"] - 52["EdgeCut Fillet
[3698, 3840, 0]"] - 53["EdgeCut Fillet
[3698, 3840, 0]"] - 54["EdgeCut Fillet
[3698, 3840, 0]"] - 55["EdgeCut Fillet
[3698, 3840, 0]"] - 56["StartSketchOnFace
[2473, 2513, 0]"] - 57["StartSketchOnFace
[3097, 3137, 0]"] + 49["Sweep Extrusion
[3524, 3561, 0]"] + 50["EdgeCut Fillet
[3578, 3658, 0]"] + 51["EdgeCut Fillet
[3659, 3736, 0]"] + 52["EdgeCut Fillet
[3762, 3904, 0]"] + 53["EdgeCut Fillet
[3762, 3904, 0]"] + 54["EdgeCut Fillet
[3762, 3904, 0]"] + 55["EdgeCut Fillet
[3762, 3904, 0]"] + 56["StartSketchOnFace
[2537, 2577, 0]"] + 57["StartSketchOnFace
[3161, 3201, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap b/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap index c9163d778..310029bcb 100644 --- a/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/bracket/ast.snap @@ -771,65 +771,69 @@ description: Result of parsing bracket.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "wallMountLength", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "arg": { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallMountingHoleDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallMountingHoleDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "3", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 3.0, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 0, - "end": 0, - "raw": "3", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 3.0, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Holes not possible. Either decrease hole diameter or increase wallMountLength\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Holes not possible. Either decrease hole diameter or increase wallMountLength" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Holes not possible. Either decrease hole diameter or increase wallMountLength\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Holes not possible. Either decrease hole diameter or increase wallMountLength" + } } ], "callee": { @@ -839,7 +843,7 @@ description: Result of parsing bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -850,8 +854,24 @@ description: Result of parsing bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "wallMountLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "preComments": [ "", @@ -868,65 +888,69 @@ description: Result of parsing bracket.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "shelfMountLength", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "arg": { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "shelfMountingHoleDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "shelfMountingHoleDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "5.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.5, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 0, - "end": 0, - "raw": "5.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.5, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "wallMountLength must be longer for hole sizes to work. Either decrease mounting hole diameters or increase shelfMountLength" + } } ], "callee": { @@ -936,7 +960,7 @@ description: Result of parsing bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -947,8 +971,24 @@ description: Result of parsing bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "shelfMountLength", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -960,65 +1000,69 @@ description: Result of parsing bracket.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "width", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "arg": { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "shelfMountingHoleDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "shelfMountingHoleDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "5.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.5, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 0, - "end": 0, - "raw": "5.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.5, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Holes not possible. Either decrease hole diameter or increase width\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Holes not possible. Either decrease hole diameter or increase width" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Holes not possible. Either decrease hole diameter or increase width\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Holes not possible. Either decrease hole diameter or increase width" + } } ], "callee": { @@ -1028,7 +1072,7 @@ description: Result of parsing bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -1039,8 +1083,24 @@ description: Result of parsing bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -1052,65 +1112,69 @@ description: Result of parsing bracket.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "width", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "left": { - "abs_path": false, + "arg": { "commentStart": 0, "end": 0, - "name": { + "left": { + "abs_path": false, "commentStart": 0, "end": 0, - "name": "wallMountingHoleDiameter", + "name": { + "commentStart": 0, + "end": 0, + "name": "wallMountingHoleDiameter", + "start": 0, + "type": "Identifier" + }, + "path": [], "start": 0, - "type": "Identifier" + "type": "Name", + "type": "Name" + }, + "operator": "*", + "right": { + "commentStart": 0, + "end": 0, + "raw": "5.5", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 5.5, + "suffix": "None" + } }, - "path": [], "start": 0, - "type": "Name", - "type": "Name" - }, - "operator": "*", - "right": { - "commentStart": 0, - "end": 0, - "raw": "5.5", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 5.5, - "suffix": "None" - } - }, - "start": 0, - "type": "BinaryExpression", - "type": "BinaryExpression" + "type": "BinaryExpression", + "type": "BinaryExpression" + } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Holes not possible. Either decrease hole diameter or increase width\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Holes not possible. Either decrease hole diameter or increase width" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Holes not possible. Either decrease hole diameter or increase width\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Holes not possible. Either decrease hole diameter or increase width" + } } ], "callee": { @@ -1120,7 +1184,7 @@ description: Result of parsing bracket.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -1131,8 +1195,24 @@ description: Result of parsing bracket.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "width", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/kcl_samples/bracket/program_memory.snap b/rust/kcl-lib/tests/kcl_samples/bracket/program_memory.snap index 0f75369e1..e2d0c594a 100644 --- a/rust/kcl-lib/tests/kcl_samples/bracket/program_memory.snap +++ b/rust/kcl-lib/tests/kcl_samples/bracket/program_memory.snap @@ -28,9 +28,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -41,9 +41,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -54,9 +54,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -67,9 +67,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -80,9 +80,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -93,9 +93,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -116,9 +116,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -141,9 +141,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -166,9 +166,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -191,9 +191,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -216,9 +216,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -241,9 +241,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -609,9 +609,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -622,9 +622,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -635,9 +635,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -648,9 +648,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -661,9 +661,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -674,9 +674,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -697,9 +697,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -722,9 +722,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -747,9 +747,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -772,9 +772,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -797,9 +797,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -822,9 +822,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -1075,9 +1075,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -1088,9 +1088,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -1101,9 +1101,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -1114,9 +1114,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -1127,9 +1127,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -1140,9 +1140,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -1163,9 +1163,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -1188,9 +1188,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -1213,9 +1213,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -1238,9 +1238,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -1263,9 +1263,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -1288,9 +1288,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -1541,9 +1541,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -1554,9 +1554,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -1567,9 +1567,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -1580,9 +1580,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -1593,9 +1593,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -1606,9 +1606,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -1629,9 +1629,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -1654,9 +1654,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -1679,9 +1679,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -1704,9 +1704,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -1729,9 +1729,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -1754,9 +1754,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -2007,9 +2007,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -2020,9 +2020,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -2033,9 +2033,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -2046,9 +2046,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -2059,9 +2059,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -2072,9 +2072,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -2095,9 +2095,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -2120,9 +2120,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -2145,9 +2145,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -2170,9 +2170,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -2195,9 +2195,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -2220,9 +2220,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -2543,9 +2543,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -2556,9 +2556,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -2569,9 +2569,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -2582,9 +2582,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -2595,9 +2595,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -2608,9 +2608,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -2631,9 +2631,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -2656,9 +2656,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -2681,9 +2681,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -2706,9 +2706,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -2731,9 +2731,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -2756,9 +2756,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -3009,9 +3009,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -3022,9 +3022,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -3035,9 +3035,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -3048,9 +3048,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -3061,9 +3061,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -3074,9 +3074,9 @@ description: Variables in memory after executing bracket.kcl "id": "[uuid]", "sourceRange": [], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, @@ -3097,9 +3097,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2083, - "end": 2089, - "start": 2083, + "commentStart": 2147, + "end": 2153, + "start": 2147, "type": "TagDeclarator", "value": "seg01" }, @@ -3122,9 +3122,9 @@ description: Variables in memory after executing bracket.kcl 0.0 ], "tag": { - "commentStart": 2128, - "end": 2134, - "start": 2128, + "commentStart": 2192, + "end": 2198, + "start": 2192, "type": "TagDeclarator", "value": "seg02" }, @@ -3147,9 +3147,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2181, - "end": 2187, - "start": 2181, + "commentStart": 2245, + "end": 2251, + "start": 2245, "type": "TagDeclarator", "value": "seg03" }, @@ -3172,9 +3172,9 @@ description: Variables in memory after executing bracket.kcl 0.3849 ], "tag": { - "commentStart": 2233, - "end": 2239, - "start": 2233, + "commentStart": 2297, + "end": 2303, + "start": 2297, "type": "TagDeclarator", "value": "seg04" }, @@ -3197,9 +3197,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2278, - "end": 2284, - "start": 2278, + "commentStart": 2342, + "end": 2348, + "start": 2342, "type": "TagDeclarator", "value": "seg05" }, @@ -3222,9 +3222,9 @@ description: Variables in memory after executing bracket.kcl -1.8651 ], "tag": { - "commentStart": 2354, - "end": 2360, - "start": 2354, + "commentStart": 2418, + "end": 2424, + "start": 2418, "type": "TagDeclarator", "value": "seg06" }, diff --git a/rust/kcl-lib/tests/kcl_samples/flange/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/flange/artifact_graph_flowchart.snap.md index c060eea00..fa13792b1 100644 --- a/rust/kcl-lib/tests/kcl_samples/flange/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/flange/artifact_graph_flowchart.snap.md @@ -1,55 +1,55 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[850, 935, 0]"] - 3["Segment
[850, 935, 0]"] + 2["Path
[863, 948, 0]"] + 3["Segment
[863, 948, 0]"] 4[Solid2d] end subgraph path6 [Path] - 6["Path
[1172, 1217, 0]"] - 7["Segment
[1172, 1217, 0]"] + 6["Path
[1185, 1230, 0]"] + 7["Segment
[1185, 1230, 0]"] 8[Solid2d] end subgraph path15 [Path] - 15["Path
[1390, 1444, 0]"] - 16["Segment
[1390, 1444, 0]"] + 15["Path
[1403, 1457, 0]"] + 16["Segment
[1403, 1457, 0]"] 17[Solid2d] end subgraph path23 [Path] - 23["Path
[1607, 1664, 0]"] - 24["Segment
[1607, 1664, 0]"] + 23["Path
[1620, 1677, 0]"] + 24["Segment
[1620, 1677, 0]"] 25[Solid2d] end subgraph path31 [Path] - 31["Path
[1799, 1844, 0]"] - 32["Segment
[1799, 1844, 0]"] + 31["Path
[1812, 1857, 0]"] + 32["Segment
[1812, 1857, 0]"] 33[Solid2d] end - 1["Plane
[827, 844, 0]"] - 5["Plane
[1149, 1166, 0]"] - 9["Sweep Extrusion
[1245, 1276, 0]"] + 1["Plane
[840, 857, 0]"] + 5["Plane
[1162, 1179, 0]"] + 9["Sweep Extrusion
[1258, 1289, 0]"] 10[Wall] 11["Cap Start"] 12["Cap End"] 13["SweepEdge Opposite"] 14["SweepEdge Adjacent"] - 18["Sweep Extrusion
[1450, 1485, 0]"] + 18["Sweep Extrusion
[1463, 1498, 0]"] 19[Wall] 20["Cap End"] 21["SweepEdge Opposite"] 22["SweepEdge Adjacent"] - 26["Sweep Extrusion
[1670, 1703, 0]"] + 26["Sweep Extrusion
[1683, 1716, 0]"] 27[Wall] 28["Cap End"] 29["SweepEdge Opposite"] 30["SweepEdge Adjacent"] - 34["Sweep Extrusion
[1850, 1925, 0]"] + 34["Sweep Extrusion
[1863, 1938, 0]"] 35[Wall] 36["SweepEdge Opposite"] 37["SweepEdge Adjacent"] - 38["StartSketchOnFace
[1347, 1384, 0]"] - 39["StartSketchOnFace
[1562, 1601, 0]"] - 40["StartSketchOnFace
[1754, 1793, 0]"] + 38["StartSketchOnFace
[1360, 1397, 0]"] + 39["StartSketchOnFace
[1575, 1614, 0]"] + 40["StartSketchOnFace
[1767, 1806, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/flange/ast.snap b/rust/kcl-lib/tests/kcl_samples/flange/ast.snap index b12a8402a..96a17d5be 100644 --- a/rust/kcl-lib/tests/kcl_samples/flange/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/flange/ast.snap @@ -429,41 +429,45 @@ description: Result of parsing flange.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "nHoles", + "name": "isGreaterThan", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"nHoles must be greater than 1\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "nHoles must be greater than 1" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"nHoles must be greater than 1\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "nHoles must be greater than 1" + } } ], "callee": { @@ -473,7 +477,7 @@ description: Result of parsing flange.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThan", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -484,8 +488,24 @@ description: Result of parsing flange.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "nHoles", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "preComments": [ "", diff --git a/rust/kcl-lib/tests/kcl_samples/lego/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/lego/artifact_graph_flowchart.snap.md index e21d54236..2535c0501 100644 --- a/rust/kcl-lib/tests/kcl_samples/lego/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/lego/artifact_graph_flowchart.snap.md @@ -1,33 +1,33 @@ ```mermaid flowchart LR subgraph path2 [Path] - 2["Path
[993, 1047, 0]"] - 3["Segment
[1053, 1080, 0]"] - 4["Segment
[1086, 1114, 0]"] - 5["Segment
[1120, 1148, 0]"] - 6["Segment
[1154, 1161, 0]"] + 2["Path
[1019, 1073, 0]"] + 3["Segment
[1079, 1106, 0]"] + 4["Segment
[1112, 1140, 0]"] + 5["Segment
[1146, 1174, 0]"] + 6["Segment
[1180, 1187, 0]"] 7[Solid2d] end subgraph path23 [Path] - 23["Path
[1408, 1495, 0]"] - 24["Segment
[1501, 1538, 0]"] - 25["Segment
[1544, 1582, 0]"] - 26["Segment
[1588, 1628, 0]"] - 27["Segment
[1634, 1641, 0]"] + 23["Path
[1434, 1521, 0]"] + 24["Segment
[1527, 1564, 0]"] + 25["Segment
[1570, 1608, 0]"] + 26["Segment
[1614, 1654, 0]"] + 27["Segment
[1660, 1667, 0]"] 28[Solid2d] end subgraph path43 [Path] - 43["Path
[1765, 1912, 0]"] - 44["Segment
[1765, 1912, 0]"] + 43["Path
[1791, 1938, 0]"] + 44["Segment
[1791, 1938, 0]"] 45[Solid2d] end subgraph path56 [Path] - 56["Path
[2202, 2377, 0]"] - 57["Segment
[2202, 2377, 0]"] + 56["Path
[2228, 2403, 0]"] + 57["Segment
[2228, 2403, 0]"] 58[Solid2d] end - 1["Plane
[970, 987, 0]"] - 8["Sweep Extrusion
[1167, 1191, 0]"] + 1["Plane
[996, 1013, 0]"] + 8["Sweep Extrusion
[1193, 1217, 0]"] 9[Wall] 10[Wall] 11[Wall] @@ -42,7 +42,7 @@ flowchart LR 20["SweepEdge Adjacent"] 21["SweepEdge Opposite"] 22["SweepEdge Adjacent"] - 29["Sweep Extrusion
[1647, 1678, 0]"] + 29["Sweep Extrusion
[1673, 1704, 0]"] 30[Wall] 31[Wall] 32[Wall] @@ -56,25 +56,25 @@ flowchart LR 40["SweepEdge Adjacent"] 41["SweepEdge Opposite"] 42["SweepEdge Adjacent"] - 46["Sweep Extrusion
[2066, 2094, 0]"] + 46["Sweep Extrusion
[2092, 2120, 0]"] 47[Wall] 48["Cap End"] 49["SweepEdge Opposite"] 50["SweepEdge Adjacent"] - 51["Sweep Extrusion
[2066, 2094, 0]"] - 52["Sweep Extrusion
[2066, 2094, 0]"] - 53["Sweep Extrusion
[2066, 2094, 0]"] - 54["Sweep Extrusion
[2066, 2094, 0]"] - 55["Sweep Extrusion
[2066, 2094, 0]"] - 59["Sweep Extrusion
[2539, 2567, 0]"] + 51["Sweep Extrusion
[2092, 2120, 0]"] + 52["Sweep Extrusion
[2092, 2120, 0]"] + 53["Sweep Extrusion
[2092, 2120, 0]"] + 54["Sweep Extrusion
[2092, 2120, 0]"] + 55["Sweep Extrusion
[2092, 2120, 0]"] + 59["Sweep Extrusion
[2565, 2593, 0]"] 60[Wall] 61["Cap End"] 62["SweepEdge Opposite"] 63["SweepEdge Adjacent"] - 64["Sweep Extrusion
[2539, 2567, 0]"] - 65["StartSketchOnFace
[1369, 1402, 0]"] - 66["StartSketchOnFace
[1728, 1759, 0]"] - 67["StartSketchOnFace
[2155, 2196, 0]"] + 64["Sweep Extrusion
[2565, 2593, 0]"] + 65["StartSketchOnFace
[1395, 1428, 0]"] + 66["StartSketchOnFace
[1754, 1785, 0]"] + 67["StartSketchOnFace
[2181, 2222, 0]"] 1 --- 2 2 --- 3 2 --- 4 diff --git a/rust/kcl-lib/tests/kcl_samples/lego/ast.snap b/rust/kcl-lib/tests/kcl_samples/lego/ast.snap index 4e73a981f..734bb14be 100644 --- a/rust/kcl-lib/tests/kcl_samples/lego/ast.snap +++ b/rust/kcl-lib/tests/kcl_samples/lego/ast.snap @@ -768,41 +768,45 @@ description: Result of parsing lego.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "lbumps", + "name": "isGreaterThan", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"lbumps must be greater than 1\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "lbumps must be greater than 1" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"lbumps must be greater than 1\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "lbumps must be greater than 1" + } } ], "callee": { @@ -812,7 +816,7 @@ description: Result of parsing lego.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThan", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -823,8 +827,24 @@ description: Result of parsing lego.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "lbumps", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "preComments": [ "", @@ -841,41 +861,45 @@ description: Result of parsing lego.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "wbumps", + "name": "isGreaterThan", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"wbumps must be greater than 1\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "wbumps must be greater than 1" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"wbumps must be greater than 1\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "wbumps must be greater than 1" + } } ], "callee": { @@ -885,7 +909,7 @@ description: Result of parsing lego.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThan", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -896,8 +920,24 @@ description: Result of parsing lego.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "wbumps", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_is0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_is0.png new file mode 100644 index 0000000000000000000000000000000000000000..6148ae43278779b7986fcf452545890b852f2298 GIT binary patch literal 19651 zcmeI4!7GDd9LHZon&jl-C?`jbifD_Wg*HnO<%C>TLrTg;TO6%imK>1PyBpbs3rUL0 zPI6f(DJusDD_-y9@O7zy<^`dWOJWi%OeMudj2T?$#d1Eo(R#^!J8Ws$MT@_Sz;=S8vX8ar^rAFg7%6FFu_7KIXR4sljZz zqqDX6v2;4Wda&8Gkk58M_cj%dGj{H!@>1$a+(e>N@qFdweZ6_d`=;EB)86iVQ#|iP z!k#U;tvi{cNw1dN_nheHnMe1^UH;1M$2_`M{-Dq4z*FUze#TikPckqgqI_dA{h5l! z++dB#+{oC7hYCO9Arl1gKs+E1698dFGa5j!MgzLntcSEkvQ5N8mkSxREElW+aX%0b z#Djc{djE0W62PRE xN<2F@{=~Cm<4-+1!~^jlA5)0rkJ=KSWhV+DQx8VLcnH3C#{C3~W#y8*Q5*+{l literal 0 HcmV?d00001 diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png new file mode 100644 index 0000000000000000000000000000000000000000..6148ae43278779b7986fcf452545890b852f2298 GIT binary patch literal 19651 zcmeI4!7GDd9LHZon&jl-C?`jbifD_Wg*HnO<%C>TLrTg;TO6%imK>1PyBpbs3rUL0 zPI6f(DJusDD_-y9@O7zy<^`dWOJWi%OeMudj2T?$#d1Eo(R#^!J8Ws$MT@_Sz;=S8vX8ar^rAFg7%6FFu_7KIXR4sljZz zqqDX6v2;4Wda&8Gkk58M_cj%dGj{H!@>1$a+(e>N@qFdweZ6_d`=;EB)86iVQ#|iP z!k#U;tvi{cNw1dN_nheHnMe1^UH;1M$2_`M{-Dq4z*FUze#TikPckqgqI_dA{h5l! z++dB#+{oC7hYCO9Arl1gKs+E1698dFGa5j!MgzLntcSEkvQ5N8mkSxREElW+aX%0b z#Djc{djE0W62PRE xN<2F@{=~Cm<4-+1!~^jlA5)0rkJ=KSWhV+DQx8VLcnH3C#{C3~W#y8*Q5*+{l literal 0 HcmV?d00001 diff --git a/rust/kcl-lib/tests/property_of_object/ast.snap b/rust/kcl-lib/tests/property_of_object/ast.snap index 6b958759f..677c2933d 100644 --- a/rust/kcl-lib/tests/property_of_object/ast.snap +++ b/rust/kcl-lib/tests/property_of_object/ast.snap @@ -137,41 +137,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_a", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -181,7 +185,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -192,8 +196,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_a", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -205,41 +225,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_a", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -249,7 +273,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -260,8 +284,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_a", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -348,41 +388,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_b", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -392,7 +436,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -403,8 +447,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_b", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -416,41 +476,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_b", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -460,7 +524,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -471,8 +535,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_b", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -605,41 +685,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_c", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -649,7 +733,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -660,8 +744,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_c", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -673,41 +773,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_c", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Literal property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Literal property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Literal property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Literal property lookup" + } } ], "callee": { @@ -717,7 +821,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -728,8 +832,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_c", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -802,41 +922,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_d", + "name": "isLessThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -846,7 +970,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertLessThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -857,8 +981,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_d", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", @@ -870,41 +1010,45 @@ description: Result of parsing property_of_object.kcl "expression": { "arguments": [ { - "abs_path": false, - "commentStart": 0, - "end": 0, - "name": { + "type": "LabeledArg", + "label": { "commentStart": 0, "end": 0, - "name": "one_d", + "name": "isGreaterThanOrEqual", "start": 0, "type": "Identifier" }, - "path": [], - "start": 0, - "type": "Name", - "type": "Name" - }, - { - "commentStart": 0, - "end": 0, - "raw": "1", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": { - "value": 1.0, - "suffix": "None" + "arg": { + "commentStart": 0, + "end": 0, + "raw": "1", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": { + "value": 1.0, + "suffix": "None" + } } }, { - "commentStart": 0, - "end": 0, - "raw": "\"Computed property lookup\"", - "start": 0, - "type": "Literal", - "type": "Literal", - "value": "Computed property lookup" + "type": "LabeledArg", + "label": { + "commentStart": 0, + "end": 0, + "name": "error", + "start": 0, + "type": "Identifier" + }, + "arg": { + "commentStart": 0, + "end": 0, + "raw": "\"Computed property lookup\"", + "start": 0, + "type": "Literal", + "type": "Literal", + "value": "Computed property lookup" + } } ], "callee": { @@ -914,7 +1058,7 @@ description: Result of parsing property_of_object.kcl "name": { "commentStart": 0, "end": 0, - "name": "assertGreaterThanOrEq", + "name": "assert", "start": 0, "type": "Identifier" }, @@ -925,8 +1069,24 @@ description: Result of parsing property_of_object.kcl "commentStart": 0, "end": 0, "start": 0, - "type": "CallExpression", - "type": "CallExpression" + "type": "CallExpressionKw", + "type": "CallExpressionKw", + "unlabeled": { + "abs_path": false, + "commentStart": 0, + "end": 0, + "name": { + "commentStart": 0, + "end": 0, + "name": "one_d", + "start": 0, + "type": "Identifier" + }, + "path": [], + "start": 0, + "type": "Name", + "type": "Name" + } }, "start": 0, "type": "ExpressionStatement", diff --git a/rust/kcl-lib/tests/property_of_object/input.kcl b/rust/kcl-lib/tests/property_of_object/input.kcl index 9e23c2b3f..34c751643 100644 --- a/rust/kcl-lib/tests/property_of_object/input.kcl +++ b/rust/kcl-lib/tests/property_of_object/input.kcl @@ -8,8 +8,8 @@ obj = { foo = 1, bar = 0 } one_a = obj["foo"] -assertLessThanOrEq(one_a, 1, "Literal property lookup") -assertGreaterThanOrEq(one_a, 1, "Literal property lookup") +assert(one_a, isLessThanOrEqual = 1, error = "Literal property lookup") +assert(one_a, isGreaterThanOrEqual = 1, error = "Literal property lookup") // Test: the property is a variable, // which must be evaluated before looking it up. @@ -18,8 +18,8 @@ assertGreaterThanOrEq(one_a, 1, "Literal property lookup") p = "foo" one_b = obj[p] -assertLessThanOrEq(one_b, 1, "Computed property lookup") -assertGreaterThanOrEq(one_b, 1, "Computed property lookup") +assert(one_b, isLessThanOrEqual = 1, error = "Computed property lookup") +assert(one_b, isGreaterThanOrEqual = 1, error = "Computed property lookup") // Test: multiple literal properties. @@ -28,13 +28,13 @@ obj2 = { inner = obj } one_c = obj2.inner["foo"] -assertLessThanOrEq(one_c, 1, "Literal property lookup") -assertGreaterThanOrEq(one_c, 1, "Literal property lookup") +assert(one_c, isLessThanOrEqual = 1, error = "Literal property lookup") +assert(one_c, isGreaterThanOrEqual = 1, error = "Literal property lookup") // Test: multiple properties, mix of literal and computed. one_d = obj2.inner[p] -assertLessThanOrEq(one_d, 1, "Computed property lookup") -assertGreaterThanOrEq(one_d, 1, "Computed property lookup") +assert(one_d, isLessThanOrEqual = 1, error = "Computed property lookup") +assert(one_d, isGreaterThanOrEqual = 1, error = "Computed property lookup") diff --git a/rust/kcl-lib/tests/property_of_object/unparsed.snap b/rust/kcl-lib/tests/property_of_object/unparsed.snap index 518d2fd6a..06301f1aa 100644 --- a/rust/kcl-lib/tests/property_of_object/unparsed.snap +++ b/rust/kcl-lib/tests/property_of_object/unparsed.snap @@ -12,8 +12,8 @@ obj = { foo = 1, bar = 0 } one_a = obj["foo"] -assertLessThanOrEq(one_a, 1, "Literal property lookup") -assertGreaterThanOrEq(one_a, 1, "Literal property lookup") +assert(one_a, isLessThanOrEqual = 1, error = "Literal property lookup") +assert(one_a, isGreaterThanOrEqual = 1, error = "Literal property lookup") // Test: the property is a variable, // which must be evaluated before looking it up. @@ -22,8 +22,8 @@ assertGreaterThanOrEq(one_a, 1, "Literal property lookup") p = "foo" one_b = obj[p] -assertLessThanOrEq(one_b, 1, "Computed property lookup") -assertGreaterThanOrEq(one_b, 1, "Computed property lookup") +assert(one_b, isLessThanOrEqual = 1, error = "Computed property lookup") +assert(one_b, isGreaterThanOrEqual = 1, error = "Computed property lookup") // Test: multiple literal properties. @@ -32,13 +32,13 @@ obj2 = { inner = obj } one_c = obj2.inner["foo"] -assertLessThanOrEq(one_c, 1, "Literal property lookup") -assertGreaterThanOrEq(one_c, 1, "Literal property lookup") +assert(one_c, isLessThanOrEqual = 1, error = "Literal property lookup") +assert(one_c, isGreaterThanOrEqual = 1, error = "Literal property lookup") // Test: multiple properties, mix of literal and computed. one_d = obj2.inner[p] -assertLessThanOrEq(one_d, 1, "Computed property lookup") -assertGreaterThanOrEq(one_d, 1, "Computed property lookup") +assert(one_d, isLessThanOrEqual = 1, error = "Computed property lookup") +assert(one_d, isGreaterThanOrEqual = 1, error = "Computed property lookup")