Compare commits
	
		
			75 Commits
		
	
	
		
			nightly-v2
			...
			jtran/fix-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0c2f63b399 | |||
| 363ae10658 | |||
| ac4a6c84cf | |||
| c6fad2e2dc | |||
| 013cb10961 | |||
| 6261083cb1 | |||
| 2b0ba37ed0 | |||
| 96174f3cf6 | |||
| aed62ff912 | |||
| 9334d64608 | |||
| 4fa7d2d8c8 | |||
| 3e615dfdbc | |||
| c9860af29f | |||
| 23a42f0195 | |||
| a77fa639f3 | |||
| 0a5ad7c95b | |||
| 4a654523d2 | |||
| 73a7e2bfd6 | |||
| eb0850fea9 | |||
| 029f76f273 | |||
| 28b5f7080c | |||
| 5b1dcfecd6 | |||
| f89d191425 | |||
| 2f4e4b62a8 | |||
| 5ebd5c8dbb | |||
| a9ceaf2678 | |||
| c8afd3399b | |||
| 5dda4828c6 | |||
| 72acab752c | |||
| 81df38ad1c | |||
| 0576a2bef1 | |||
| 4b2f6b4647 | |||
| 69edaa4183 | |||
| 2eb7c382bf | |||
| 38913ecb98 | |||
| debd06129f | |||
| d38bd342a0 | |||
| f026f10335 | |||
| 895d7ebc6d | |||
| 65edf17a44 | |||
| 0c2a0a8c07 | |||
| 97cef4d16c | |||
| 9358278f7b | |||
| a174e084d4 | |||
| df7246897a | |||
| 0c9f64dd7c | |||
| d2b9d3a058 | |||
| 7e54f08778 | |||
| d9c2dd376e | |||
| 275a2150e7 | |||
| 8b8feb8d68 | |||
| e21ef3f122 | |||
| 66834931aa | |||
| 06c1bcaf2e | |||
| fc7df7ecbe | |||
| 67cb7b33bb | |||
| ea74b94fac | |||
| 529833c63f | |||
| 92da86391a | |||
| e7cb390db4 | |||
| 8a66bbbdbd | |||
| 3c53babb50 | |||
| 474acb1c68 | |||
| 1c941112d7 | |||
| 6f1d718097 | |||
| 36957237c0 | |||
| da9cae98aa | |||
| 9ae025dc56 | |||
| 579ab23d78 | |||
| 4bef33e745 | |||
| ac7bd28c5a | |||
| d478d81156 | |||
| 3d27f0191b | |||
| 30c2acd18a | |||
| a83b4b2145 | 
| @ -1,3 +1,3 @@ | ||||
| [codespell] | ||||
| ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,absolutey,atleast,ue,afterall | ||||
| skip: **/target,node_modules,build,**/Cargo.lock,./docs/kcl/*.md,.yarn.lock,**/yarn.lock,./openapi/*.json,./src/lib/machine-api.d.ts | ||||
| ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,atleast,ue,afterall | ||||
| skip: **/target,node_modules,build,dist,./out,**/Cargo.lock,./docs/kcl/*.md,.yarn.lock,**/yarn.lock,./openapi/*.json,./packages/codemirror-lang-kcl/test/all.test.ts,tsconfig.tsbuildinfo | ||||
|  | ||||
							
								
								
									
										12
									
								
								.eslintrc
									
									
									
									
									
								
							
							
						
						| @ -5,16 +5,24 @@ | ||||
|     }, | ||||
|     "plugins": [ | ||||
|       "css-modules", | ||||
|       "jest", | ||||
|       "react", | ||||
|       "suggest-no-throw", | ||||
|       "@typescript-eslint" | ||||
|     ], | ||||
|     "extends": [ | ||||
|       "react-app", | ||||
|       "react-app/jest", | ||||
|       "plugin:css-modules/recommended" | ||||
|     ], | ||||
|     "rules": { | ||||
|       "@typescript-eslint/no-floating-promises": "error", | ||||
|       "@typescript-eslint/no-misused-promises": "error", | ||||
|       "no-restricted-globals": [ | ||||
|         "error", | ||||
|         { | ||||
|           "name": "isNaN", | ||||
|           "message": "Use Number.isNaN() instead." | ||||
|         } | ||||
|       ], | ||||
|       "semi": [ | ||||
|         "error", | ||||
|         "never" | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						| @ -21,7 +21,7 @@ if [[ ! -f "test-results/.last-run.json" ]]; then | ||||
| fi | ||||
|  | ||||
| retry=1 | ||||
| max_retrys=4 | ||||
| max_retrys=5 | ||||
|  | ||||
| # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||
| while [[ $retry -le $max_retrys ]]; do | ||||
|  | ||||
							
								
								
									
										4
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @ -26,3 +26,7 @@ updates: | ||||
|     reviewers: | ||||
|       - adamchalmers | ||||
|       - jessfraz | ||||
|     groups: | ||||
|       serde-dependencies: | ||||
|         patterns: | ||||
|           - "serde*" | ||||
|  | ||||
							
								
								
									
										16
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @ -173,7 +173,13 @@ jobs: | ||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||
|         run: yarn electron-builder --config --publish always | ||||
|           DEBUG: "electron-notarize*" | ||||
|         # TODO: Fix electron-notarize flakes. The logs above should help gather more data on failures | ||||
|         uses: nick-fields/retry@v3.0.0 | ||||
|         with: | ||||
|           timeout_minutes: 10 | ||||
|           max_attempts: 3 | ||||
|           command: yarn electron-builder --config --publish always | ||||
|  | ||||
|       - name: List artifacts in out/ | ||||
|         run: ls -R out | ||||
| @ -228,7 +234,13 @@ jobs: | ||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||
|         run: yarn electron-builder --config --publish always | ||||
|           DEBUG: "electron-notarize*" | ||||
|         # TODO: Fix electron-notarize flakes. The logs above should help gather more data on failures | ||||
|         uses: nick-fields/retry@v3.0.0 | ||||
|         with: | ||||
|           timeout_minutes: 10 | ||||
|           max_attempts: 3 | ||||
|           command: yarn electron-builder --config --publish always | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|  | ||||
							
								
								
									
										8
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @ -18,7 +18,6 @@ permissions: | ||||
| jobs: | ||||
|  | ||||
|   check-rust-changes: | ||||
|     if: github.event.pull_request.draft == false | ||||
|     runs-on: ubuntu-latest | ||||
|     outputs: | ||||
|       rust-changed: ${{ steps.filter.outputs.rust }} | ||||
| @ -35,7 +34,6 @@ jobs: | ||||
|               - 'src/wasm-lib/**' | ||||
|  | ||||
|   electron: | ||||
|     if: github.event.pull_request.draft == false | ||||
|     timeout-minutes: 60 | ||||
|     name: playwright:electron:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} | ||||
|     strategy: | ||||
| @ -129,9 +127,12 @@ jobs: | ||||
|       shell: bash | ||||
|       run: yarn tron:package | ||||
|     - name: Run ubuntu/chrome snapshots | ||||
|       if: ${{ matrix.os == 'namespace-profile-ubuntu-8-cores' && matrix.shardIndex == 1 }} | ||||
|       shell: bash | ||||
|       # TODO: break this in its own job, for now it's not slowing down the overall execution as ubuntu is the quickest, | ||||
|       # but we could do better. This forces a large 1/1 shard of all 20 snapshot tests that runs in about 3 minutes. | ||||
|       run: | | ||||
|         PLATFORM=web yarn playwright test --config=playwright.config.ts --retries="3" --update-snapshots --grep=@snapshot  --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} | ||||
|         PLATFORM=web yarn playwright test --config=playwright.config.ts --retries="3" --update-snapshots --grep=@snapshot  --shard=1/1 | ||||
|       env: | ||||
|         CI: true | ||||
|         NODE_ENV: development | ||||
| @ -152,6 +153,7 @@ jobs: | ||||
|       continue-on-error: true | ||||
|       run: rm -r test-results | ||||
|     - name: check for changes | ||||
|       if: ${{ matrix.os == 'namespace-profile-ubuntu-8-cores' && matrix.shardIndex == 1 }} | ||||
|       shell: bash | ||||
|       id: git-check | ||||
|       run: | | ||||
|  | ||||
							
								
								
									
										40
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @ -337,13 +337,47 @@ For individual testing: | ||||
| yarn test abstractSyntaxTree -t "unexpected closed curly brace" --silent=false | ||||
| ``` | ||||
|  | ||||
| Which will run our suite of [Vitest unit](https://vitest.dev/) and [React Testing Library E2E](https://testing-library.com/docs/react-testing-library/intro/) tests, in interactive mode by default. | ||||
| Which will run our suite of [Vitest unit](https://vitest.dev/) and [React Testing Library E2E](https://testing-library.com/docs/react-testing-library/intro) tests, in interactive mode by default. | ||||
|  | ||||
| ### Rust tests | ||||
|  | ||||
| ```bash | ||||
| **Dependencies** | ||||
|  | ||||
| - `KITTYCAD_API_TOKEN` | ||||
| - `cargo-nextest` | ||||
| - `just` | ||||
|  | ||||
| #### Setting KITTYCAD_API_TOKEN | ||||
| Use the production zoo.dev token, set this environment variable before running the tests | ||||
|  | ||||
| #### Installing cargonextest | ||||
|  | ||||
| ``` | ||||
| cd src/wasm-lib | ||||
| KITTYCAD_API_TOKEN=XXX cargo test -- --test-threads=1 | ||||
| cargo search cargo-nextest | ||||
| cargo install cargo-nextest | ||||
| ``` | ||||
|  | ||||
| #### just | ||||
| install [`just`](https://github.com/casey/just?tab=readme-ov-file#pre-built-binaries) | ||||
|  | ||||
| #### Running the tests | ||||
|  | ||||
| ```bash | ||||
| # With just | ||||
| # Make sure KITTYCAD_API_TOKEN=<prod zoo.dev token> is set | ||||
| # Make sure you installed cargo-nextest | ||||
| # Make sure you installed just | ||||
| cd src/wasm-lib | ||||
| just test | ||||
| ``` | ||||
|  | ||||
| ```bash | ||||
| # Without just | ||||
| # Make sure KITTYCAD_API_TOKEN=<prod zoo.dev token> is set | ||||
| # Make sure you installed cargo-nextest | ||||
| cd src/wasm-lib | ||||
| export RUST_BRACKTRACE="full" && cargo nextest run --workspace --test-threads=1 | ||||
| ``` | ||||
|  | ||||
| Where `XXX` is an API token from the production engine (NOT the dev environment). | ||||
|  | ||||
| @ -24,3 +24,5 @@ once fixed in engine will just start working here with no language changes. | ||||
|     chamfer cases work currently. | ||||
|  | ||||
| - **Appearance**: Changing the appearance on a loft does not work. | ||||
|  | ||||
| - **Helix**: Currently sweeping a helix does not work. | ||||
|  | ||||
							
								
								
									
										42
									
								
								docs/kcl/circleThreePoint.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										43
									
								
								docs/kcl/helixRevolutions.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -35,6 +35,7 @@ layout: manual | ||||
| * [`ceil`](kcl/ceil) | ||||
| * [`chamfer`](kcl/chamfer) | ||||
| * [`circle`](kcl/circle) | ||||
| * [`circleThreePoint`](kcl/circleThreePoint) | ||||
| * [`close`](kcl/close) | ||||
| * [`cm`](kcl/cm) | ||||
| * [`cos`](kcl/cos) | ||||
| @ -47,6 +48,7 @@ layout: manual | ||||
| * [`getOppositeEdge`](kcl/getOppositeEdge) | ||||
| * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) | ||||
| * [`helix`](kcl/helix) | ||||
| * [`helixRevolutions`](kcl/helixRevolutions) | ||||
| * [`hole`](kcl/hole) | ||||
| * [`hollow`](kcl/hollow) | ||||
| * [`import`](kcl/import) | ||||
| @ -80,6 +82,7 @@ layout: manual | ||||
| * [`pi`](kcl/pi) | ||||
| * [`polar`](kcl/polar) | ||||
| * [`polygon`](kcl/polygon) | ||||
| * [`pop`](kcl/pop) | ||||
| * [`pow`](kcl/pow) | ||||
| * [`profileStart`](kcl/profileStart) | ||||
| * [`profileStartX`](kcl/profileStartX) | ||||
|  | ||||
							
								
								
									
										39
									
								
								docs/kcl/pop.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										10899
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
							
						
						| @ -1,19 +1,19 @@ | ||||
| --- | ||||
| title: "AxisOrEdgeReference" | ||||
| excerpt: "Axis or tagged edge." | ||||
| title: "Axis2dOrEdgeReference" | ||||
| excerpt: "A 2D axis or tagged edge." | ||||
| layout: manual | ||||
| --- | ||||
| 
 | ||||
| Axis or tagged edge. | ||||
| A 2D axis or tagged edge. | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| **This schema accepts any of the following:** | ||||
| 
 | ||||
| Axis and origin. | ||||
| 2D axis and origin. | ||||
| 
 | ||||
| [`AxisAndOrigin`](/docs/kcl/types/AxisAndOrigin) | ||||
| [`AxisAndOrigin2d`](/docs/kcl/types/AxisAndOrigin2d) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										42
									
								
								docs/kcl/types/Axis3dOrEdgeReference.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,42 @@ | ||||
| --- | ||||
| title: "Axis3dOrEdgeReference" | ||||
| excerpt: "A 3D axis or tagged edge." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A 3D axis or tagged edge. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| **This schema accepts any of the following:** | ||||
|  | ||||
| 3D axis and origin. | ||||
|  | ||||
| [`AxisAndOrigin3d`](/docs/kcl/types/AxisAndOrigin3d) | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Tagged edge. | ||||
|  | ||||
| [`EdgeReference`](/docs/kcl/types/EdgeReference) | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "AxisAndOrigin" | ||||
| excerpt: "Axis and origin." | ||||
| title: "AxisAndOrigin2d" | ||||
| excerpt: "A 2D axis and origin." | ||||
| layout: manual | ||||
| --- | ||||
| 
 | ||||
| Axis and origin. | ||||
| A 2D axis and origin. | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										105
									
								
								docs/kcl/types/AxisAndOrigin3d.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,105 @@ | ||||
| --- | ||||
| title: "AxisAndOrigin3d" | ||||
| excerpt: "A 3D axis and origin." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A 3D axis and origin. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| **This schema accepts exactly one of the following:** | ||||
|  | ||||
| X-axis. | ||||
|  | ||||
| **enum:** `X` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Y-axis. | ||||
|  | ||||
| **enum:** `Y` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Z-axis. | ||||
|  | ||||
| **enum:** `Z` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Flip the X-axis. | ||||
|  | ||||
| **enum:** `-X` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Flip the Y-axis. | ||||
|  | ||||
| **enum:** `-Y` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Flip the Z-axis. | ||||
|  | ||||
| **enum:** `-Z` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `custom` |`object`|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										23
									
								
								docs/kcl/types/CircleThreePointData.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,23 @@ | ||||
| --- | ||||
| title: "CircleThreePointData" | ||||
| excerpt: "Data for drawing a 3-point circle" | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Data for drawing a 3-point circle | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `p1` |`[number, number]`| Point one for circle derivation. | No | | ||||
| | `p2` |`[number, number]`| Point two for circle derivation. | No | | ||||
| | `p3` |`[number, number]`| Point three for circle derivation. | No | | ||||
|  | ||||
|  | ||||
							
								
								
									
										25
									
								
								docs/kcl/types/Helix.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,25 @@ | ||||
| --- | ||||
| title: "Helix" | ||||
| excerpt: "A helix." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A helix. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `value` |`string`| The id of the helix. | No | | ||||
| | `revolutions` |`number`| Number of revolutions. | No | | ||||
| | `angleStart` |`number`| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? | No | | ||||
| | `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`|  | No | | ||||
|  | ||||
|  | ||||
| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "HelixData" | ||||
| excerpt: "Data for helices." | ||||
| excerpt: "Data for a helix." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Data for helices. | ||||
| Data for a helix. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
| @ -19,6 +19,8 @@ Data for helices. | ||||
| | `revolutions` |`number`| Number of revolutions. | No | | ||||
| | `angleStart` |`number`| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? The default is `false`. | No | | ||||
| | `length` |`number`| Length of the helix. If this argument is not provided, the height of the solid is used. | No | | ||||
| | `length` |`number`| Length of the helix. | No | | ||||
| | `radius` |`number`| Radius of the helix. | No | | ||||
| | `axis` |[`Axis3dOrEdgeReference`](/docs/kcl/types/Axis3dOrEdgeReference)| Axis to use as mirror. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										24
									
								
								docs/kcl/types/HelixRevolutionsData.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,24 @@ | ||||
| --- | ||||
| title: "HelixRevolutionsData" | ||||
| excerpt: "Data for helix revolutions." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Data for helix revolutions. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `revolutions` |`number`| Number of revolutions. | No | | ||||
| | `angleStart` |`number`| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? The default is `false`. | No | | ||||
| | `length` |`number`| Length of the helix. If this argument is not provided, the height of the solid is used. | No | | ||||
|  | ||||
|  | ||||
							
								
								
									
										25
									
								
								docs/kcl/types/HelixValue.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,25 @@ | ||||
| --- | ||||
| title: "HelixValue" | ||||
| excerpt: "A helix." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A helix. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `value` |`string`| The id of the helix. | No | | ||||
| | `revolutions` |`number`| Number of revolutions. | No | | ||||
| | `angleStart` |`number`| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? | No | | ||||
| | `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`|  | No | | ||||
|  | ||||
|  | ||||
| @ -285,6 +285,27 @@ An solid is a collection of extrude surfaces. | ||||
| | `value` |`[` [`Solid`](/docs/kcl/types/Solid) `]`|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
| A helix. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: [`Helix`](/docs/kcl/types/Helix)|  | No | | ||||
| | `value` |`string`| The id of the helix. | No | | ||||
| | `revolutions` |`number`| Number of revolutions. | No | | ||||
| | `angleStart` |`number`| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? | No | | ||||
| | `__meta` |`[` [`Metadata`](/docs/kcl/types/Metadata) `]`|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
| Data for an imported geometry. | ||||
|  | ||||
|  | ||||
| @ -16,6 +16,6 @@ Data for a mirror. | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `axis` |[`AxisOrEdgeReference`](/docs/kcl/types/AxisOrEdgeReference)| Axis to use as mirror. | No | | ||||
| | `axis` |[`Axis2dOrEdgeReference`](/docs/kcl/types/Axis2dOrEdgeReference)| Axis to use as mirror. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -17,7 +17,7 @@ Data for revolution surfaces. | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `angle` |`number` (**maximum:** 360.0) (**minimum:** -360.0)| Angle to revolve (in degrees). Default is 360. | No | | ||||
| | `axis` |[`AxisOrEdgeReference`](/docs/kcl/types/AxisOrEdgeReference)| Axis of revolution. | No | | ||||
| | `axis` |[`Axis2dOrEdgeReference`](/docs/kcl/types/Axis2dOrEdgeReference)| Axis of revolution. | No | | ||||
| | `tolerance` |`number`| Tolerance for the revolve operation. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -16,7 +16,7 @@ Data for a sweep. | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `path` |[`Sketch`](/docs/kcl/types/Sketch)| The path to sweep along. | No | | ||||
| | `path` |[`SweepPath`](/docs/kcl/types/SweepPath)| The path to sweep along. | No | | ||||
| | `sectional` |`boolean`| If true, the sweep will be broken up into sub-sweeps (extrusions, revolves, sweeps) based on the trajectory path components. | No | | ||||
| | `tolerance` |`number`| Tolerance for the sweep operation. | No | | ||||
|  | ||||
|  | ||||
							
								
								
									
										42
									
								
								docs/kcl/types/SweepPath.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,42 @@ | ||||
| --- | ||||
| title: "SweepPath" | ||||
| excerpt: "A path to sweep along." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A path to sweep along. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| **This schema accepts any of the following:** | ||||
|  | ||||
| A path to sweep along. | ||||
|  | ||||
| [`Sketch`](/docs/kcl/types/Sketch) | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
| A path to sweep along. | ||||
|  | ||||
| [`Helix`](/docs/kcl/types/Helix) | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -36,7 +36,8 @@ type DragFromHandler = ( | ||||
|  | ||||
| export class SceneFixture { | ||||
|   public page: Page | ||||
|  | ||||
|   public streamWrapper!: Locator | ||||
|   public loadingIndicator!: Locator | ||||
|   private exeIndicator!: Locator | ||||
|  | ||||
|   constructor(page: Page) { | ||||
| @ -64,6 +65,8 @@ export class SceneFixture { | ||||
|     this.page = page | ||||
|  | ||||
|     this.exeIndicator = page.getByTestId('model-state-indicator-execution-done') | ||||
|     this.streamWrapper = page.getByTestId('stream') | ||||
|     this.loadingIndicator = this.streamWrapper.getByTestId('loading') | ||||
|   } | ||||
|  | ||||
|   makeMouseHelpers = ( | ||||
|  | ||||
| @ -14,6 +14,7 @@ export class ToolbarFixture { | ||||
|  | ||||
|   extrudeButton!: Locator | ||||
|   loftButton!: Locator | ||||
|   sweepButton!: Locator | ||||
|   shellButton!: Locator | ||||
|   offsetPlaneButton!: Locator | ||||
|   startSketchBtn!: Locator | ||||
| @ -40,6 +41,7 @@ export class ToolbarFixture { | ||||
|     this.page = page | ||||
|     this.extrudeButton = page.getByTestId('extrude') | ||||
|     this.loftButton = page.getByTestId('loft') | ||||
|     this.sweepButton = page.getByTestId('sweep') | ||||
|     this.shellButton = page.getByTestId('shell') | ||||
|     this.offsetPlaneButton = page.getByTestId('plane-offset') | ||||
|     this.startSketchBtn = page.getByTestId('sketch') | ||||
|  | ||||
| @ -756,6 +756,17 @@ test(`Offset plane point-and-click`, async ({ | ||||
|     }) | ||||
|     await scene.expectPixelColor([74, 74, 74], testPoint, 15) | ||||
|   }) | ||||
|  | ||||
|   await test.step('Delete offset plane via feature tree selection', async () => { | ||||
|     await editor.closePane() | ||||
|     const operationButton = await toolbar.getFeatureTreeOperation( | ||||
|       'Offset Plane', | ||||
|       0 | ||||
|     ) | ||||
|     await operationButton.click({ button: 'left' }) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     await scene.expectPixelColor([50, 51, 96], testPoint, 15) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| const loftPointAndClickCases = [ | ||||
| @ -851,6 +862,173 @@ loftPointAndClickCases.forEach(({ shouldPreselect }) => { | ||||
|       }) | ||||
|       await scene.expectPixelColor([89, 89, 89], testPoint, 15) | ||||
|     }) | ||||
|  | ||||
|     await test.step('Delete loft via feature tree selection', async () => { | ||||
|       await editor.closePane() | ||||
|       const operationButton = await toolbar.getFeatureTreeOperation('Loft', 0) | ||||
|       await operationButton.click({ button: 'left' }) | ||||
|       await page.keyboard.press('Backspace') | ||||
|       await scene.expectPixelColor([254, 254, 254], testPoint, 15) | ||||
|     }) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| // TODO: merge with above test. Right now we're not able to delete a loft | ||||
| // right after creation via selection for some reason, so we go with a new instance | ||||
| test('Loft and offset plane deletion via selection', async ({ | ||||
|   context, | ||||
|   page, | ||||
|   homePage, | ||||
|   scene, | ||||
| }) => { | ||||
|   const initialCode = `sketch001 = startSketchOn('XZ') | ||||
|   |> circle({ center = [0, 0], radius = 30 }, %) | ||||
|   plane001 = offsetPlane('XZ', 50) | ||||
|   sketch002 = startSketchOn(plane001) | ||||
|   |> circle({ center = [0, 0], radius = 20 }, %) | ||||
| loft001 = loft([sketch001, sketch002]) | ||||
| ` | ||||
|   await context.addInitScript((initialCode) => { | ||||
|     localStorage.setItem('persistCode', initialCode) | ||||
|   }, initialCode) | ||||
|   await page.setBodyDimensions({ width: 1000, height: 500 }) | ||||
|   await homePage.goToModelingScene() | ||||
|  | ||||
|   // One dumb hardcoded screen pixel value | ||||
|   const testPoint = { x: 575, y: 200 } | ||||
|   const [clickOnSketch1] = scene.makeMouseHelpers(testPoint.x, testPoint.y) | ||||
|   const [clickOnSketch2] = scene.makeMouseHelpers(testPoint.x, testPoint.y + 80) | ||||
|  | ||||
|   await test.step(`Delete loft`, async () => { | ||||
|     // Check for loft | ||||
|     await scene.expectPixelColor([89, 89, 89], testPoint, 15) | ||||
|     await clickOnSketch1() | ||||
|     await expect(page.locator('.cm-activeLine')).toHaveText(` | ||||
|       |> circle({ center = [0, 0], radius = 30 }, %) | ||||
|     `) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     // Check for sketch 1 | ||||
|     await scene.expectPixelColor([254, 254, 254], testPoint, 15) | ||||
|   }) | ||||
|  | ||||
|   await test.step('Delete sketch002', async () => { | ||||
|     await page.waitForTimeout(1000) | ||||
|     await clickOnSketch2() | ||||
|     await expect(page.locator('.cm-activeLine')).toHaveText(` | ||||
|       |> circle({ center = [0, 0], radius = 20 }, %) | ||||
|     `) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     // Check for plane001 | ||||
|     await scene.expectPixelColor([228, 228, 228], testPoint, 15) | ||||
|   }) | ||||
|  | ||||
|   await test.step('Delete plane001', async () => { | ||||
|     await page.waitForTimeout(1000) | ||||
|     await clickOnSketch2() | ||||
|     await expect(page.locator('.cm-activeLine')).toHaveText(` | ||||
|       plane001 = offsetPlane('XZ', 50) | ||||
|     `) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     // Check for sketch 1 | ||||
|     await scene.expectPixelColor([254, 254, 254], testPoint, 15) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| test(`Sweep point-and-click`, async ({ | ||||
|   context, | ||||
|   page, | ||||
|   homePage, | ||||
|   scene, | ||||
|   editor, | ||||
|   toolbar, | ||||
|   cmdBar, | ||||
| }) => { | ||||
|   const initialCode = `sketch001 = startSketchOn('YZ') | ||||
|   |> circle({ | ||||
|        center = [0, 0], | ||||
|        radius = 500 | ||||
|      }, %) | ||||
| sketch002 = startSketchOn('XZ') | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> xLine(-500, %) | ||||
|   |> tangentialArcTo([-2000, 500], %) | ||||
| ` | ||||
|   await context.addInitScript((initialCode) => { | ||||
|     localStorage.setItem('persistCode', initialCode) | ||||
|   }, initialCode) | ||||
|   await page.setBodyDimensions({ width: 1000, height: 500 }) | ||||
|   await homePage.goToModelingScene() | ||||
|   await scene.waitForExecutionDone() | ||||
|  | ||||
|   // One dumb hardcoded screen pixel value | ||||
|   const testPoint = { x: 700, y: 250 } | ||||
|   const [clickOnSketch1] = scene.makeMouseHelpers(testPoint.x, testPoint.y) | ||||
|   const [clickOnSketch2] = scene.makeMouseHelpers(testPoint.x - 50, testPoint.y) | ||||
|   const sweepDeclaration = 'sweep001 = sweep({ path = sketch002 }, sketch001)' | ||||
|  | ||||
|   await test.step(`Look for sketch001`, async () => { | ||||
|     await toolbar.closePane('code') | ||||
|     await scene.expectPixelColor([53, 53, 53], testPoint, 15) | ||||
|   }) | ||||
|  | ||||
|   await test.step(`Go through the command bar flow`, async () => { | ||||
|     await toolbar.sweepButton.click() | ||||
|     await cmdBar.expectState({ | ||||
|       commandName: 'Sweep', | ||||
|       currentArgKey: 'profile', | ||||
|       currentArgValue: '', | ||||
|       headerArguments: { | ||||
|         Path: '', | ||||
|         Profile: '', | ||||
|       }, | ||||
|       highlightedHeaderArg: 'profile', | ||||
|       stage: 'arguments', | ||||
|     }) | ||||
|     await clickOnSketch1() | ||||
|     await cmdBar.expectState({ | ||||
|       commandName: 'Sweep', | ||||
|       currentArgKey: 'path', | ||||
|       currentArgValue: '', | ||||
|       headerArguments: { | ||||
|         Path: '', | ||||
|         Profile: '1 face', | ||||
|       }, | ||||
|       highlightedHeaderArg: 'path', | ||||
|       stage: 'arguments', | ||||
|     }) | ||||
|     await clickOnSketch2() | ||||
|     await cmdBar.expectState({ | ||||
|       commandName: 'Sweep', | ||||
|       headerArguments: { | ||||
|         Path: '1 face', | ||||
|         Profile: '1 face', | ||||
|       }, | ||||
|       stage: 'review', | ||||
|     }) | ||||
|     await cmdBar.progressCmdBar() | ||||
|   }) | ||||
|  | ||||
|   await test.step(`Confirm code is added to the editor, scene has changed`, async () => { | ||||
|     await scene.expectPixelColor([135, 64, 73], testPoint, 15) | ||||
|     await toolbar.openPane('code') | ||||
|     await editor.expectEditor.toContain(sweepDeclaration) | ||||
|     await editor.expectState({ | ||||
|       diagnostics: [], | ||||
|       activeLines: [sweepDeclaration], | ||||
|       highlightedCode: '', | ||||
|     }) | ||||
|     await toolbar.closePane('code') | ||||
|   }) | ||||
|  | ||||
|   await test.step('Delete sweep via feature tree selection', async () => { | ||||
|     await toolbar.openPane('feature-tree') | ||||
|     await page.waitForTimeout(500) | ||||
|     const operationButton = await toolbar.getFeatureTreeOperation('Sweep', 0) | ||||
|     await operationButton.click({ button: 'left' }) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     await page.waitForTimeout(500) | ||||
|     await toolbar.closePane('feature-tree') | ||||
|     await scene.expectPixelColor([53, 53, 53], testPoint, 15) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| @ -1030,4 +1208,104 @@ extrude001 = extrude(40, sketch001) | ||||
|     }) | ||||
|     await scene.expectPixelColor([49, 49, 49], testPoint, 15) | ||||
|   }) | ||||
|  | ||||
|   await test.step('Delete shell via feature tree selection', async () => { | ||||
|     await editor.closePane() | ||||
|     const operationButton = await toolbar.getFeatureTreeOperation('Shell', 0) | ||||
|     await operationButton.click({ button: 'left' }) | ||||
|     await page.keyboard.press('Backspace') | ||||
|     await scene.expectPixelColor([99, 99, 99], testPoint, 15) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| const shellSketchOnFacesCases = [ | ||||
|   `sketch001 = startSketchOn('XZ') | ||||
|   |> circle({ center = [0, 0], radius = 100 }, %) | ||||
|   |> extrude(100, %) | ||||
|  | ||||
| sketch002 = startSketchOn(sketch001, 'END') | ||||
|   |> circle({ center = [0, 0], radius = 50 }, %) | ||||
|   |> extrude(50, %) | ||||
|   `, | ||||
|   `sketch001 = startSketchOn('XZ') | ||||
|   |> circle({ center = [0, 0], radius = 100 }, %) | ||||
| extrude001 = extrude(100, sketch001) | ||||
|  | ||||
| sketch002 = startSketchOn(extrude001, 'END') | ||||
|   |> circle({ center = [0, 0], radius = 50 }, %) | ||||
| extrude002 = extrude(50, sketch002) | ||||
|   `, | ||||
| ] | ||||
| shellSketchOnFacesCases.forEach((initialCode, index) => { | ||||
|   const hasExtrudesInPipe = index === 0 | ||||
|   test(`Shell point-and-click sketch on face (extrudes in pipes: ${hasExtrudesInPipe})`, async ({ | ||||
|     context, | ||||
|     page, | ||||
|     homePage, | ||||
|     scene, | ||||
|     editor, | ||||
|     toolbar, | ||||
|     cmdBar, | ||||
|   }) => { | ||||
|     await context.addInitScript((initialCode) => { | ||||
|       localStorage.setItem('persistCode', initialCode) | ||||
|     }, initialCode) | ||||
|     await page.setBodyDimensions({ width: 1000, height: 500 }) | ||||
|     await homePage.goToModelingScene() | ||||
|     await scene.waitForExecutionDone() | ||||
|  | ||||
|     // One dumb hardcoded screen pixel value | ||||
|     const testPoint = { x: 550, y: 295 } | ||||
|     const [clickOnCap] = scene.makeMouseHelpers(testPoint.x, testPoint.y) | ||||
|     const shellDeclaration = `shell001 = shell({ faces = ['end'], thickness = 5 }, ${ | ||||
|       hasExtrudesInPipe ? 'sketch002' : 'extrude002' | ||||
|     })` | ||||
|  | ||||
|     await test.step(`Look for the grey of the shape`, async () => { | ||||
|       await toolbar.closePane('code') | ||||
|       await scene.expectPixelColor([128, 128, 128], testPoint, 15) | ||||
|     }) | ||||
|  | ||||
|     await test.step(`Go through the command bar flow, selecting a cap and keeping default thickness`, async () => { | ||||
|       await toolbar.shellButton.click() | ||||
|       await cmdBar.expectState({ | ||||
|         stage: 'arguments', | ||||
|         currentArgKey: 'selection', | ||||
|         currentArgValue: '', | ||||
|         headerArguments: { | ||||
|           Selection: '', | ||||
|           Thickness: '', | ||||
|         }, | ||||
|         highlightedHeaderArg: 'selection', | ||||
|         commandName: 'Shell', | ||||
|       }) | ||||
|       await clickOnCap() | ||||
|       await page.waitForTimeout(500) | ||||
|       await cmdBar.progressCmdBar() | ||||
|       await page.waitForTimeout(500) | ||||
|       await cmdBar.progressCmdBar() | ||||
|       await page.waitForTimeout(500) | ||||
|       await cmdBar.expectState({ | ||||
|         stage: 'review', | ||||
|         headerArguments: { | ||||
|           Selection: '1 cap', | ||||
|           Thickness: '5', | ||||
|         }, | ||||
|         commandName: 'Shell', | ||||
|       }) | ||||
|       await cmdBar.progressCmdBar() | ||||
|     }) | ||||
|  | ||||
|     await test.step(`Confirm code is added to the editor, scene has changed`, async () => { | ||||
|       await toolbar.openPane('code') | ||||
|       await editor.expectEditor.toContain(shellDeclaration) | ||||
|       await editor.expectState({ | ||||
|         diagnostics: [], | ||||
|         activeLines: [shellDeclaration], | ||||
|         highlightedCode: '', | ||||
|       }) | ||||
|       await toolbar.closePane('code') | ||||
|       await scene.expectPixelColor([73, 73, 73], testPoint, 15) | ||||
|     }) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| @ -115,7 +115,7 @@ test( | ||||
| ) | ||||
|  | ||||
| test( | ||||
|   'yyyyyyyyy open a file in a project works and renders, open another file in different project with errors, it should clear the scene', | ||||
|   'open a file in a project works and renders, open another file in different project with errors, it should clear the scene', | ||||
|   { tag: '@electron' }, | ||||
|   async ({ context, page }, testInfo) => { | ||||
|     await context.folderSetupFn(async (dir) => { | ||||
| @ -199,7 +199,7 @@ test( | ||||
| ) | ||||
|  | ||||
| test( | ||||
|   'aaayyyyyyyy open a file in a project works and renders, open another file in different project that is empty, it should clear the scene', | ||||
|   'open a file in a project works and renders, open another file in different project that is empty, it should clear the scene', | ||||
|   { tag: '@electron' }, | ||||
|   async ({ context, page }, testInfo) => { | ||||
|     await context.folderSetupFn(async (dir) => { | ||||
| @ -276,7 +276,7 @@ test( | ||||
| ) | ||||
|  | ||||
| test( | ||||
|   'nooooooooooooo open a file in a project works and renders, open empty file, it should clear the scene', | ||||
|   'open a file in a project works and renders, open empty file, it should clear the scene', | ||||
|   { tag: '@electron' }, | ||||
|   async ({ context, page }, testInfo) => { | ||||
|     await context.folderSetupFn(async (dir) => { | ||||
| @ -1885,3 +1885,48 @@ test.fixme( | ||||
|     }) | ||||
|   } | ||||
| ) | ||||
|  | ||||
| test( | ||||
|   'project name with foreign characters should open', | ||||
|   { tag: '@electron' }, | ||||
|   async ({ context, page }, testInfo) => { | ||||
|     await context.folderSetupFn(async (dir) => { | ||||
|       const bracketDir = path.join(dir, 'اَلْعَرَبِيَّةُ') | ||||
|       await fsp.mkdir(bracketDir, { recursive: true }) | ||||
|       await fsp.copyFile( | ||||
|         executorInputPath('focusrite_scarlett_mounting_braket.kcl'), | ||||
|         path.join(bracketDir, 'main.kcl') | ||||
|       ) | ||||
|  | ||||
|       await fsp.writeFile(path.join(bracketDir, 'empty.kcl'), '') | ||||
|     }) | ||||
|  | ||||
|     await page.setBodyDimensions({ width: 1200, height: 500 }) | ||||
|     const u = await getUtils(page) | ||||
|  | ||||
|     page.on('console', console.log) | ||||
|  | ||||
|     const pointOnModel = { x: 630, y: 280 } | ||||
|  | ||||
|     await test.step('Opening the اَلْعَرَبِيَّةُ project should load the stream', async () => { | ||||
|       // expect to see the text bracket | ||||
|       await expect(page.getByText('اَلْعَرَبِيَّةُ')).toBeVisible() | ||||
|  | ||||
|       await page.getByText('اَلْعَرَبِيَّةُ').click() | ||||
|  | ||||
|       await expect( | ||||
|         page.getByRole('button', { name: 'Start Sketch' }) | ||||
|       ).toBeEnabled({ | ||||
|         timeout: 20_000, | ||||
|       }) | ||||
|  | ||||
|       // gray at this pixel means the stream has loaded in the most | ||||
|       // user way we can verify it (pixel color) | ||||
|       await expect | ||||
|         .poll(() => u.getGreatestPixDiff(pointOnModel, [85, 85, 85]), { | ||||
|           timeout: 10_000, | ||||
|         }) | ||||
|         .toBeLessThan(15) | ||||
|     }) | ||||
|   } | ||||
| ) | ||||
|  | ||||
| @ -614,6 +614,38 @@ extrude001 = extrude(50, sketch001) | ||||
|       await expect(gizmo).toBeVisible() | ||||
|     }) | ||||
|   }) | ||||
|  | ||||
|   test(`Refreshing the app doesn't cause the stream to pause on long-executing files`, async ({ | ||||
|     context, | ||||
|     homePage, | ||||
|     scene, | ||||
|     toolbar, | ||||
|     viewport, | ||||
|   }) => { | ||||
|     await context.folderSetupFn(async (dir) => { | ||||
|       const legoDir = path.join(dir, 'lego') | ||||
|       await fsp.mkdir(legoDir, { recursive: true }) | ||||
|       await fsp.copyFile( | ||||
|         executorInputPath('lego.kcl'), | ||||
|         path.join(legoDir, 'main.kcl') | ||||
|       ) | ||||
|     }) | ||||
|  | ||||
|     await test.step(`Test setup`, async () => { | ||||
|       await homePage.openProject('lego') | ||||
|       await toolbar.closePane('code') | ||||
|     }) | ||||
|     await test.step(`Waiting for the loading spinner to disappear`, async () => { | ||||
|       await scene.loadingIndicator.waitFor({ state: 'detached' }) | ||||
|     }) | ||||
|     await test.step(`The part should start loading quickly, not waiting until execution is complete`, async () => { | ||||
|       await scene.expectPixelColor( | ||||
|         [143, 143, 143], | ||||
|         { x: (viewport?.width ?? 1200) / 2, y: (viewport?.height ?? 500) / 2 }, | ||||
|         15 | ||||
|       ) | ||||
|     }) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| async function clickExportButton(page: Page) { | ||||
|  | ||||
| @ -39,8 +39,8 @@ test.describe('Sketch tests', () => { | ||||
|   ${startProfileAt1} | ||||
|   |> arc({ | ||||
|         radius = screwRadius, | ||||
|         angle_start = 0, | ||||
|         angle_end = 360 | ||||
|         angleStart = 0, | ||||
|         angleEnd = 360 | ||||
|       }, %) | ||||
|    | ||||
|     part001 = startSketchOn('XY') | ||||
| @ -60,8 +60,8 @@ test.describe('Sketch tests', () => { | ||||
|   |> yLine(wireOffset, %) | ||||
|   |> arc({ | ||||
|         radius = wireRadius, | ||||
|         angle_start = 0, | ||||
|         angle_end = 180 | ||||
|         angleStart = 0, | ||||
|         angleEnd = 180 | ||||
|       }, %) | ||||
|   |> yLine(-wireOffset, %) | ||||
|   |> xLine(-width / 4, %) | ||||
| @ -1323,3 +1323,85 @@ test.describe(`Sketching with offset planes`, () => { | ||||
|     }) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| // Regression test for https://github.com/KittyCAD/modeling-app/issues/4891 | ||||
| test.describe(`Click based selection don't brick the app when clicked out of range after format using cache`, () => { | ||||
|   test(`Can select a line that reformmed after entering sketch mode`, async ({ | ||||
|     context, | ||||
|     page, | ||||
|     scene, | ||||
|     toolbar, | ||||
|     editor, | ||||
|     homePage, | ||||
|   }) => { | ||||
|     // We seed the scene with a single offset plane | ||||
|     await context.addInitScript(() => { | ||||
|       localStorage.setItem( | ||||
|         'persistCode', | ||||
|         `sketch001 = startSketchOn('XZ') | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line([3.14, 3.14], %) | ||||
|   |> arcTo({ | ||||
|   end = [4, 2], | ||||
|   interior = [1, 2] | ||||
|   }, %) | ||||
| ` | ||||
|       ) | ||||
|     }) | ||||
|  | ||||
|     await homePage.goToModelingScene() | ||||
|     await scene.waitForExecutionDone() | ||||
|  | ||||
|     await test.step(`format the code`, async () => { | ||||
|       // doesn't contain condensed version | ||||
|       await editor.expectEditor.not.toContain( | ||||
|         `arcTo({ end = [4, 2], interior = [1, 2] }, %)` | ||||
|       ) | ||||
|       // click the code to enter sketch mode | ||||
|       await page.getByText(`arcTo`).click() | ||||
|       // Format the code. | ||||
|       await page.locator('#code-pane button:first-child').click() | ||||
|       await page.locator('button:has-text("Format code")').click() | ||||
|     }) | ||||
|  | ||||
|     await test.step(`Ensure the code reformatted`, async () => { | ||||
|       await editor.expectEditor.toContain( | ||||
|         `arcTo({ end = [4, 2], interior = [1, 2] }, %)` | ||||
|       ) | ||||
|     }) | ||||
|  | ||||
|     const [arcClick, arcHover] = scene.makeMouseHelpers(699, 337) | ||||
|     await test.step('Ensure we can hover the arc', async () => { | ||||
|       await arcHover() | ||||
|  | ||||
|       // Check that the code is highlighted | ||||
|       await editor.expectState({ | ||||
|         activeLines: ["sketch001=startSketchOn('XZ')"], | ||||
|         diagnostics: [], | ||||
|         highlightedCode: 'arcTo({end = [4, 2], interior = [1, 2]}, %)', | ||||
|       }) | ||||
|     }) | ||||
|  | ||||
|     await test.step('reset the selection', async () => { | ||||
|       // Move the mouse out of the way | ||||
|       await page.mouse.move(655, 337) | ||||
|  | ||||
|       await editor.expectState({ | ||||
|         activeLines: ["sketch001=startSketchOn('XZ')"], | ||||
|         diagnostics: [], | ||||
|         highlightedCode: '', | ||||
|       }) | ||||
|     }) | ||||
|  | ||||
|     await test.step('Ensure we can click the arc', async () => { | ||||
|       await arcClick() | ||||
|  | ||||
|       // Check that the code is highlighted | ||||
|       await editor.expectState({ | ||||
|         activeLines: [], | ||||
|         diagnostics: [], | ||||
|         highlightedCode: 'arcTo({end = [4, 2], interior = [1, 2]}, %)', | ||||
|       }) | ||||
|     }) | ||||
|   }) | ||||
| }) | ||||
|  | ||||
| Before Width: | Height: | Size: 49 KiB | 
| Before Width: | Height: | Size: 51 KiB After Width: | Height: | Size: 52 KiB | 
| Before Width: | Height: | Size: 47 KiB | 
| Before Width: | Height: | Size: 55 KiB | 
| Before Width: | Height: | Size: 53 KiB After Width: | Height: | Size: 53 KiB | 
| Before Width: | Height: | Size: 48 KiB | 
| Before Width: | Height: | Size: 43 KiB | 
| Before Width: | Height: | Size: 44 KiB | 
| Before Width: | Height: | Size: 41 KiB | 
| Before Width: | Height: | Size: 39 KiB | 
| Before Width: | Height: | Size: 47 KiB | 
| Before Width: | Height: | Size: 35 KiB | 
| Before Width: | Height: | Size: 34 KiB | 
| Before Width: | Height: | Size: 57 KiB | 
| Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 42 KiB | 
| Before Width: | Height: | Size: 54 KiB | 
| Before Width: | Height: | Size: 52 KiB After Width: | Height: | Size: 52 KiB | 
| Before Width: | Height: | Size: 52 KiB | 
| Before Width: | Height: | Size: 74 KiB After Width: | Height: | Size: 74 KiB | 
| Before Width: | Height: | Size: 65 KiB | 
| Before Width: | Height: | Size: 50 KiB After Width: | Height: | Size: 50 KiB | 
| Before Width: | Height: | Size: 46 KiB After Width: | Height: | Size: 47 KiB | 
| Before Width: | Height: | Size: 65 KiB After Width: | Height: | Size: 66 KiB | 
| Before Width: | Height: | Size: 62 KiB | 
| Before Width: | Height: | Size: 152 KiB | 
| Before Width: | Height: | Size: 144 KiB After Width: | Height: | Size: 144 KiB | 
| Before Width: | Height: | Size: 130 KiB | 
| Before Width: | Height: | Size: 136 KiB | 
| Before Width: | Height: | Size: 128 KiB After Width: | Height: | Size: 128 KiB | 
| Before Width: | Height: | Size: 112 KiB | 
| Before Width: | Height: | Size: 38 KiB After Width: | Height: | Size: 48 KiB | 
| Before Width: | Height: | Size: 38 KiB | 
| Before Width: | Height: | Size: 42 KiB After Width: | Height: | Size: 53 KiB | 
| Before Width: | Height: | Size: 41 KiB | 
| Before Width: | Height: | Size: 41 KiB After Width: | Height: | Size: 48 KiB | 
| Before Width: | Height: | Size: 40 KiB | 
| Before Width: | Height: | Size: 40 KiB After Width: | Height: | Size: 52 KiB | 
| Before Width: | Height: | Size: 40 KiB | 
| Before Width: | Height: | Size: 44 KiB After Width: | Height: | Size: 53 KiB | 
| Before Width: | Height: | Size: 44 KiB | 
| Before Width: | Height: | Size: 38 KiB After Width: | Height: | Size: 47 KiB | 
| Before Width: | Height: | Size: 38 KiB | 
| @ -389,25 +389,25 @@ test.describe('Testing selections', () => { | ||||
|     await expect(u.codeLocator).toContainText(`sketch005 = startSketchOn({ | ||||
|      plane = { | ||||
|        origin = { x = 0, y = -50, z = 0 }, | ||||
|        x_axis = { x = 1, y = 0, z = 0 }, | ||||
|        y_axis = { x = 0, y = 0, z = 1 }, | ||||
|        z_axis = { x = 0, y = -1, z = 0 } | ||||
|        xAxis = { x = 1, y = 0, z = 0 }, | ||||
|        yAxis = { x = 0, y = 0, z = 1 }, | ||||
|        zAxis = { x = 0, y = -1, z = 0 } | ||||
|      } | ||||
|    })`) | ||||
|     await expect(u.codeLocator).toContainText(`sketch003 = startSketchOn({ | ||||
|      plane = { | ||||
|        origin = { x = 116.53, y = 0, z = 163.25 }, | ||||
|        x_axis = { x = -0.81, y = 0, z = 0.58 }, | ||||
|        y_axis = { x = 0, y = -1, z = 0 }, | ||||
|        z_axis = { x = 0.58, y = 0, z = 0.81 } | ||||
|        xAxis = { x = -0.81, y = 0, z = 0.58 }, | ||||
|        yAxis = { x = 0, y = -1, z = 0 }, | ||||
|        zAxis = { x = 0.58, y = 0, z = 0.81 } | ||||
|      } | ||||
|    })`) | ||||
|     await expect(u.codeLocator).toContainText(`sketch002 = startSketchOn({ | ||||
|      plane = { | ||||
|        origin = { x = -91.74, y = 0, z = 80.89 }, | ||||
|        x_axis = { x = -0.66, y = 0, z = -0.75 }, | ||||
|        y_axis = { x = 0, y = -1, z = 0 }, | ||||
|        z_axis = { x = -0.75, y = 0, z = 0.66 } | ||||
|        xAxis = { x = -0.66, y = 0, z = -0.75 }, | ||||
|        yAxis = { x = 0, y = -1, z = 0 }, | ||||
|        zAxis = { x = -0.75, y = 0, z = 0.66 } | ||||
|      } | ||||
|    })`) | ||||
|  | ||||
|  | ||||
| @ -156,13 +156,13 @@ test.describe('Text-to-CAD tests', () => { | ||||
|     const cmdSearchBar = page.getByPlaceholder('Search commands') | ||||
|     await expect(cmdSearchBar).toBeVisible() | ||||
|  | ||||
|     const textToCadCommand = page.getByText('Text-to-CAD') | ||||
|     const textToCadCommand = page.getByRole('option', { name: 'Text-to-CAD' }) | ||||
|     await expect(textToCadCommand.first()).toBeVisible() | ||||
|     // Click the Text-to-CAD command | ||||
|     await textToCadCommand.first().click() | ||||
|  | ||||
|     // Enter the prompt. | ||||
|     const prompt = page.getByText('Prompt') | ||||
|     const prompt = page.getByRole('textbox', { name: 'Prompt' }) | ||||
|     await expect(prompt.first()).toBeVisible() | ||||
|  | ||||
|     // Type the prompt. | ||||
| @ -224,13 +224,13 @@ test.describe('Text-to-CAD tests', () => { | ||||
|     const cmdSearchBar = page.getByPlaceholder('Search commands') | ||||
|     await expect(cmdSearchBar).toBeVisible() | ||||
|  | ||||
|     const textToCadCommand = page.getByText('Text-to-CAD') | ||||
|     const textToCadCommand = page.getByRole('option', { name: 'Text-to-CAD' }) | ||||
|     await expect(textToCadCommand.first()).toBeVisible() | ||||
|     // Click the Text-to-CAD command | ||||
|     await textToCadCommand.first().click() | ||||
|  | ||||
|     // Enter the prompt. | ||||
|     const prompt = page.getByText('Prompt') | ||||
|     const prompt = page.getByRole('textbox', { name: 'Prompt' }) | ||||
|     await expect(prompt.first()).toBeVisible() | ||||
|  | ||||
|     const badPrompt = 'akjsndladf lajbhflauweyfaaaljhr472iouafyvsssssss' | ||||
| @ -314,13 +314,13 @@ test.describe('Text-to-CAD tests', () => { | ||||
|     const cmdSearchBar = page.getByPlaceholder('Search commands') | ||||
|     await expect(cmdSearchBar).toBeVisible() | ||||
|  | ||||
|     const textToCadCommand = page.getByText('Text-to-CAD') | ||||
|     const textToCadCommand = page.getByRole('option', { name: 'Text-to-CAD' }) | ||||
|     await expect(textToCadCommand.first()).toBeVisible() | ||||
|     // Click the Text-to-CAD command | ||||
|     await textToCadCommand.first().click() | ||||
|  | ||||
|     // Enter the prompt. | ||||
|     const prompt = page.getByText('Prompt') | ||||
|     const prompt = page.getByRole('textbox', { name: 'Prompt' }) | ||||
|     await expect(prompt.first()).toBeVisible() | ||||
|  | ||||
|     const badPrompt = 'akjsndladflajbhflauweyf15;' | ||||
| @ -392,13 +392,13 @@ test.describe('Text-to-CAD tests', () => { | ||||
|     const cmdSearchBar = page.getByPlaceholder('Search commands') | ||||
|     await expect(cmdSearchBar).toBeVisible() | ||||
|  | ||||
|     const textToCadCommand = page.getByText('Text-to-CAD') | ||||
|     const textToCadCommand = page.getByRole('option', { name: 'Text-to-CAD' }) | ||||
|     await expect(textToCadCommand.first()).toBeVisible() | ||||
|     // Click the Text-to-CAD command | ||||
|     await textToCadCommand.first().click() | ||||
|  | ||||
|     // Enter the prompt. | ||||
|     const prompt = page.getByText('Prompt') | ||||
|     const prompt = page.getByRole('textbox', { name: 'Prompt' }) | ||||
|     await expect(prompt.first()).toBeVisible() | ||||
|  | ||||
|     // Type the prompt. | ||||
| @ -604,7 +604,7 @@ async function sendPromptFromCommandBar(page: Page, promptStr: string) { | ||||
|     await page.waitForTimeout(1000) | ||||
|  | ||||
|     // Enter the prompt. | ||||
|     const prompt = page.getByText('Prompt') | ||||
|     const prompt = page.getByRole('textbox', { name: 'Prompt' }) | ||||
|     await expect(prompt.first()).toBeVisible() | ||||
|  | ||||
|     // Type the prompt. | ||||
|  | ||||
| @ -38,7 +38,7 @@ win: | ||||
|     #     - arm64 | ||||
|   signingHashAlgorithms: | ||||
|     - sha256 | ||||
|   sign: "./sign-win.js" | ||||
|   sign: "./scripts/sign-win.js" | ||||
|   publisherName: "KittyCAD Inc" # needs to be exactly like on Digicert | ||||
|   icon: "assets/icon.ico" | ||||
|   fileAssociations: | ||||
|  | ||||
							
								
								
									
										18
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						| @ -2,11 +2,11 @@ | ||||
|   "nodes": { | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1721933792, | ||||
|         "narHash": "sha256-zYVwABlQnxpbaHMfX6Wt9jhyQstFYwN2XjleOJV3VVg=", | ||||
|         "lastModified": 1736320768, | ||||
|         "narHash": "sha256-nIYdTAiKIGnFNugbomgBJR+Xv5F1ZQU+HfaBqJKroC0=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "2122a9b35b35719ad9a395fe783eabb092df01b1", | ||||
|         "rev": "4bc9c909d9ac828a039f288cf872d16d38185db8", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @ -18,11 +18,11 @@ | ||||
|     }, | ||||
|     "nixpkgs_2": { | ||||
|       "locked": { | ||||
|         "lastModified": 1718428119, | ||||
|         "narHash": "sha256-WdWDpNaq6u1IPtxtYHHWpl5BmabtpmLnMAx0RdJ/vo8=", | ||||
|         "lastModified": 1728538411, | ||||
|         "narHash": "sha256-f0SBJz1eZ2yOuKUr5CA9BHULGXVSn6miBuUWdTyhUhU=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "e6cea36f83499eb4e9cd184c8a8e823296b50ad5", | ||||
|         "rev": "b69de56fac8c2b6f8fd27f2eca01dcda8e0a4221", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @ -43,11 +43,11 @@ | ||||
|         "nixpkgs": "nixpkgs_2" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1721960387, | ||||
|         "narHash": "sha256-o21ax+745ETGXrcgc/yUuLw1SI77ymp3xEpJt+w/kks=", | ||||
|         "lastModified": 1736476219, | ||||
|         "narHash": "sha256-+qyv3QqdZCdZ3cSO/cbpEY6tntyYjfe1bB12mdpNFaY=", | ||||
|         "owner": "oxalica", | ||||
|         "repo": "rust-overlay", | ||||
|         "rev": "9cbf831c5b20a53354fc12758abd05966f9f1699", | ||||
|         "rev": "de30cc5963da22e9742bbbbb9a3344570ed237b9", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|  | ||||
							
								
								
									
										8
									
								
								interface.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						| @ -11,6 +11,13 @@ export interface IElectronAPI { | ||||
|   open: typeof dialog.showOpenDialog | ||||
|   save: typeof dialog.showSaveDialog | ||||
|   openExternal: typeof shell.openExternal | ||||
|   takeElectronWindowScreenshot: ({ | ||||
|     width, | ||||
|     height, | ||||
|   }: { | ||||
|     width: number | ||||
|     height: number | ||||
|   }) => Promise<string> | ||||
|   showInFolder: typeof shell.showItemInFolder | ||||
|   /** Require to be called first before {@link loginWithDeviceFlow} */ | ||||
|   startDeviceFlow: (host: string) => Promise<string> | ||||
| @ -86,5 +93,6 @@ export interface IElectronAPI { | ||||
| declare global { | ||||
|   interface Window { | ||||
|     electron: IElectronAPI | ||||
|     openExternalLink: (e: React.MouseEvent<HTMLAnchorElement>) => void | ||||
|   } | ||||
| } | ||||
|  | ||||
							
								
								
									
										28
									
								
								package.json
									
									
									
									
									
								
							
							
						
						| @ -10,23 +10,23 @@ | ||||
|   }, | ||||
|   "description": "Edit CAD visually or with code", | ||||
|   "main": ".vite/build/main.js", | ||||
|   "license": "none", | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "@codemirror/autocomplete": "^6.17.0", | ||||
|     "@codemirror/commands": "^6.6.0", | ||||
|     "@codemirror/language": "^6.10.3", | ||||
|     "@codemirror/lint": "^6.8.1", | ||||
|     "@codemirror/lint": "^6.8.4", | ||||
|     "@codemirror/search": "^6.5.6", | ||||
|     "@codemirror/state": "^6.4.1", | ||||
|     "@codemirror/theme-one-dark": "^6.1.2", | ||||
|     "@csstools/postcss-oklab-function": "^4.0.2", | ||||
|     "@csstools/postcss-oklab-function": "^4.0.7", | ||||
|     "@fortawesome/fontawesome-svg-core": "^6.5.2", | ||||
|     "@fortawesome/free-brands-svg-icons": "^6.5.2", | ||||
|     "@fortawesome/free-solid-svg-icons": "^6.4.2", | ||||
|     "@fortawesome/react-fontawesome": "^0.2.0", | ||||
|     "@headlessui/react": "^1.7.19", | ||||
|     "@headlessui/tailwindcss": "^0.2.0", | ||||
|     "@kittycad/lib": "2.0.7", | ||||
|     "@kittycad/lib": "2.0.13", | ||||
|     "@lezer/highlight": "^1.2.1", | ||||
|     "@lezer/lr": "^1.4.1", | ||||
|     "@react-hook/resize-observer": "^2.0.1", | ||||
| @ -52,13 +52,13 @@ | ||||
|     "react": "^18.3.1", | ||||
|     "react-dom": "^18.2.0", | ||||
|     "react-hot-toast": "^2.4.1", | ||||
|     "react-hotkeys-hook": "^4.5.1", | ||||
|     "react-hotkeys-hook": "^4.6.1", | ||||
|     "react-json-view": "^1.21.3", | ||||
|     "react-modal": "^3.16.1", | ||||
|     "react-modal": "^3.16.3", | ||||
|     "react-modal-promise": "^1.0.2", | ||||
|     "react-router-dom": "^6.28.0", | ||||
|     "sketch-helpers": "^0.0.4", | ||||
|     "three": "^0.166.1", | ||||
|     "three": "^0.172.0", | ||||
|     "ua-parser-js": "^1.0.37", | ||||
|     "uuid": "^11.0.2", | ||||
|     "vscode-jsonrpc": "^8.2.1", | ||||
| @ -91,8 +91,8 @@ | ||||
|     "build:wasm": "yarn wasm-prep && cd src/wasm-lib && wasm-pack build --release --target web --out-dir pkg && cargo test -p kcl-lib export_bindings && cd ../.. && yarn isomorphic-copy-wasm && yarn fmt", | ||||
|     "remove-importmeta": "sed -i 's/import.meta.url/window.location.origin/g' \"./src/wasm-lib/pkg/wasm_lib.js\"; sed -i '' 's/import.meta.url/window.location.origin/g' \"./src/wasm-lib/pkg/wasm_lib.js\" || echo \"sed for both mac and linux\"", | ||||
|     "wasm-prep": "rimraf src/wasm-lib/pkg && mkdirp src/wasm-lib/pkg && rimraf src/wasm-lib/kcl/bindings", | ||||
|     "lint-fix": "eslint --fix src e2e packages/codemirror-lsp-client", | ||||
|     "lint": "eslint --max-warnings 0 src e2e packages/codemirror-lsp-client", | ||||
|     "lint-fix": "eslint --fix --ext .ts --ext .tsx src e2e packages/codemirror-lsp-client/src", | ||||
|     "lint": "eslint --max-warnings 0 --ext .ts --ext .tsx src e2e packages/codemirror-lsp-client/src", | ||||
|     "files:set-version": "echo \"$(jq --arg v \"$VERSION\" '.version=$v' package.json --indent 2)\" > package.json", | ||||
|     "files:set-notes": "./scripts/set-files-notes.sh", | ||||
|     "files:flip-to-nightly": "./scripts/flip-files-to-nightly.sh", | ||||
| @ -166,13 +166,11 @@ | ||||
|     "@types/react": "^18.3.4", | ||||
|     "@types/react-dom": "^18.3.1", | ||||
|     "@types/react-modal": "^3.16.3", | ||||
|     "@types/three": "^0.163.0", | ||||
|     "@types/three": "^0.172.0", | ||||
|     "@types/ua-parser-js": "^0.7.39", | ||||
|     "@types/uuid": "^9.0.8", | ||||
|     "@types/wicg-file-system-access": "^2023.10.5", | ||||
|     "@types/ws": "^8.5.13", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.0.0", | ||||
|     "@typescript-eslint/parser": "^5.0.0", | ||||
|     "@vitejs/plugin-react": "^4.3.0", | ||||
|     "@vitest/web-worker": "^1.5.0", | ||||
|     "@xstate/cli": "^0.5.17", | ||||
| @ -182,11 +180,12 @@ | ||||
|     "electron-builder": "24.13.3", | ||||
|     "electron-notarize": "1.2.2", | ||||
|     "eslint": "^8.0.1", | ||||
|     "eslint-config-react-app": "^7.0.1", | ||||
|     "eslint-plugin-css-modules": "^2.12.0", | ||||
|     "eslint-plugin-import": "^2.30.0", | ||||
|     "eslint-plugin-jest": "^28.10.0", | ||||
|     "eslint-plugin-react": "^7.37.3", | ||||
|     "eslint-plugin-suggest-no-throw": "^1.0.0", | ||||
|     "happy-dom": "^15.11.7", | ||||
|     "happy-dom": "^16.3.0", | ||||
|     "http-server": "^14.1.1", | ||||
|     "husky": "^9.1.5", | ||||
|     "kill-port": "^2.0.1", | ||||
| @ -200,6 +199,7 @@ | ||||
|     "tailwindcss": "^3.4.1", | ||||
|     "ts-node": "^10.0.0", | ||||
|     "typescript": "^5.7.2", | ||||
|     "typescript-eslint": "^8.19.1", | ||||
|     "vite": "^5.4.6", | ||||
|     "vite-plugin-package-version": "^1.1.0", | ||||
|     "vite-tsconfig-paths": "^4.3.2", | ||||
|  | ||||
							
								
								
									
										7
									
								
								packages/codemirror-lang-kcl/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,7 @@ | ||||
| node_modules | ||||
| build | ||||
| dist | ||||
| tsconfig.tsbuildinfo | ||||
| *.d.ts | ||||
| *.js | ||||
| !rollup.config.js | ||||
							
								
								
									
										36
									
								
								packages/codemirror-lang-kcl/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,36 @@ | ||||
| { | ||||
|   "name": "@kittycad/codemirror-lang-kcl", | ||||
|   "version": "1.0.0", | ||||
|   "description": "Zoo KCL language support for CodeMirror 6.", | ||||
|   "main": "src/index.ts", | ||||
|   "scripts": { | ||||
|     "build": "rollup -c", | ||||
|     "test": "vitest --config vitest.main.config.ts run" | ||||
|   }, | ||||
|   "type": "module", | ||||
|   "repository": "https://github.com/KittyCAD/modeling-app", | ||||
|   "author": "Zoo Engineering Team", | ||||
|   "license": "MIT", | ||||
|   "private": false, | ||||
|   "exports": { | ||||
|     "import": "./dist/index.js", | ||||
|     "require": "./dist/index.cjs" | ||||
|   }, | ||||
|   "types": "dist/index.d.ts", | ||||
|   "dependencies": { | ||||
|     "@codemirror/language": "^6.10.3", | ||||
|     "@codemirror/state": "^6.4.1", | ||||
|     "@lezer/highlight": "^1.2.1", | ||||
|     "typescript": "^5.7.2" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@lezer/generator": "^1.7.2", | ||||
|     "@rollup/plugin-typescript": "^12.1.2", | ||||
|     "rollup": "^4.29.1", | ||||
|     "rollup-plugin-dts": "^6.1.1", | ||||
|     "vitest": "^2.1.8" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "dist/" | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										25
									
								
								packages/codemirror-lang-kcl/rollup.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,25 @@ | ||||
| import dts from 'rollup-plugin-dts' | ||||
| import { lezer } from '@lezer/generator/rollup' | ||||
| import typescript from '@rollup/plugin-typescript' | ||||
|  | ||||
| export default [ | ||||
|   { | ||||
|     input: 'src/index.ts', | ||||
|     // imports are considered internal if they start with './' or '/' or 'word:' | ||||
|     external: (id) => id != 'tslib' && !/^(\.?\/|\w:)/.test(id), | ||||
|     output: [ | ||||
|       { file: 'dist/index.cjs', format: 'cjs' }, | ||||
|       { file: 'dist/index.js', format: 'es' }, | ||||
|     ], | ||||
|     plugins: [lezer(), typescript()], | ||||
|   }, | ||||
|   { | ||||
|     input: 'src/index.ts', | ||||
|     external: (id) => id != 'tslib' && !/^(\.?\/|\w:)/.test(id), | ||||
|     output: [ | ||||
|       { file: 'dist/index.d.cts', format: 'cjs' }, | ||||
|       { file: 'dist/index.d.ts', format: 'es' }, | ||||
|     ], | ||||
|     plugins: [lezer(), typescript(), dts()], | ||||
|   }, | ||||
| ] | ||||
							
								
								
									
										42
									
								
								packages/codemirror-lang-kcl/src/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,42 @@ | ||||
| // Base CodeMirror language support for kcl. | ||||
|  | ||||
| import { | ||||
|   LRLanguage, | ||||
|   LanguageSupport, | ||||
|   indentNodeProp, | ||||
|   continuedIndent, | ||||
|   delimitedIndent, | ||||
|   foldNodeProp, | ||||
|   foldInside, | ||||
| } from '@codemirror/language' | ||||
| // @ts-ignore: No types available | ||||
| import { parser } from './kcl.grammar' | ||||
|  | ||||
| export const KclLanguage = LRLanguage.define({ | ||||
|   name: 'kcl', | ||||
|   parser: parser.configure({ | ||||
|     props: [ | ||||
|       indentNodeProp.add({ | ||||
|         Body: delimitedIndent({ closing: '}' }), | ||||
|         BlockComment: () => null, | ||||
|         'Statement Property': continuedIndent({ except: /^{/ }), | ||||
|       }), | ||||
|       foldNodeProp.add({ | ||||
|         'Body ArrayExpression ObjectExpression': foldInside, | ||||
|         BlockComment(tree) { | ||||
|           return { from: tree.from + 2, to: tree.to - 2 } | ||||
|         }, | ||||
|         PipeExpression(tree) { | ||||
|           return { from: tree.firstChild!.to, to: tree.to } | ||||
|         }, | ||||
|       }), | ||||
|     ], | ||||
|   }), | ||||
|   languageData: { | ||||
|     commentTokens: { line: '//', block: { open: '/*', close: '*/' } }, | ||||
|   }, | ||||
| }) | ||||
|  | ||||
| export function kcl() { | ||||
|   return new LanguageSupport(KclLanguage) | ||||
| } | ||||
| @ -17,7 +17,7 @@ | ||||
| 
 | ||||
| statement[@isGroup=Statement] { | ||||
|   ImportStatement { kw<"import"> ImportItems ImportFrom String } | | ||||
|   FunctionDeclaration { kw<"export">? kw<"fn"> VariableDefinition Equals ParamList Arrow Body } | | ||||
|   FunctionDeclaration { kw<"export">? kw<"fn"> VariableDefinition Equals? ParamList Arrow? Body } | | ||||
|   VariableDeclaration { kw<"export">? (kw<"var"> | kw<"let"> | kw<"const">)? VariableDefinition Equals expression } | | ||||
|   ReturnStatement { kw<"return"> expression } | | ||||
|   ExpressionStatement { expression } | ||||
| @ -57,7 +57,7 @@ expression[@isGroup=Expression] { | ||||
| 
 | ||||
| UnaryOp { AddOp | BangOp } | ||||
| 
 | ||||
| ObjectProperty { PropertyName ":" expression } | ||||
| ObjectProperty { PropertyName (":" | Equals) expression } | ||||
| 
 | ||||
| ArgumentList { "(" commaSep<expression> ")" } | ||||
| 
 | ||||
| @ -85,7 +85,7 @@ commaSep1NoTrailingComma<term> { term ("," term)* } | ||||
| @tokens { | ||||
|   String[isolate] { "'" ("\\" _ | !['\\])* "'" | '"' ("\\" _ | !["\\])* '"' } | ||||
| 
 | ||||
|   Number { "." @digit+ | @digit+ ("." @digit*)? } | ||||
|   Number { "." @digit+ | @digit+ ("." @digit+)? } | ||||
|   @precedence { Number, "." } | ||||
| 
 | ||||
|   AddOp { "+" | "-" } | ||||
							
								
								
									
										22
									
								
								packages/codemirror-lang-kcl/test/all.test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,22 @@ | ||||
| import { KclLanguage } from '../src/index' | ||||
| import { fileTests } from '@lezer/generator/dist/test' | ||||
|  | ||||
| import * as fs from 'fs' | ||||
| import * as path from 'path' | ||||
|  | ||||
| let caseDir = path.dirname(__filename) | ||||
|  | ||||
| for (let file of fs.readdirSync(caseDir)) { | ||||
|   if (!/\.txt$/.test(file)) continue | ||||
|  | ||||
|   let fname = /^[^\.]*/.exec(file)?.at(0) | ||||
|   if (fname) { | ||||
|     let tests = fileTests( | ||||
|       fs.readFileSync(path.join(caseDir, file), 'utf8'), | ||||
|       file | ||||
|     ) | ||||
|     describe(fname, () => { | ||||
|       for (let { name, run } of tests) it(name, () => run(KclLanguage.parser)) | ||||
|     }) | ||||
|   } | ||||
| } | ||||
							
								
								
									
										60
									
								
								packages/codemirror-lang-kcl/test/cases.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,60 @@ | ||||
| # Booleans | ||||
|  | ||||
| true | ||||
| false | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(ExpressionStatement(true), ExpressionStatement(false)) | ||||
|  | ||||
| # Identifiers | ||||
|  | ||||
| one | ||||
| _Two_Three | ||||
| Four5 | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(ExpressionStatement(VariableName), | ||||
|         ExpressionStatement(VariableName), | ||||
|         ExpressionStatement(VariableName)) | ||||
|  | ||||
| # Strings | ||||
|  | ||||
| "hello" | ||||
| 'hi' | ||||
| "one\"\\two" | ||||
| '3\'\\four\x' | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(ExpressionStatement(String), | ||||
|         ExpressionStatement(String), | ||||
|         ExpressionStatement(String), | ||||
|         ExpressionStatement(String)) | ||||
|  | ||||
| # VariableDeclaration | ||||
|  | ||||
| let a = 'abc' | ||||
| export const x = 0.2 | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(VariableDeclaration(let, VariableDefinition, Equals, String), | ||||
|         VariableDeclaration(export, const, VariableDefinition, Equals, Number)) | ||||
|  | ||||
| # IfExpression | ||||
|  | ||||
| if x { 1 } else { $tag } | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(ExpressionStatement(IfExpression(if, VariableName, Body(ExpressionStatement(Number)), else, Body(ExpressionStatement(TagDeclarator))))) | ||||
|  | ||||
| # Shebang | ||||
|  | ||||
| #!anything | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(Shebang) | ||||
							
								
								
									
										60
									
								
								packages/codemirror-lang-kcl/test/fn.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,60 @@ | ||||
| # full | ||||
|  | ||||
| fn two = () => { | ||||
|   return 2 | ||||
| } | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(FunctionDeclaration(fn, | ||||
|                             VariableDefinition, | ||||
|                             Equals, | ||||
|                             ParamList, | ||||
|                             Arrow, | ||||
|                             Body(ReturnStatement(return, | ||||
|                                                  Number)))) | ||||
|  | ||||
| # = is optional | ||||
|  | ||||
| fn one () => { | ||||
|   return 1 | ||||
| } | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(FunctionDeclaration(fn, | ||||
|                             VariableDefinition, | ||||
|                             ParamList, | ||||
|                             Arrow, | ||||
|                             Body(ReturnStatement(return, | ||||
|                                                  Number)))) | ||||
|  | ||||
| # => is optional | ||||
|  | ||||
| fn one = () { | ||||
|   return 1 | ||||
| } | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(FunctionDeclaration(fn, | ||||
|                             VariableDefinition, | ||||
|                             Equals, | ||||
|                             ParamList, | ||||
|                             Body(ReturnStatement(return, | ||||
|                                                  Number)))) | ||||
|  | ||||
| # terse | ||||
|  | ||||
| fn two() { | ||||
|   return 2 | ||||
| } | ||||
|  | ||||
| ==> | ||||
|  | ||||
| Program(FunctionDeclaration(fn, | ||||
|                             VariableDefinition, | ||||
|                             ParamList, | ||||
|                             Body(ReturnStatement(return, | ||||
|                                                  Number)))) | ||||
|  | ||||
							
								
								
									
										20
									
								
								packages/codemirror-lang-kcl/test/key.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,20 @@ | ||||
| # colon (deprecated) | ||||
|  | ||||
| x = { k: 123 } | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ObjectExpression(ObjectProperty(PropertyName, | ||||
|                                                             Number)))) | ||||
|  | ||||
| # equal | ||||
|  | ||||
| x = { k = 123 } | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ObjectExpression(ObjectProperty(PropertyName, | ||||
|                                                             Equals, | ||||
|                                                             Number)))) | ||||
							
								
								
									
										43
									
								
								packages/codemirror-lang-kcl/test/range.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,43 @@ | ||||
| # spaced | ||||
|  | ||||
| a = [0 .. 1] | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ArrayExpression(IntegerRange(Number, | ||||
|                                                          Number)))) | ||||
|  | ||||
| # compact | ||||
|  | ||||
| a = [0..1] | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ArrayExpression(IntegerRange(Number, | ||||
|                                                          Number)))) | ||||
|  | ||||
| # expr spaced | ||||
|  | ||||
| a = [start .. start + 10] | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ArrayExpression(IntegerRange(VariableName, | ||||
|                                                          BinaryExpression(VariableName, | ||||
|                                                                           AddOp, | ||||
|                                                                           Number))))) | ||||
|  | ||||
| # expr compact | ||||
|  | ||||
| a = [start..start + 10] | ||||
|  | ||||
| ==> | ||||
| Program(VariableDeclaration(VariableDefinition, | ||||
|                             Equals, | ||||
|                             ArrayExpression(IntegerRange(VariableName, | ||||
|                                                          BinaryExpression(VariableName, | ||||
|                                                                           AddOp, | ||||
|                                                                           Number))))) | ||||
							
								
								
									
										19
									
								
								packages/codemirror-lang-kcl/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,19 @@ | ||||
| { | ||||
|   "compilerOptions": { | ||||
|     "composite": true, | ||||
|     "rootDir": "src", | ||||
|     "outDir": "dist", | ||||
|     "target": "esnext", | ||||
|     "lib": ["dom", "dom.iterable", "esnext"], | ||||
|     "module": "esnext", | ||||
|     "esModuleInterop": true, | ||||
|     "moduleResolution": "node", | ||||
|     "forceConsistentCasingInFileNames": true, | ||||
|     "strict": true, | ||||
|     "noImplicitAny": true, | ||||
|     "skipLibCheck": true, | ||||
|     "declaration": true | ||||
|   }, | ||||
|   "include": ["src", "./*.ts"], | ||||
|   "exclude": ["node_modules", "vitest.main.config.ts"] | ||||
| } | ||||
							
								
								
									
										29
									
								
								packages/codemirror-lang-kcl/vitest.main.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,29 @@ | ||||
| // Overrides the test options from the modeling-app config. | ||||
|  | ||||
| import viteTsconfigPaths from 'vite-tsconfig-paths' | ||||
| import { defineConfig, configDefaults } from 'vitest/config' | ||||
| // @ts-ignore: No types available | ||||
| import { lezer } from '@lezer/generator/rollup' | ||||
|  | ||||
| const config = defineConfig({ | ||||
|   test: { | ||||
|     globals: true, | ||||
|     pool: 'forks', | ||||
|     poolOptions: { | ||||
|       forks: { | ||||
|         maxForks: 2, | ||||
|         minForks: 1, | ||||
|       }, | ||||
|     }, | ||||
|     environment: 'node', | ||||
|     reporters: process.env.GITHUB_ACTIONS | ||||
|       ? ['dot', 'github-actions'] | ||||
|       : ['verbose', 'hanging-process'], | ||||
|     testTimeout: 1000, | ||||
|     hookTimeout: 1000, | ||||
|     teardownTimeout: 1000, | ||||
|   }, | ||||
|   plugins: [viteTsconfigPaths(), lezer()], | ||||
| }) | ||||
|  | ||||
| export default config | ||||
							
								
								
									
										714
									
								
								packages/codemirror-lang-kcl/yarn.lock
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,714 @@ | ||||
| # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. | ||||
| # yarn lockfile v1 | ||||
|  | ||||
|  | ||||
| "@babel/code-frame@^7.24.2": | ||||
|   version "7.26.2" | ||||
|   resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.26.2.tgz#4b5fab97d33338eff916235055f0ebc21e573a85" | ||||
|   integrity sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ== | ||||
|   dependencies: | ||||
|     "@babel/helper-validator-identifier" "^7.25.9" | ||||
|     js-tokens "^4.0.0" | ||||
|     picocolors "^1.0.0" | ||||
|  | ||||
| "@babel/helper-validator-identifier@^7.25.9": | ||||
|   version "7.25.9" | ||||
|   resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz#24b64e2c3ec7cd3b3c547729b8d16871f22cbdc7" | ||||
|   integrity sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ== | ||||
|  | ||||
| "@codemirror/language@^6.10.3": | ||||
|   version "6.10.8" | ||||
|   resolved "https://registry.yarnpkg.com/@codemirror/language/-/language-6.10.8.tgz#3e3a346a2b0a8cf63ee1cfe03349eb1965dce5f9" | ||||
|   integrity sha512-wcP8XPPhDH2vTqf181U8MbZnW+tDyPYy0UzVOa+oHORjyT+mhhom9vBd7dApJwoDz9Nb/a8kHjJIsuA/t8vNFw== | ||||
|   dependencies: | ||||
|     "@codemirror/state" "^6.0.0" | ||||
|     "@codemirror/view" "^6.23.0" | ||||
|     "@lezer/common" "^1.1.0" | ||||
|     "@lezer/highlight" "^1.0.0" | ||||
|     "@lezer/lr" "^1.0.0" | ||||
|     style-mod "^4.0.0" | ||||
|  | ||||
| "@codemirror/state@^6.0.0", "@codemirror/state@^6.4.1", "@codemirror/state@^6.5.0": | ||||
|   version "6.5.0" | ||||
|   resolved "https://registry.yarnpkg.com/@codemirror/state/-/state-6.5.0.tgz#e98dde85620618651543152fe1c2483300a0ccc9" | ||||
|   integrity sha512-MwBHVK60IiIHDcoMet78lxt6iw5gJOGSbNbOIVBHWVXIH4/Nq1+GQgLLGgI1KlnN86WDXsPudVaqYHKBIx7Eyw== | ||||
|   dependencies: | ||||
|     "@marijn/find-cluster-break" "^1.0.0" | ||||
|  | ||||
| "@codemirror/view@^6.23.0": | ||||
|   version "6.36.1" | ||||
|   resolved "https://registry.yarnpkg.com/@codemirror/view/-/view-6.36.1.tgz#3c543b8fd72c96b30c4b2b1464d1ebce7e0c5c4b" | ||||
|   integrity sha512-miD1nyT4m4uopZaDdO2uXU/LLHliKNYL9kB1C1wJHrunHLm/rpkb5QVSokqgw9hFqEZakrdlb/VGWX8aYZTslQ== | ||||
|   dependencies: | ||||
|     "@codemirror/state" "^6.5.0" | ||||
|     style-mod "^4.1.0" | ||||
|     w3c-keyname "^2.2.4" | ||||
|  | ||||
| "@esbuild/aix-ppc64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz#c7184a326533fcdf1b8ee0733e21c713b975575f" | ||||
|   integrity sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ== | ||||
|  | ||||
| "@esbuild/android-arm64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz#09d9b4357780da9ea3a7dfb833a1f1ff439b4052" | ||||
|   integrity sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A== | ||||
|  | ||||
| "@esbuild/android-arm@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.21.5.tgz#9b04384fb771926dfa6d7ad04324ecb2ab9b2e28" | ||||
|   integrity sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg== | ||||
|  | ||||
| "@esbuild/android-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.21.5.tgz#29918ec2db754cedcb6c1b04de8cd6547af6461e" | ||||
|   integrity sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA== | ||||
|  | ||||
| "@esbuild/darwin-arm64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz#e495b539660e51690f3928af50a76fb0a6ccff2a" | ||||
|   integrity sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ== | ||||
|  | ||||
| "@esbuild/darwin-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz#c13838fa57372839abdddc91d71542ceea2e1e22" | ||||
|   integrity sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw== | ||||
|  | ||||
| "@esbuild/freebsd-arm64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz#646b989aa20bf89fd071dd5dbfad69a3542e550e" | ||||
|   integrity sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g== | ||||
|  | ||||
| "@esbuild/freebsd-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz#aa615cfc80af954d3458906e38ca22c18cf5c261" | ||||
|   integrity sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ== | ||||
|  | ||||
| "@esbuild/linux-arm64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz#70ac6fa14f5cb7e1f7f887bcffb680ad09922b5b" | ||||
|   integrity sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q== | ||||
|  | ||||
| "@esbuild/linux-arm@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz#fc6fd11a8aca56c1f6f3894f2bea0479f8f626b9" | ||||
|   integrity sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA== | ||||
|  | ||||
| "@esbuild/linux-ia32@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz#3271f53b3f93e3d093d518d1649d6d68d346ede2" | ||||
|   integrity sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg== | ||||
|  | ||||
| "@esbuild/linux-loong64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz#ed62e04238c57026aea831c5a130b73c0f9f26df" | ||||
|   integrity sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg== | ||||
|  | ||||
| "@esbuild/linux-mips64el@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz#e79b8eb48bf3b106fadec1ac8240fb97b4e64cbe" | ||||
|   integrity sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg== | ||||
|  | ||||
| "@esbuild/linux-ppc64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz#5f2203860a143b9919d383ef7573521fb154c3e4" | ||||
|   integrity sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w== | ||||
|  | ||||
| "@esbuild/linux-riscv64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz#07bcafd99322d5af62f618cb9e6a9b7f4bb825dc" | ||||
|   integrity sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA== | ||||
|  | ||||
| "@esbuild/linux-s390x@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz#b7ccf686751d6a3e44b8627ababc8be3ef62d8de" | ||||
|   integrity sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A== | ||||
|  | ||||
| "@esbuild/linux-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz#6d8f0c768e070e64309af8004bb94e68ab2bb3b0" | ||||
|   integrity sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ== | ||||
|  | ||||
| "@esbuild/netbsd-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz#bbe430f60d378ecb88decb219c602667387a6047" | ||||
|   integrity sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg== | ||||
|  | ||||
| "@esbuild/openbsd-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz#99d1cf2937279560d2104821f5ccce220cb2af70" | ||||
|   integrity sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow== | ||||
|  | ||||
| "@esbuild/sunos-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz#08741512c10d529566baba837b4fe052c8f3487b" | ||||
|   integrity sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg== | ||||
|  | ||||
| "@esbuild/win32-arm64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz#675b7385398411240735016144ab2e99a60fc75d" | ||||
|   integrity sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A== | ||||
|  | ||||
| "@esbuild/win32-ia32@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz#1bfc3ce98aa6ca9a0969e4d2af72144c59c1193b" | ||||
|   integrity sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA== | ||||
|  | ||||
| "@esbuild/win32-x64@0.21.5": | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz#acad351d582d157bb145535db2a6ff53dd514b5c" | ||||
|   integrity sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw== | ||||
|  | ||||
| "@jridgewell/sourcemap-codec@^1.5.0": | ||||
|   version "1.5.0" | ||||
|   resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz#3188bcb273a414b0d215fd22a58540b989b9409a" | ||||
|   integrity sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ== | ||||
|  | ||||
| "@lezer/common@^1.0.0", "@lezer/common@^1.1.0": | ||||
|   version "1.2.3" | ||||
|   resolved "https://registry.yarnpkg.com/@lezer/common/-/common-1.2.3.tgz#138fcddab157d83da557554851017c6c1e5667fd" | ||||
|   integrity sha512-w7ojc8ejBqr2REPsWxJjrMFsA/ysDCFICn8zEOR9mrqzOu2amhITYuLD8ag6XZf0CFXDrhKqw7+tW8cX66NaDA== | ||||
|  | ||||
| "@lezer/generator@^1.7.2": | ||||
|   version "1.7.2" | ||||
|   resolved "https://registry.yarnpkg.com/@lezer/generator/-/generator-1.7.2.tgz#a491c91eb9f117ea803e748fa97574514156a2a3" | ||||
|   integrity sha512-CwgULPOPPmH54tv4gki18bElLCdJ1+FBC+nGVSVD08vFWDsMjS7KEjNTph9JOypDnet90ujN3LzQiW3CyVODNQ== | ||||
|   dependencies: | ||||
|     "@lezer/common" "^1.1.0" | ||||
|     "@lezer/lr" "^1.3.0" | ||||
|  | ||||
| "@lezer/highlight@^1.0.0", "@lezer/highlight@^1.2.1": | ||||
|   version "1.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/@lezer/highlight/-/highlight-1.2.1.tgz#596fa8f9aeb58a608be0a563e960c373cbf23f8b" | ||||
|   integrity sha512-Z5duk4RN/3zuVO7Jq0pGLJ3qynpxUVsh7IbUbGj88+uV2ApSAn6kWg2au3iJb+0Zi7kKtqffIESgNcRXWZWmSA== | ||||
|   dependencies: | ||||
|     "@lezer/common" "^1.0.0" | ||||
|  | ||||
| "@lezer/lr@^1.0.0", "@lezer/lr@^1.3.0": | ||||
|   version "1.4.2" | ||||
|   resolved "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.4.2.tgz#931ea3dea8e9de84e90781001dae30dea9ff1727" | ||||
|   integrity sha512-pu0K1jCIdnQ12aWNaAVU5bzi7Bd1w54J3ECgANPmYLtQKP0HBj2cE/5coBD66MT10xbtIuUr7tg0Shbsvk0mDA== | ||||
|   dependencies: | ||||
|     "@lezer/common" "^1.0.0" | ||||
|  | ||||
| "@marijn/find-cluster-break@^1.0.0": | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/@marijn/find-cluster-break/-/find-cluster-break-1.0.2.tgz#775374306116d51c0c500b8c4face0f9a04752d8" | ||||
|   integrity sha512-l0h88YhZFyKdXIFNfSWpyjStDjGHwZ/U7iobcK1cQQD8sejsONdQtTVU+1wVN1PBw40PiiHB1vA5S7VTfQiP9g== | ||||
|  | ||||
| "@rollup/plugin-typescript@^12.1.2": | ||||
|   version "12.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/plugin-typescript/-/plugin-typescript-12.1.2.tgz#ebaeec2e7376faa889030ccd7cb485a649e63118" | ||||
|   integrity sha512-cdtSp154H5sv637uMr1a8OTWB0L1SWDSm1rDGiyfcGcvQ6cuTs4MDk2BVEBGysUWago4OJN4EQZqOTl/QY3Jgg== | ||||
|   dependencies: | ||||
|     "@rollup/pluginutils" "^5.1.0" | ||||
|     resolve "^1.22.1" | ||||
|  | ||||
| "@rollup/pluginutils@^5.1.0": | ||||
|   version "5.1.4" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-5.1.4.tgz#bb94f1f9eaaac944da237767cdfee6c5b2262d4a" | ||||
|   integrity sha512-USm05zrsFxYLPdWWq+K3STlWiT/3ELn3RcV5hJMghpeAIhxfsUIg6mt12CBJBInWMV4VneoV7SfGv8xIwo2qNQ== | ||||
|   dependencies: | ||||
|     "@types/estree" "^1.0.0" | ||||
|     estree-walker "^2.0.2" | ||||
|     picomatch "^4.0.2" | ||||
|  | ||||
| "@rollup/rollup-android-arm-eabi@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.29.1.tgz#9bd38df6a29afb7f0336d988bc8112af0c8816c0" | ||||
|   integrity sha512-ssKhA8RNltTZLpG6/QNkCSge+7mBQGUqJRisZ2MDQcEGaK93QESEgWK2iOpIDZ7k9zPVkG5AS3ksvD5ZWxmItw== | ||||
|  | ||||
| "@rollup/rollup-android-arm64@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.29.1.tgz#bd1a98390e15b76eeef907175a37c5f0f9e4d214" | ||||
|   integrity sha512-CaRfrV0cd+NIIcVVN/jx+hVLN+VRqnuzLRmfmlzpOzB87ajixsN/+9L5xNmkaUUvEbI5BmIKS+XTwXsHEb65Ew== | ||||
|  | ||||
| "@rollup/rollup-darwin-arm64@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.29.1.tgz#bc6fa8a2cc77b5f367424e5e994e3537524e6879" | ||||
|   integrity sha512-2ORr7T31Y0Mnk6qNuwtyNmy14MunTAMx06VAPI6/Ju52W10zk1i7i5U3vlDRWjhOI5quBcrvhkCHyF76bI7kEw== | ||||
|  | ||||
| "@rollup/rollup-darwin-x64@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.29.1.tgz#76059c91f06b17406347b127df10f065283b2e61" | ||||
|   integrity sha512-j/Ej1oanzPjmN0tirRd5K2/nncAhS9W6ICzgxV+9Y5ZsP0hiGhHJXZ2JQ53iSSjj8m6cRY6oB1GMzNn2EUt6Ng== | ||||
|  | ||||
| "@rollup/rollup-freebsd-arm64@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.29.1.tgz#83178315c0be4b4c8c1fd835e1952d2dc1eb4e6e" | ||||
|   integrity sha512-91C//G6Dm/cv724tpt7nTyP+JdN12iqeXGFM1SqnljCmi5yTXriH7B1r8AD9dAZByHpKAumqP1Qy2vVNIdLZqw== | ||||
|  | ||||
| "@rollup/rollup-freebsd-x64@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.29.1.tgz#1ef24fa0576bf7899a0a0a649156606dbd7a0d46" | ||||
|   integrity sha512-hEioiEQ9Dec2nIRoeHUP6hr1PSkXzQaCUyqBDQ9I9ik4gCXQZjJMIVzoNLBRGet+hIUb3CISMh9KXuCcWVW/8w== | ||||
|  | ||||
| "@rollup/rollup-linux-arm-gnueabihf@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.29.1.tgz#443a6f5681bf4611caae42988994a6d8ee676216" | ||||
|   integrity sha512-Py5vFd5HWYN9zxBv3WMrLAXY3yYJ6Q/aVERoeUFwiDGiMOWsMs7FokXihSOaT/PMWUty/Pj60XDQndK3eAfE6A== | ||||
|  | ||||
| "@rollup/rollup-linux-arm-musleabihf@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.29.1.tgz#9738b27184102228637a683e5f35b22ea352394f" | ||||
|   integrity sha512-RiWpGgbayf7LUcuSNIbahr0ys2YnEERD4gYdISA06wa0i8RALrnzflh9Wxii7zQJEB2/Eh74dX4y/sHKLWp5uQ== | ||||
|  | ||||
| "@rollup/rollup-linux-arm64-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.29.1.tgz#b5e9d5e30ff36a19bedd29c715ba18a1889ff269" | ||||
|   integrity sha512-Z80O+taYxTQITWMjm/YqNoe9d10OX6kDh8X5/rFCMuPqsKsSyDilvfg+vd3iXIqtfmp+cnfL1UrYirkaF8SBZA== | ||||
|  | ||||
| "@rollup/rollup-linux-arm64-musl@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.29.1.tgz#1d8f68f0829b57f746ec03432ad046f1af014a98" | ||||
|   integrity sha512-fOHRtF9gahwJk3QVp01a/GqS4hBEZCV1oKglVVq13kcK3NeVlS4BwIFzOHDbmKzt3i0OuHG4zfRP0YoG5OF/rA== | ||||
|  | ||||
| "@rollup/rollup-linux-loongarch64-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.29.1.tgz#07027feb883408e74a3002c8e50caaedd288ae38" | ||||
|   integrity sha512-5a7q3tnlbcg0OodyxcAdrrCxFi0DgXJSoOuidFUzHZ2GixZXQs6Tc3CHmlvqKAmOs5eRde+JJxeIf9DonkmYkw== | ||||
|  | ||||
| "@rollup/rollup-linux-powerpc64le-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.29.1.tgz#544ce1b0847a9c1240425e86f33daceac7ec4e12" | ||||
|   integrity sha512-9b4Mg5Yfz6mRnlSPIdROcfw1BU22FQxmfjlp/CShWwO3LilKQuMISMTtAu/bxmmrE6A902W2cZJuzx8+gJ8e9w== | ||||
|  | ||||
| "@rollup/rollup-linux-riscv64-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.29.1.tgz#64be13d51852ec1e2dfbd25d997ed5f42f35ea6d" | ||||
|   integrity sha512-G5pn0NChlbRM8OJWpJFMX4/i8OEU538uiSv0P6roZcbpe/WfhEO+AT8SHVKfp8qhDQzaz7Q+1/ixMy7hBRidnQ== | ||||
|  | ||||
| "@rollup/rollup-linux-s390x-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.29.1.tgz#31f51e1e05c6264552d03875d9e2e673f0fd86e3" | ||||
|   integrity sha512-WM9lIkNdkhVwiArmLxFXpWndFGuOka4oJOZh8EP3Vb8q5lzdSCBuhjavJsw68Q9AKDGeOOIHYzYm4ZFvmWez5g== | ||||
|  | ||||
| "@rollup/rollup-linux-x64-gnu@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.29.1.tgz#f4c95b26f4ad69ebdb64b42f0ae4da2a0f617958" | ||||
|   integrity sha512-87xYCwb0cPGZFoGiErT1eDcssByaLX4fc0z2nRM6eMtV9njAfEE6OW3UniAoDhX4Iq5xQVpE6qO9aJbCFumKYQ== | ||||
|  | ||||
| "@rollup/rollup-linux-x64-musl@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.29.1.tgz#ab7be89192f72beb9ea6e2386186fefde4f69d82" | ||||
|   integrity sha512-xufkSNppNOdVRCEC4WKvlR1FBDyqCSCpQeMMgv9ZyXqqtKBfkw1yfGMTUTs9Qsl6WQbJnsGboWCp7pJGkeMhKA== | ||||
|  | ||||
| "@rollup/rollup-win32-arm64-msvc@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.29.1.tgz#7f12efb8240b238346951559998802722944421e" | ||||
|   integrity sha512-F2OiJ42m77lSkizZQLuC+jiZ2cgueWQL5YC9tjo3AgaEw+KJmVxHGSyQfDUoYR9cci0lAywv2Clmckzulcq6ig== | ||||
|  | ||||
| "@rollup/rollup-win32-ia32-msvc@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.29.1.tgz#353d14d6eee943004d129796e4feddd3aa260921" | ||||
|   integrity sha512-rYRe5S0FcjlOBZQHgbTKNrqxCBUmgDJem/VQTCcTnA2KCabYSWQDrytOzX7avb79cAAweNmMUb/Zw18RNd4mng== | ||||
|  | ||||
| "@rollup/rollup-win32-x64-msvc@4.29.1": | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.29.1.tgz#c82f04a09ba481e13857d6f2516e072aaa51b7f4" | ||||
|   integrity sha512-+10CMg9vt1MoHj6x1pxyjPSMjHTIlqs8/tBztXvPAx24SKs9jwVnKqHJumlH/IzhaPUaj3T6T6wfZr8okdXaIg== | ||||
|  | ||||
| "@types/estree@1.0.6", "@types/estree@^1.0.0": | ||||
|   version "1.0.6" | ||||
|   resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.6.tgz#628effeeae2064a1b4e79f78e81d87b7e5fc7b50" | ||||
|   integrity sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw== | ||||
|  | ||||
| "@vitest/expect@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/expect/-/expect-2.1.8.tgz#13fad0e8d5a0bf0feb675dcf1d1f1a36a1773bc1" | ||||
|   integrity sha512-8ytZ/fFHq2g4PJVAtDX57mayemKgDR6X3Oa2Foro+EygiOJHUXhCqBAAKQYYajZpFoIfvBCF1j6R6IYRSIUFuw== | ||||
|   dependencies: | ||||
|     "@vitest/spy" "2.1.8" | ||||
|     "@vitest/utils" "2.1.8" | ||||
|     chai "^5.1.2" | ||||
|     tinyrainbow "^1.2.0" | ||||
|  | ||||
| "@vitest/mocker@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/mocker/-/mocker-2.1.8.tgz#51dec42ac244e949d20009249e033e274e323f73" | ||||
|   integrity sha512-7guJ/47I6uqfttp33mgo6ga5Gr1VnL58rcqYKyShoRK9ebu8T5Rs6HN3s1NABiBeVTdWNrwUMcHH54uXZBN4zA== | ||||
|   dependencies: | ||||
|     "@vitest/spy" "2.1.8" | ||||
|     estree-walker "^3.0.3" | ||||
|     magic-string "^0.30.12" | ||||
|  | ||||
| "@vitest/pretty-format@2.1.8", "@vitest/pretty-format@^2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/pretty-format/-/pretty-format-2.1.8.tgz#88f47726e5d0cf4ba873d50c135b02e4395e2bca" | ||||
|   integrity sha512-9HiSZ9zpqNLKlbIDRWOnAWqgcA7xu+8YxXSekhr0Ykab7PAYFkhkwoqVArPOtJhPmYeE2YHgKZlj3CP36z2AJQ== | ||||
|   dependencies: | ||||
|     tinyrainbow "^1.2.0" | ||||
|  | ||||
| "@vitest/runner@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/runner/-/runner-2.1.8.tgz#b0e2dd29ca49c25e9323ea2a45a5125d8729759f" | ||||
|   integrity sha512-17ub8vQstRnRlIU5k50bG+QOMLHRhYPAna5tw8tYbj+jzjcspnwnwtPtiOlkuKC4+ixDPTuLZiqiWWQ2PSXHVg== | ||||
|   dependencies: | ||||
|     "@vitest/utils" "2.1.8" | ||||
|     pathe "^1.1.2" | ||||
|  | ||||
| "@vitest/snapshot@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/snapshot/-/snapshot-2.1.8.tgz#d5dc204f4b95dc8b5e468b455dfc99000047d2de" | ||||
|   integrity sha512-20T7xRFbmnkfcmgVEz+z3AU/3b0cEzZOt/zmnvZEctg64/QZbSDJEVm9fLnnlSi74KibmRsO9/Qabi+t0vCRPg== | ||||
|   dependencies: | ||||
|     "@vitest/pretty-format" "2.1.8" | ||||
|     magic-string "^0.30.12" | ||||
|     pathe "^1.1.2" | ||||
|  | ||||
| "@vitest/spy@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/spy/-/spy-2.1.8.tgz#bc41af3e1e6a41ae3b67e51f09724136b88fa447" | ||||
|   integrity sha512-5swjf2q95gXeYPevtW0BLk6H8+bPlMb4Vw/9Em4hFxDcaOxS+e0LOX4yqNxoHzMR2akEB2xfpnWUzkZokmgWDg== | ||||
|   dependencies: | ||||
|     tinyspy "^3.0.2" | ||||
|  | ||||
| "@vitest/utils@2.1.8": | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/@vitest/utils/-/utils-2.1.8.tgz#f8ef85525f3362ebd37fd25d268745108d6ae388" | ||||
|   integrity sha512-dwSoui6djdwbfFmIgbIjX2ZhIoG7Ex/+xpxyiEgIGzjliY8xGkcpITKTlp6B4MgtGkF2ilvm97cPM96XZaAgcA== | ||||
|   dependencies: | ||||
|     "@vitest/pretty-format" "2.1.8" | ||||
|     loupe "^3.1.2" | ||||
|     tinyrainbow "^1.2.0" | ||||
|  | ||||
| assertion-error@^2.0.1: | ||||
|   version "2.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-2.0.1.tgz#f641a196b335690b1070bf00b6e7593fec190bf7" | ||||
|   integrity sha512-Izi8RQcffqCeNVgFigKli1ssklIbpHnCYc6AknXGYoB6grJqyeby7jv12JUQgmTAnIDnbck1uxksT4dzN3PWBA== | ||||
|  | ||||
| cac@^6.7.14: | ||||
|   version "6.7.14" | ||||
|   resolved "https://registry.yarnpkg.com/cac/-/cac-6.7.14.tgz#804e1e6f506ee363cb0e3ccbb09cad5dd9870959" | ||||
|   integrity sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ== | ||||
|  | ||||
| chai@^5.1.2: | ||||
|   version "5.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/chai/-/chai-5.1.2.tgz#3afbc340b994ae3610ca519a6c70ace77ad4378d" | ||||
|   integrity sha512-aGtmf24DW6MLHHG5gCx4zaI3uBq3KRtxeVs0DjFH6Z0rDNbsvTxFASFvdj79pxjxZ8/5u3PIiN3IwEIQkiiuPw== | ||||
|   dependencies: | ||||
|     assertion-error "^2.0.1" | ||||
|     check-error "^2.1.1" | ||||
|     deep-eql "^5.0.1" | ||||
|     loupe "^3.1.0" | ||||
|     pathval "^2.0.0" | ||||
|  | ||||
| check-error@^2.1.1: | ||||
|   version "2.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/check-error/-/check-error-2.1.1.tgz#87eb876ae71ee388fa0471fe423f494be1d96ccc" | ||||
|   integrity sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw== | ||||
|  | ||||
| debug@^4.3.7: | ||||
|   version "4.4.0" | ||||
|   resolved "https://registry.yarnpkg.com/debug/-/debug-4.4.0.tgz#2b3f2aea2ffeb776477460267377dc8710faba8a" | ||||
|   integrity sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA== | ||||
|   dependencies: | ||||
|     ms "^2.1.3" | ||||
|  | ||||
| deep-eql@^5.0.1: | ||||
|   version "5.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-5.0.2.tgz#4b756d8d770a9257300825d52a2c2cff99c3a341" | ||||
|   integrity sha512-h5k/5U50IJJFpzfL6nO9jaaumfjO/f2NjK/oYB2Djzm4p9L+3T9qWpZqZ2hAbLPuuYq9wrU08WQyBTL5GbPk5Q== | ||||
|  | ||||
| es-module-lexer@^1.5.4: | ||||
|   version "1.6.0" | ||||
|   resolved "https://registry.yarnpkg.com/es-module-lexer/-/es-module-lexer-1.6.0.tgz#da49f587fd9e68ee2404fe4e256c0c7d3a81be21" | ||||
|   integrity sha512-qqnD1yMU6tk/jnaMosogGySTZP8YtUgAffA9nMN+E/rjxcfRQ6IEk7IiozUjgxKoFHBGjTLnrHB/YC45r/59EQ== | ||||
|  | ||||
| esbuild@^0.21.3: | ||||
|   version "0.21.5" | ||||
|   resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.21.5.tgz#9ca301b120922959b766360d8ac830da0d02997d" | ||||
|   integrity sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw== | ||||
|   optionalDependencies: | ||||
|     "@esbuild/aix-ppc64" "0.21.5" | ||||
|     "@esbuild/android-arm" "0.21.5" | ||||
|     "@esbuild/android-arm64" "0.21.5" | ||||
|     "@esbuild/android-x64" "0.21.5" | ||||
|     "@esbuild/darwin-arm64" "0.21.5" | ||||
|     "@esbuild/darwin-x64" "0.21.5" | ||||
|     "@esbuild/freebsd-arm64" "0.21.5" | ||||
|     "@esbuild/freebsd-x64" "0.21.5" | ||||
|     "@esbuild/linux-arm" "0.21.5" | ||||
|     "@esbuild/linux-arm64" "0.21.5" | ||||
|     "@esbuild/linux-ia32" "0.21.5" | ||||
|     "@esbuild/linux-loong64" "0.21.5" | ||||
|     "@esbuild/linux-mips64el" "0.21.5" | ||||
|     "@esbuild/linux-ppc64" "0.21.5" | ||||
|     "@esbuild/linux-riscv64" "0.21.5" | ||||
|     "@esbuild/linux-s390x" "0.21.5" | ||||
|     "@esbuild/linux-x64" "0.21.5" | ||||
|     "@esbuild/netbsd-x64" "0.21.5" | ||||
|     "@esbuild/openbsd-x64" "0.21.5" | ||||
|     "@esbuild/sunos-x64" "0.21.5" | ||||
|     "@esbuild/win32-arm64" "0.21.5" | ||||
|     "@esbuild/win32-ia32" "0.21.5" | ||||
|     "@esbuild/win32-x64" "0.21.5" | ||||
|  | ||||
| estree-walker@^2.0.2: | ||||
|   version "2.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-2.0.2.tgz#52f010178c2a4c117a7757cfe942adb7d2da4cac" | ||||
|   integrity sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w== | ||||
|  | ||||
| estree-walker@^3.0.3: | ||||
|   version "3.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-3.0.3.tgz#67c3e549ec402a487b4fc193d1953a524752340d" | ||||
|   integrity sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g== | ||||
|   dependencies: | ||||
|     "@types/estree" "^1.0.0" | ||||
|  | ||||
| expect-type@^1.1.0: | ||||
|   version "1.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/expect-type/-/expect-type-1.1.0.tgz#a146e414250d13dfc49eafcfd1344a4060fa4c75" | ||||
|   integrity sha512-bFi65yM+xZgk+u/KRIpekdSYkTB5W1pEf0Lt8Q8Msh7b+eQ7LXVtIB1Bkm4fvclDEL1b2CZkMhv2mOeF8tMdkA== | ||||
|  | ||||
| fsevents@~2.3.2, fsevents@~2.3.3: | ||||
|   version "2.3.3" | ||||
|   resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" | ||||
|   integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== | ||||
|  | ||||
| function-bind@^1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" | ||||
|   integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== | ||||
|  | ||||
| hasown@^2.0.2: | ||||
|   version "2.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" | ||||
|   integrity sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ== | ||||
|   dependencies: | ||||
|     function-bind "^1.1.2" | ||||
|  | ||||
| is-core-module@^2.16.0: | ||||
|   version "2.16.1" | ||||
|   resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.16.1.tgz#2a98801a849f43e2add644fbb6bc6229b19a4ef4" | ||||
|   integrity sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w== | ||||
|   dependencies: | ||||
|     hasown "^2.0.2" | ||||
|  | ||||
| js-tokens@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" | ||||
|   integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== | ||||
|  | ||||
| loupe@^3.1.0, loupe@^3.1.2: | ||||
|   version "3.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/loupe/-/loupe-3.1.2.tgz#c86e0696804a02218f2206124c45d8b15291a240" | ||||
|   integrity sha512-23I4pFZHmAemUnz8WZXbYRSKYj801VDaNv9ETuMh7IrMc7VuVVSo+Z9iLE3ni30+U48iDWfi30d3twAXBYmnCg== | ||||
|  | ||||
| magic-string@^0.30.10, magic-string@^0.30.12: | ||||
|   version "0.30.17" | ||||
|   resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.30.17.tgz#450a449673d2460e5bbcfba9a61916a1714c7453" | ||||
|   integrity sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA== | ||||
|   dependencies: | ||||
|     "@jridgewell/sourcemap-codec" "^1.5.0" | ||||
|  | ||||
| ms@^2.1.3: | ||||
|   version "2.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" | ||||
|   integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== | ||||
|  | ||||
| nanoid@^3.3.7: | ||||
|   version "3.3.8" | ||||
|   resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.8.tgz#b1be3030bee36aaff18bacb375e5cce521684baf" | ||||
|   integrity sha512-WNLf5Sd8oZxOm+TzppcYk8gVOgP+l58xNy58D0nbUnOxOWRWvlcCV4kUF7ltmI6PsrLl/BgKEyS4mqsGChFN0w== | ||||
|  | ||||
| path-parse@^1.0.7: | ||||
|   version "1.0.7" | ||||
|   resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" | ||||
|   integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== | ||||
|  | ||||
| pathe@^1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/pathe/-/pathe-1.1.2.tgz#6c4cb47a945692e48a1ddd6e4094d170516437ec" | ||||
|   integrity sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ== | ||||
|  | ||||
| pathval@^2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/pathval/-/pathval-2.0.0.tgz#7e2550b422601d4f6b8e26f1301bc8f15a741a25" | ||||
|   integrity sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA== | ||||
|  | ||||
| picocolors@^1.0.0, picocolors@^1.1.1: | ||||
|   version "1.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.1.1.tgz#3d321af3eab939b083c8f929a1d12cda81c26b6b" | ||||
|   integrity sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA== | ||||
|  | ||||
| picomatch@^4.0.2: | ||||
|   version "4.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-4.0.2.tgz#77c742931e8f3b8820946c76cd0c1f13730d1dab" | ||||
|   integrity sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg== | ||||
|  | ||||
| postcss@^8.4.43: | ||||
|   version "8.4.49" | ||||
|   resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.49.tgz#4ea479048ab059ab3ae61d082190fabfd994fe19" | ||||
|   integrity sha512-OCVPnIObs4N29kxTjzLfUryOkvZEq+pf8jTF0lg8E7uETuWHA+v7j3c/xJmiqpX450191LlmZfUKkXxkTry7nA== | ||||
|   dependencies: | ||||
|     nanoid "^3.3.7" | ||||
|     picocolors "^1.1.1" | ||||
|     source-map-js "^1.2.1" | ||||
|  | ||||
| resolve@^1.22.1: | ||||
|   version "1.22.10" | ||||
|   resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.10.tgz#b663e83ffb09bbf2386944736baae803029b8b39" | ||||
|   integrity sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w== | ||||
|   dependencies: | ||||
|     is-core-module "^2.16.0" | ||||
|     path-parse "^1.0.7" | ||||
|     supports-preserve-symlinks-flag "^1.0.0" | ||||
|  | ||||
| rollup-plugin-dts@^6.1.1: | ||||
|   version "6.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/rollup-plugin-dts/-/rollup-plugin-dts-6.1.1.tgz#46b33f4d1d7f4e66f1171ced9b282ac11a15a254" | ||||
|   integrity sha512-aSHRcJ6KG2IHIioYlvAOcEq6U99sVtqDDKVhnwt70rW6tsz3tv5OSjEiWcgzfsHdLyGXZ/3b/7b/+Za3Y6r1XA== | ||||
|   dependencies: | ||||
|     magic-string "^0.30.10" | ||||
|   optionalDependencies: | ||||
|     "@babel/code-frame" "^7.24.2" | ||||
|  | ||||
| rollup@^4.20.0, rollup@^4.29.1: | ||||
|   version "4.29.1" | ||||
|   resolved "https://registry.yarnpkg.com/rollup/-/rollup-4.29.1.tgz#a9aaaece817e5f778489e5bf82e379cc8a5c05bc" | ||||
|   integrity sha512-RaJ45M/kmJUzSWDs1Nnd5DdV4eerC98idtUOVr6FfKcgxqvjwHmxc5upLF9qZU9EpsVzzhleFahrT3shLuJzIw== | ||||
|   dependencies: | ||||
|     "@types/estree" "1.0.6" | ||||
|   optionalDependencies: | ||||
|     "@rollup/rollup-android-arm-eabi" "4.29.1" | ||||
|     "@rollup/rollup-android-arm64" "4.29.1" | ||||
|     "@rollup/rollup-darwin-arm64" "4.29.1" | ||||
|     "@rollup/rollup-darwin-x64" "4.29.1" | ||||
|     "@rollup/rollup-freebsd-arm64" "4.29.1" | ||||
|     "@rollup/rollup-freebsd-x64" "4.29.1" | ||||
|     "@rollup/rollup-linux-arm-gnueabihf" "4.29.1" | ||||
|     "@rollup/rollup-linux-arm-musleabihf" "4.29.1" | ||||
|     "@rollup/rollup-linux-arm64-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-arm64-musl" "4.29.1" | ||||
|     "@rollup/rollup-linux-loongarch64-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-powerpc64le-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-riscv64-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-s390x-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-x64-gnu" "4.29.1" | ||||
|     "@rollup/rollup-linux-x64-musl" "4.29.1" | ||||
|     "@rollup/rollup-win32-arm64-msvc" "4.29.1" | ||||
|     "@rollup/rollup-win32-ia32-msvc" "4.29.1" | ||||
|     "@rollup/rollup-win32-x64-msvc" "4.29.1" | ||||
|     fsevents "~2.3.2" | ||||
|  | ||||
| siginfo@^2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/siginfo/-/siginfo-2.0.0.tgz#32e76c70b79724e3bb567cb9d543eb858ccfaf30" | ||||
|   integrity sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g== | ||||
|  | ||||
| source-map-js@^1.2.1: | ||||
|   version "1.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.1.tgz#1ce5650fddd87abc099eda37dcff024c2667ae46" | ||||
|   integrity sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA== | ||||
|  | ||||
| stackback@0.0.2: | ||||
|   version "0.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/stackback/-/stackback-0.0.2.tgz#1ac8a0d9483848d1695e418b6d031a3c3ce68e3b" | ||||
|   integrity sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw== | ||||
|  | ||||
| std-env@^3.8.0: | ||||
|   version "3.8.0" | ||||
|   resolved "https://registry.yarnpkg.com/std-env/-/std-env-3.8.0.tgz#b56ffc1baf1a29dcc80a3bdf11d7fca7c315e7d5" | ||||
|   integrity sha512-Bc3YwwCB+OzldMxOXJIIvC6cPRWr/LxOp48CdQTOkPyk/t4JWWJbrilwBd7RJzKV8QW7tJkcgAmeuLLJugl5/w== | ||||
|  | ||||
| style-mod@^4.0.0, style-mod@^4.1.0: | ||||
|   version "4.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/style-mod/-/style-mod-4.1.2.tgz#ca238a1ad4786520f7515a8539d5a63691d7bf67" | ||||
|   integrity sha512-wnD1HyVqpJUI2+eKZ+eo1UwghftP6yuFheBqqe+bWCotBjC2K1YnteJILRMs3SM4V/0dLEW1SC27MWP5y+mwmw== | ||||
|  | ||||
| supports-preserve-symlinks-flag@^1.0.0: | ||||
|   version "1.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" | ||||
|   integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== | ||||
|  | ||||
| tinybench@^2.9.0: | ||||
|   version "2.9.0" | ||||
|   resolved "https://registry.yarnpkg.com/tinybench/-/tinybench-2.9.0.tgz#103c9f8ba6d7237a47ab6dd1dcff77251863426b" | ||||
|   integrity sha512-0+DUvqWMValLmha6lr4kD8iAMK1HzV0/aKnCtWb9v9641TnP/MFb7Pc2bxoxQjTXAErryXVgUOfv2YqNllqGeg== | ||||
|  | ||||
| tinyexec@^0.3.1: | ||||
|   version "0.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/tinyexec/-/tinyexec-0.3.2.tgz#941794e657a85e496577995c6eef66f53f42b3d2" | ||||
|   integrity sha512-KQQR9yN7R5+OSwaK0XQoj22pwHoTlgYqmUscPYoknOoWCWfj/5/ABTMRi69FrKU5ffPVh5QcFikpWJI/P1ocHA== | ||||
|  | ||||
| tinypool@^1.0.1: | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/tinypool/-/tinypool-1.0.2.tgz#706193cc532f4c100f66aa00b01c42173d9051b2" | ||||
|   integrity sha512-al6n+QEANGFOMf/dmUMsuS5/r9B06uwlyNjZZql/zv8J7ybHCgoihBNORZCY2mzUuAnomQa2JdhyHKzZxPCrFA== | ||||
|  | ||||
| tinyrainbow@^1.2.0: | ||||
|   version "1.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/tinyrainbow/-/tinyrainbow-1.2.0.tgz#5c57d2fc0fb3d1afd78465c33ca885d04f02abb5" | ||||
|   integrity sha512-weEDEq7Z5eTHPDh4xjX789+fHfF+P8boiFB+0vbWzpbnbsEr/GRaohi/uMKxg8RZMXnl1ItAi/IUHWMsjDV7kQ== | ||||
|  | ||||
| tinyspy@^3.0.2: | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/tinyspy/-/tinyspy-3.0.2.tgz#86dd3cf3d737b15adcf17d7887c84a75201df20a" | ||||
|   integrity sha512-n1cw8k1k0x4pgA2+9XrOkFydTerNcJ1zWCO5Nn9scWHTD+5tp8dghT2x1uduQePZTZgd3Tupf+x9BxJjeJi77Q== | ||||
|  | ||||
| typescript@^5.7.2: | ||||
|   version "5.7.2" | ||||
|   resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.7.2.tgz#3169cf8c4c8a828cde53ba9ecb3d2b1d5dd67be6" | ||||
|   integrity sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg== | ||||
|  | ||||
| vite-node@2.1.8: | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/vite-node/-/vite-node-2.1.8.tgz#9495ca17652f6f7f95ca7c4b568a235e0c8dbac5" | ||||
|   integrity sha512-uPAwSr57kYjAUux+8E2j0q0Fxpn8M9VoyfGiRI8Kfktz9NcYMCenwY5RnZxnF1WTu3TGiYipirIzacLL3VVGFg== | ||||
|   dependencies: | ||||
|     cac "^6.7.14" | ||||
|     debug "^4.3.7" | ||||
|     es-module-lexer "^1.5.4" | ||||
|     pathe "^1.1.2" | ||||
|     vite "^5.0.0" | ||||
|  | ||||
| vite@^5.0.0: | ||||
|   version "5.4.11" | ||||
|   resolved "https://registry.yarnpkg.com/vite/-/vite-5.4.11.tgz#3b415cd4aed781a356c1de5a9ebafb837715f6e5" | ||||
|   integrity sha512-c7jFQRklXua0mTzneGW9QVyxFjUgwcihC4bXEtujIo2ouWCe1Ajt/amn2PCxYnhYfd5k09JX3SB7OYWFKYqj8Q== | ||||
|   dependencies: | ||||
|     esbuild "^0.21.3" | ||||
|     postcss "^8.4.43" | ||||
|     rollup "^4.20.0" | ||||
|   optionalDependencies: | ||||
|     fsevents "~2.3.3" | ||||
|  | ||||
| vitest@^2.1.8: | ||||
|   version "2.1.8" | ||||
|   resolved "https://registry.yarnpkg.com/vitest/-/vitest-2.1.8.tgz#2e6a00bc24833574d535c96d6602fb64163092fa" | ||||
|   integrity sha512-1vBKTZskHw/aosXqQUlVWWlGUxSJR8YtiyZDJAFeW2kPAeX6S3Sool0mjspO+kXLuxVWlEDDowBAeqeAQefqLQ== | ||||
|   dependencies: | ||||
|     "@vitest/expect" "2.1.8" | ||||
|     "@vitest/mocker" "2.1.8" | ||||
|     "@vitest/pretty-format" "^2.1.8" | ||||
|     "@vitest/runner" "2.1.8" | ||||
|     "@vitest/snapshot" "2.1.8" | ||||
|     "@vitest/spy" "2.1.8" | ||||
|     "@vitest/utils" "2.1.8" | ||||
|     chai "^5.1.2" | ||||
|     debug "^4.3.7" | ||||
|     expect-type "^1.1.0" | ||||
|     magic-string "^0.30.12" | ||||
|     pathe "^1.1.2" | ||||
|     std-env "^3.8.0" | ||||
|     tinybench "^2.9.0" | ||||
|     tinyexec "^0.3.1" | ||||
|     tinypool "^1.0.1" | ||||
|     tinyrainbow "^1.2.0" | ||||
|     vite "^5.0.0" | ||||
|     vite-node "2.1.8" | ||||
|     why-is-node-running "^2.3.0" | ||||
|  | ||||
| w3c-keyname@^2.2.4: | ||||
|   version "2.2.8" | ||||
|   resolved "https://registry.yarnpkg.com/w3c-keyname/-/w3c-keyname-2.2.8.tgz#7b17c8c6883d4e8b86ac8aba79d39e880f8869c5" | ||||
|   integrity sha512-dpojBhNsCNN7T82Tm7k26A6G9ML3NkhDsnw9n/eoxSRlVBB4CEtIQ/KTCLI2Fwf3ataSXRhYFkQi3SlnFwPvPQ== | ||||
|  | ||||
| why-is-node-running@^2.3.0: | ||||
|   version "2.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/why-is-node-running/-/why-is-node-running-2.3.0.tgz#a3f69a97107f494b3cdc3bdddd883a7d65cebf04" | ||||
|   integrity sha512-hUrmaWBdVDcxvYqnyh09zunKzROWjbZTiNy8dBEjkS7ehEDQibXJ7XvlmtbwuTclUiIyN+CyXQD4Vmko8fNm8w== | ||||
|   dependencies: | ||||
|     siginfo "^2.0.0" | ||||
|     stackback "0.0.2" | ||||
| @ -42,7 +42,7 @@ export default class StreamDemuxer extends Queue<Uint8Array> { | ||||
|           // try to parse the content-length from the headers | ||||
|           const length = parseInt(match[1]) | ||||
|  | ||||
|           if (isNaN(length)) | ||||
|           if (Number.isNaN(length)) | ||||
|             return Promise.reject(new Error('invalid content length')) | ||||
|  | ||||
|           // slice the headers since we now have the content length | ||||
|  | ||||
