Compare commits
	
		
			469 Commits
		
	
	
		
			achalmers/
			...
			dependabot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 6e2274a6c4 | |||
| 4b9f71c994 | |||
| e86a5622c8 | |||
| a503d1ce50 | |||
| 11a94cc99e | |||
| e295f82495 | |||
| 0b9cf2dc21 | |||
| eb58507e93 | |||
| ca28a5f549 | |||
| 6f4bbdb79e | |||
| 6773dbe7ff | |||
| acfc2b47fa | |||
| 9dc7ff9797 | |||
| 308a0fb06e | |||
| 214ae6f512 | |||
| 8d54fec589 | |||
| 4bfbecd3e7 | |||
| dff3848a00 | |||
| f875efab1b | |||
| 3f082c8222 | |||
| e1c45bdb33 | |||
| 5cb5dbd689 | |||
| 0a8881bc69 | |||
| be9438160e | |||
| 77b565f781 | |||
| c843dfad95 | |||
| a3ff0a45eb | |||
| 4617ad0fed | |||
| 5fa51a2f92 | |||
| 4218777afb | |||
| 8b1b462e29 | |||
| 2bc99ba39b | |||
| ffe0da6dcd | |||
| d27afb8c74 | |||
| 1c778bf373 | |||
| 5df8a943a9 | |||
| ab729dbcdb | |||
| 84865eaed0 | |||
| 543e809739 | |||
| 61b669cf4e | |||
| 75f1aaa824 | |||
| f4848d7dea | |||
| a0167f6ba6 | |||
| e5a26c42e6 | |||
| 9c87b124d9 | |||
| 21389c089d | |||
| 29f57be8c1 | |||
| cd55f07619 | |||
| baf7d3dd9d | |||
| 54a9a50969 | |||
| 2830c750fa | |||
| d3160cd85a | |||
| fd1b4c3a32 | |||
| b0a41c31ac | |||
| 5825ba575c | |||
| e5bec2140e | |||
| 7bf6bc3048 | |||
| 22f9df73ed | |||
| 834472e0a6 | |||
| bcdf6e314f | |||
| 55e9845ade | |||
| d61cf882c1 | |||
| 874d19cbfd | |||
| 9dcc955760 | |||
| 9b594efe53 | |||
| 7b9f40c4cb | |||
| 81b79da90f | |||
| 2ad5a880fa | |||
| b57a9ba54c | |||
| b32f5c1d4e | |||
| b6d4cc7a4e | |||
| 43a34b191e | |||
| 19a93e8deb | |||
| b8c623e1ec | |||
| 4006c28479 | |||
| 8c932fdb8d | |||
| a74c715c01 | |||
| 1ac39d95f2 | |||
| 41b1ec94fa | |||
| 525c803888 | |||
| 2ee1c78aad | |||
| dc21034b86 | |||
| 1684786659 | |||
| 12505b4398 | |||
| 115f2fdea2 | |||
| 0df28abc4b | |||
| 1e07ea4986 | |||
| f34c23d203 | |||
| 5295f0ae7d | |||
| 07a90b3171 | |||
| 54936f6932 | |||
| 6e296af507 | |||
| 60c152bf14 | |||
| 59de494125 | |||
| 1c44b01d16 | |||
| 789fb83a5d | |||
| 63fc287742 | |||
| 5e1b91b0e7 | |||
| a1c2e817a4 | |||
| 6ed4e72e1d | |||
| 6477011c0f | |||
| cd9dc3e6a5 | |||
| 4b424de5a6 | |||
| 0f1b94f8b9 | |||
| 8879f488bb | |||
| 67d0fb76f6 | |||
| fff3c58560 | |||
| 8880df4fbb | |||
| d94017c5e3 | |||
| 8fe91259fa | |||
| 57d4204f47 | |||
| ee601f93bf | |||
| b0b48a2e9f | |||
| 46f940ead5 | |||
| 014cedb2cc | |||
| 2375f900b9 | |||
| 9fd4fd0dd8 | |||
| ee5037bf35 | |||
| 881745e131 | |||
| 49fce9ed57 | |||
| fb7b2be427 | |||
| 2ec68e3c73 | |||
| 6e2dd53ee0 | |||
| f5c262206e | |||
| 9c9b448705 | |||
| 615b03aea5 | |||
| c3c435348d | |||
| d13f7fd508 | |||
| af842aeded | |||
| 0d4b7adf99 | |||
| e708b6ee6b | |||
| 4dd8a25fdd | |||
| 029799215b | |||
| e3b8807d6f | |||
| 0e5d88df0b | |||
| 95781143eb | |||
| c184a7d4d8 | |||
| c38e52fbb7 | |||
| ea0a3ac3ba | |||
| 385589ddf9 | |||
| 22df47fa96 | |||
| a68748abcf | |||
| 1b8688f274 | |||
| 397839da84 | |||
| ac120838e5 | |||
| e6a2ac9c4a | |||
| 6e7e6e96cf | |||
| 73e155d79b | |||
| a782f26ec2 | |||
| 01076c3aed | |||
| fe512611ac | |||
| cba953c245 | |||
| 54ca6ea0b2 | |||
| 6a01608c3a | |||
| 530f15e04a | |||
| 725e59d987 | |||
| 54313c9b03 | |||
| 890d96496c | |||
| 35999366a7 | |||
| 2affc7271d | |||
| d30fbf8b4b | |||
| 3f7e776464 | |||
| 79cff57f43 | |||
| 1cd2cd82b2 | |||
| 60e187bd3e | |||
| c64175425b | |||
| 36464e6984 | |||
| 2f0002e53c | |||
| 482833c88f | |||
| d9d0a72306 | |||
| 65cd9fab64 | |||
| 5e41e382ce | |||
| 1e3cb00092 | |||
| d1a2bd01ca | |||
| aca13d087b | |||
| fcdde3e482 | |||
| a1df3d0ffc | |||
| 1852e6167b | |||
| 29bf77bb82 | |||
| e81b614523 | |||
| 5a5fe3bb95 | |||
| 0710f6e5f2 | |||
| c9d5633647 | |||
| f9419a98b5 | |||
| 999f72bccf | |||
| 9dbe74e008 | |||
| 88d9cdc52b | |||
| 2dd1f0f213 | |||
| b971f3ecf4 | |||
| 2198bd7580 | |||
| 5fa1497b75 | |||
| ff86e41283 | |||
| 08e4c03ca7 | |||
| c654582137 | |||
| 6c2fa95a32 | |||
| 263a4f324d | |||
| 3160c58d8a | |||
| 73e26cbb4d | |||
| 21e2a92f54 | |||
| d7f2bfdabe | |||
| a76eabbb80 | |||
| a82564989e | |||
| e69837a411 | |||
| 7e31f870bf | |||
| 2f51763df9 | |||
| 7c4bf8d793 | |||
| 4747cdcab6 | |||
| de73f335fe | |||
| a62004da82 | |||
| 92e0da1f8d | |||
| a111473658 | |||
| 7cfed9bff4 | |||
| a30bd185d8 | |||
| e8cae630a1 | |||
| 74ec749560 | |||
| ebdaf59d1c | |||
| cd68414d54 | |||
| c8238ff04a | |||
| 8089369108 | |||
| 8ebe78c664 | |||
| a85c1a9375 | |||
| 5701616f3e | |||
| 846acaba2f | |||
| 0a524d42f6 | |||
| fe28527ef9 | |||
| 0e8d0083c4 | |||
| 4f4167b247 | |||
| fbc2e9d02c | |||
| 33b15e818b | |||
| 6cebb84ae0 | |||
| 85403e47e4 | |||
| 0dfee64e3b | |||
| 6370d45f94 | |||
| fb3e922180 | |||
| 1257ec0327 | |||
| 08e9fe2e52 | |||
| 7cec1d45fe | |||
| 93710bc8f2 | |||
| 87e7e9447f | |||
| 8be113d284 | |||
| 7cfc927d5c | |||
| c0f04d5f86 | |||
| 3dbc701f26 | |||
| 16e7ae38e3 | |||
| 24c7260327 | |||
| 72cfc4a471 | |||
| 2d128ed32e | |||
| cd6749ba02 | |||
| 7243405e1b | |||
| c8da057ec2 | |||
| 220fe5b2b8 | |||
| 4e6429de49 | |||
| 5391a65b18 | |||
| 592628917a | |||
| 4c6e8633f7 | |||
| c5150468a2 | |||
| 39126dbff1 | |||
| f86a69f12a | |||
| de354ee5d3 | |||
| dfef7338ee | |||
| ee08948f54 | |||
| 832f6b65e2 | |||
| 68efd77c5d | |||
| 8f138109dd | |||
| 8972f53256 | |||
| 0c5b13ade5 | |||
| 446f92a53a | |||
| 2256e3bc09 | |||
| 9e2876edc6 | |||
| a138af1ec8 | |||
| 684c585a48 | |||
| 500be20649 | |||
| 5fbbe2fa8c | |||
| 5f5ecc5afe | |||
| 3dafc31cad | |||
| 9c230bc678 | |||
| 1fad6966b6 | |||
| c7efb4c006 | |||
| 68fd921a64 | |||
| a20e710e8f | |||
| 9daf2d7794 | |||
| f86473d13b | |||
| 6fccc68c18 | |||
| ade66d0876 | |||
| b5f3a067ee | |||
| bb9d24f821 | |||
| bd3cd97d74 | |||
| 1b5839a7f8 | |||
| a9e480f0ed | |||
| 63fa04608c | |||
| 0d4d7fa751 | |||
| 68cdb68231 | |||
| 053bdffc45 | |||
| 9ffc08b84a | |||
| 47e8d3f4fc | |||
| 53db421d97 | |||
| 289ed291c4 | |||
| 39ceb83840 | |||
| af449ff6ca | |||
| e1bf55cc4a | |||
| 8fe2d33063 | |||
| d7e36eed24 | |||
| 6123ed6a82 | |||
| da6cd5cf9f | |||
| ad5bfa1a29 | |||
| 6358bdd7cd | |||
| d6fe414b2e | |||
| 25e7e8cb89 | |||
| a175870453 | |||
| 24516cdb2d | |||
| 496398de52 | |||
| 3304a74064 | |||
| f4877cb160 | |||
| f7196e7eb0 | |||
| 5260bd6820 | |||
| 394653247a | |||
| fbd22a2d17 | |||
| 7c568f68e5 | |||
| 31b0766754 | |||
| cd33b40c37 | |||
| 3300772e3d | |||
| fa37752a41 | |||
| 34c5c153c8 | |||
| 3f343698a8 | |||
| 0bd9f42e17 | |||
| aad29fca9f | |||
| a8c1a14d48 | |||
| 8194f8b70b | |||
| 03e4f457d4 | |||
| 226ed37c5f | |||
| 0f3f923019 | |||
| bf8fb0d127 | |||
| 4a275c2ff7 | |||
| baf5509f1d | |||
| 47a5e1f6d3 | |||
| d85211c5a4 | |||
| 1beb6b5186 | |||
| 17978ab1d7 | |||
| a1bcad9dfb | |||
| 2e7bdf02cf | |||
| 6f76196b72 | |||
| e7af064518 | |||
| 674d49e2ae | |||
| 4cb48674c6 | |||
| 82daec2aff | |||
| f1ef9d5200 | |||
| dc226d3270 | |||
| 7bf50d8fe0 | |||
| b26764bc9a | |||
| 1b0c6298d7 | |||
| fe9a483726 | |||
| bd42ea037b | |||
| fdb1b21af3 | |||
| 630ef316b8 | |||
| e322926be9 | |||
| a9e61da8b5 | |||
| e2a835a437 | |||
| c61273085f | |||
| a79e365c0f | |||
| 2386ba24e5 | |||
| e42a891df8 | |||
| 98200565bf | |||
| 570fd827ed | |||
| 0add26cf61 | |||
| b54fc534c2 | |||
| c66f851a3f | |||
| 13b8ab71d8 | |||
| bdeab4f87d | |||
| 05ccf5e2f4 | |||
| 7ab015d783 | |||
| 3d6cfa980f | |||
| 9f5f1eb8c3 | |||
| 50fcdff879 | |||
| efaae2b193 | |||
| 7e4ebacb72 | |||
| 72482506c3 | |||
| a51b5b09a3 | |||
| 53ccc1ed6c | |||
| 8106749ccf | |||
| 081e34a600 | |||
| 541400f4be | |||
| 39d249030d | |||
| f8a69fac73 | |||
| 24f4bf160f | |||
| 8011594e24 | |||
| 0e09affb8f | |||
| 197a47346a | |||
| 9d083710e0 | |||
| afa7c1dc4e | |||
| c74b695a71 | |||
| d0c244e05e | |||
| a315b77f02 | |||
| 15c854ff18 | |||
| acd3a5717d | |||
| 8a2555550f | |||
| 62e75c852a | |||
| dd3601ea7b | |||
| a5e7782d9a | |||
| 79b0b70688 | |||
| 1d134c1be0 | |||
| 1c58572234 | |||
| ecee51e82b | |||
| 978ac42f1c | |||
| 893996430e | |||
| 41e65fc4e9 | |||
| 99aa74ceba | |||
| 0bcf33ed00 | |||
| d0a9b5ecab | |||
| a569f818cf | |||
| f73556ba7b | |||
| 29cdc66b34 | |||
| c9800a58d0 | |||
| e46aca4992 | |||
| 9564890b29 | |||
| f8a1f40f20 | |||
| c551d88db4 | |||
| 8eee3e1c58 | |||
| b02529cae0 | |||
| cf03021366 | |||
| f52d2d55f1 | |||
| 59b1319e50 | |||
| b07bbda20b | |||
| 3c01924184 | |||
| bd16902f02 | |||
| 8c3af1a72a | |||
| 33f5d7740d | |||
| b388f60648 | |||
| 8f4380be74 | |||
| 9ae8042a57 | |||
| 4b676d47da | |||
| e6641e68f3 | |||
| 450afb1605 | |||
| 04433fecad | |||
| 6567e2ff92 | |||
| 91c32a7fe2 | |||
| f735cdc22e | |||
| 1b72c7df85 | |||
| 062abd148f | |||
| c93ed0f306 | |||
| 27e2518dde | |||
| dc6505acaf | |||
| 6ff3284eca | |||
| 4cb6ceb043 | |||
| 1db3e1b5e4 | |||
| d797d20d50 | |||
| cf52e151fb | |||
| 87c551b869 | |||
| 2001262494 | |||
| 777b225066 | |||
| ae6373e4f5 | |||
| 87979b17cf | |||
| 4be63e7331 | |||
| 56d930c4f2 | |||
| d48eb0c66c | |||
| a69d7d03d0 | |||
| 00a8273173 | |||
| 51868f892b | |||
| 8e9286a747 | |||
| 023ed1a687 | |||
| 5b7d707b26 | |||
| 5b95194aa7 | |||
| 6080a99e73 | |||
| 5106c49e21 | |||
| 25f18845c7 | |||
| 0a7f1a41fc | |||
| 1625b58577 | |||
| ab6115c4e2 | |||
| fe621240c3 | |||
| 97faf5ae2b | 
| @ -1,3 +1,3 @@ | ||||
| [codespell] | ||||
| ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,absolutey,atleast | ||||
| ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,absolutey,atleast,ue,afterall | ||||
| skip: **/target,node_modules,build,**/Cargo.lock,./docs/kcl/*.md,./src-tauri/gen/schemas | ||||
|  | ||||
							
								
								
									
										10
									
								
								.eslintrc
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								.eslintrc
									
									
									
									
									
								
							| @ -4,7 +4,8 @@ | ||||
|       "project": "./tsconfig.json" | ||||
|     }, | ||||
|     "plugins": [ | ||||
|       "css-modules" | ||||
|       "css-modules", | ||||
|       "suggest-no-throw", | ||||
|     ], | ||||
|     "extends": [ | ||||
|       "react-app", | ||||
| @ -17,6 +18,7 @@ | ||||
|         "never" | ||||
|       ], | ||||
|       "react-hooks/exhaustive-deps": "off", | ||||
|       "suggest-no-throw/suggest-no-throw": "warn", | ||||
|     }, | ||||
|     "overrides": [ | ||||
|       { | ||||
| @ -25,6 +27,12 @@ | ||||
|           "@typescript-eslint/no-floating-promises": "warn", | ||||
|           "testing-library/prefer-screen-queries": "off" | ||||
|         } | ||||
|       }, | ||||
|       { | ||||
|         "files": ["src/**/*.test.ts"], | ||||
|         "rules": { | ||||
|           "suggest-no-throw/suggest-no-throw": "off", | ||||
|         } | ||||
|       } | ||||
|     ] | ||||
| } | ||||
|  | ||||
							
								
								
									
										37
									
								
								.github/ISSUE_TEMPLATE/cryptic_error.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								.github/ISSUE_TEMPLATE/cryptic_error.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| name: Cryptic KCL Error | ||||
| description: File a bug report for source code that produces a confusing error | ||||
| title: "[CRYPTIC]: " | ||||
| labels: ["cryptic-error"] | ||||
| assignees: [] | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Thank you for taking the time to report a confusing error. Please provide as much information as possible to help us resolve it." | ||||
|  | ||||
|   - type: textarea | ||||
|     id: kcl | ||||
|     attributes: | ||||
|       label: Paste minimal KCL source that produces a cryptic error | ||||
|       description: Minimal KCL reproducer that produces a cryptic error | ||||
|       placeholder: "const ..." | ||||
|       render: javascript | ||||
|     validations: | ||||
|       required: true | ||||
|  | ||||
|   - type: textarea | ||||
|     id: expected-behavior | ||||
|     attributes: | ||||
|       label: Expected Behavior | ||||
|       description: Description of what you expected to happen (if you know). | ||||
|       placeholder: "I expected that..." | ||||
|     validations: | ||||
|       required: false | ||||
|  | ||||
|   - type: textarea | ||||
|     id: additional-context | ||||
|     attributes: | ||||
|       label: Additional Context | ||||
|       description: Add any other context about the problem here. | ||||
|       placeholder: "Anything else you want to add..." | ||||
|     validations: | ||||
|       required: false | ||||
							
								
								
									
										4
									
								
								.github/workflows/cargo-bench.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/cargo-bench.yml
									
									
									
									
										vendored
									
									
								
							| @ -38,5 +38,7 @@ jobs: | ||||
|       - name: Benchmark kcl library | ||||
|         shell: bash | ||||
|         run: |- | ||||
|           cd src/wasm-lib/kcl; cargo bench -- iai | ||||
|           cd src/wasm-lib/kcl; cargo bench --all-features -- iai | ||||
|         env: | ||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN}} | ||||
|  | ||||
|  | ||||
							
								
								
									
										40
									
								
								.github/workflows/cargo-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								.github/workflows/cargo-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|     paths: | ||||
|       - '**/Cargo.toml' | ||||
|       - '**/Cargo.lock' | ||||
|       - '**/rust-toolchain.toml' | ||||
|       - '**.rs' | ||||
|       - .github/workflows/cargo-check.yml | ||||
|   pull_request: | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
| name: cargo check | ||||
| jobs: | ||||
|   cargocheck: | ||||
|     name: cargo check | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       matrix: | ||||
|         dir: ['src/wasm-lib'] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: Install latest rust | ||||
|         uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|             toolchain: stable | ||||
|             override: true | ||||
|  | ||||
|       - name: Rust Cache | ||||
|         uses: Swatinem/rust-cache@v2.6.1 | ||||
|  | ||||
|       - name: Run check | ||||
|         run: | | ||||
|           cd "${{ matrix.dir }}" | ||||
|           # We specifically want to test the disable-println feature | ||||
|           # Since it is not enabled by default, we need to specify it | ||||
|           # This is used in kcl-lsp | ||||
|           cargo check --all --features disable-println --features pyo3 | ||||
							
								
								
									
										11
									
								
								.github/workflows/cargo-clippy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/cargo-clippy.yml
									
									
									
									
										vendored
									
									
								
							| @ -9,6 +9,12 @@ on: | ||||
|       - '**.rs' | ||||
|       - .github/workflows/cargo-clippy.yml | ||||
|   pull_request: | ||||
|     paths: | ||||
|       - '**/Cargo.toml' | ||||
|       - '**/Cargo.lock' | ||||
|       - '**/rust-toolchain.toml' | ||||
|       - '**.rs' | ||||
|       - .github/workflows/cargo-clippy.yml | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
| @ -54,3 +60,8 @@ jobs: | ||||
|         run: | | ||||
|           cd "${{ matrix.dir }}" | ||||
|           cargo clippy --all --tests --benches -- -D warnings | ||||
|       # If this fails, run "cargo check" to update Cargo.lock, | ||||
|       # then add Cargo.lock to the PR. | ||||
|       - name: Check Cargo.lock doesn't need updating | ||||
|         run: | | ||||
|           cargo check --locked || echo "Pls run cargo check and commit the changed Cargo.lock" | ||||
|  | ||||
							
								
								
									
										115
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										115
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @ -13,12 +13,18 @@ on: | ||||
|   # Will checkout the last commit from the default branch (main as of 2023-10-04) | ||||
|  | ||||
| env: | ||||
|   CUT_RELEASE_PR: ${{ github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} | ||||
|   BUILD_RELEASE: ${{ github.event_name == 'release' || github.event_name == 'schedule' || github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|   pull-requests: write | ||||
|   actions: read | ||||
|  | ||||
| jobs: | ||||
|   check-format: | ||||
|     runs-on: 'ubuntu-latest' | ||||
| @ -83,8 +89,43 @@ jobs: | ||||
|       - run: yarn build:wasm | ||||
|  | ||||
|       - run: yarn simpleserver:ci | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|  | ||||
|       - name: Install Chromium Browser | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: yarn playwright install chromium --with-deps | ||||
|  | ||||
|       - name: run unit tests | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: yarn test:nowatch | ||||
|         env: | ||||
|           VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|  | ||||
|       - name: check for changes | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         id: git-check | ||||
|         run: | | ||||
|             git add src/lang/std/artifactMapGraphs | ||||
|             if git status src/lang/std/artifactMapGraphs | grep -q "Changes to be committed" | ||||
|             then echo "modified=true" >> $GITHUB_OUTPUT | ||||
|             else echo "modified=false" >> $GITHUB_OUTPUT | ||||
|             fi | ||||
|       - name: Commit changes, if any | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' && steps.git-check.outputs.modified == 'true' }} | ||||
|         run: | | ||||
|           git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||||
|           git config --local user.name "github-actions[bot]" | ||||
|           git remote set-url origin https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git | ||||
|           git fetch origin | ||||
|           echo ${{ github.head_ref }} | ||||
|           git checkout ${{ github.head_ref }} | ||||
|           # TODO when webkit works on ubuntu remove the os part of the commit message | ||||
|           git commit -am "Look at this (photo)Graph *in the voice of Nickelback*" || true | ||||
|           git push | ||||
|           git push origin ${{ github.head_ref }} | ||||
|          | ||||
|  | ||||
|  | ||||
|       - run: yarn test:nowatch | ||||
|  | ||||
|  | ||||
|   prepare-json-files: | ||||
| @ -110,8 +151,14 @@ jobs: | ||||
|           echo "$(jq --arg name 'Zoo Modeling App (Nightly)' \ | ||||
|             '.productName=$name' src-tauri/tauri.release.conf.json --indent 2)" > src-tauri/tauri.release.conf.json | ||||
|  | ||||
|       - name: Set updater test version | ||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||
|         run: | | ||||
|           echo "$(jq --arg url 'https://dl.zoo.dev/releases/modeling-app/test/last_update.json' \ | ||||
|             '.plugins.updater.endpoints[]=$url' src-tauri/tauri.release.conf.json --indent 2)" > src-tauri/tauri.release.conf.json | ||||
|  | ||||
|       - uses: actions/upload-artifact@v3 | ||||
|         if: github.event_name == 'schedule' | ||||
|         if: ${{ github.event_name == 'schedule' || env.CUT_RELEASE_PR == 'true' }} | ||||
|         with: | ||||
|           path: | | ||||
|             package.json | ||||
| @ -138,6 +185,7 @@ jobs: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/download-artifact@v3 | ||||
|         if: github.event_name == 'schedule' | ||||
|  | ||||
|       - name: Copy updated .json files | ||||
|         if: github.event_name == 'schedule' | ||||
| @ -147,6 +195,14 @@ jobs: | ||||
|           cp artifact/src-tauri/tauri.conf.json src-tauri/tauri.conf.json | ||||
|           cp artifact/src-tauri/tauri.release.conf.json src-tauri/tauri.release.conf.json | ||||
|  | ||||
|       - name: Update WebView2 on Windows | ||||
|         if: matrix.os == 'windows-latest' | ||||
|         # Workaround needed to build the tauri windows app with matching edge version. | ||||
|         # From https://github.com/actions/runner-images/issues/9538 | ||||
|         run: | | ||||
|           Invoke-WebRequest -Uri 'https://go.microsoft.com/fwlink/p/?LinkId=2124703' -OutFile 'setup.exe' | ||||
|           Start-Process -FilePath setup.exe -Verb RunAs -Wait | ||||
|  | ||||
|       - name: Install ubuntu system dependencies | ||||
|         if: matrix.os == 'ubuntu-latest' | ||||
|         run: | | ||||
| @ -172,9 +228,7 @@ jobs: | ||||
|       - name: Setup Rust | ||||
|         uses: dtolnay/rust-toolchain@stable | ||||
|  | ||||
|       # TODO: re-enable for Windows builds, see https://github.com/tauri-apps/tauri/issues/9045 | ||||
|       - name: Setup Rust cache | ||||
|         if: matrix.os != 'windows-latest' | ||||
|         uses: swatinem/rust-cache@v2 | ||||
|         with: | ||||
|           workspaces: './src-tauri -> target' | ||||
| @ -232,12 +286,8 @@ jobs: | ||||
|         shell: cmd | ||||
|  | ||||
|       - name: Build the app (debug) | ||||
|         uses: tauri-apps/tauri-action@v0 | ||||
|         if: ${{ env.BUILD_RELEASE == 'false' }} | ||||
|         with: | ||||
|           includeRelease: false | ||||
|           includeDebug: true | ||||
|           args: "${{ env.TAURI_ARGS_MACOS }} ${{ env.TAURI_ARGS_UBUNTU }}" | ||||
|         run: "yarn tauri build --debug ${{ env.TAURI_ARGS_MACOS }} ${{ env.TAURI_ARGS_UBUNTU }}" | ||||
|  | ||||
|       - name: Build for Mac TestFlight (nightly) | ||||
|         if: ${{ github.event_name == 'schedule' && matrix.os == 'macos-14' }} | ||||
| @ -330,7 +380,6 @@ jobs: | ||||
|       # specific and we want to overwrite it with the this new build after and | ||||
|       # not upload the apple store build to the public bucket | ||||
|       - name: Build the app (release) and sign | ||||
|         uses: tauri-apps/tauri-action@v0 | ||||
|         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||
|         env: | ||||
|           TAURI_SIGNING_PRIVATE_KEY: ${{ secrets.TAURI_SIGNING_PRIVATE_KEY }} | ||||
| @ -342,8 +391,7 @@ jobs: | ||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||
|           APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }} | ||||
|           TAURI_CONF_ARGS: "--config ${{ matrix.os == 'windows-latest' && 'src-tauri\\tauri.release.conf.json' || 'src-tauri/tauri.release.conf.json' }}" | ||||
|         with: | ||||
|           args: "${{ env.TAURI_CONF_ARGS }} ${{ env.TAURI_ARGS_MACOS }} ${{ env.TAURI_ARGS_UBUNTU }}" | ||||
|         run: "yarn tauri build ${{ env.TAURI_CONF_ARGS }} ${{ env.TAURI_ARGS_MACOS }} ${{ env.TAURI_ARGS_UBUNTU }}" | ||||
|  | ||||
|       - uses: actions/upload-artifact@v3 | ||||
|         if: matrix.os != 'ubuntu-latest' | ||||
| @ -364,8 +412,45 @@ jobs: | ||||
|           E2E_APPLICATION: "./src-tauri/target/${{ env.BUILD_RELEASE == 'true' && 'release' || 'debug' }}/zoo-modeling-app" | ||||
|           KITTYCAD_API_TOKEN: ${{ env.BUILD_RELEASE == 'true' && secrets.KITTYCAD_API_TOKEN || secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|  | ||||
|       - name: Run e2e tests (windows only) | ||||
|         if: ${{ matrix.os == 'windows-latest' && github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: | | ||||
|           cargo install tauri-driver --force | ||||
|           yarn wdio run wdio.conf.ts | ||||
|         env: | ||||
|           E2E_APPLICATION: ".\\src-tauri\\target\\${{ env.BUILD_RELEASE == 'true' && 'release' || 'debug' }}\\Zoo Modeling App.exe" | ||||
|           KITTYCAD_API_TOKEN: ${{ env.BUILD_RELEASE == 'true' && secrets.KITTYCAD_API_TOKEN || secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|           VITE_KC_API_BASE_URL: ${{ env.BUILD_RELEASE == 'true' && 'https://api.zoo.dev' || 'https://api.dev.zoo.dev' }} | ||||
|           E2E_TAURI_ENABLED: true | ||||
|           TS_NODE_COMPILER_OPTIONS: '{"module": "commonjs"}' | ||||
|  | ||||
|       - uses: actions/download-artifact@v3 | ||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||
|  | ||||
|       - name: Copy updated .json file for updater test | ||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||
|         run: | | ||||
|           ls -l artifact | ||||
|           cp artifact/src-tauri/tauri.release.conf.json src-tauri/tauri.release.conf.json | ||||
|           cat src-tauri/tauri.release.conf.json | ||||
|  | ||||
|       - name: Build the app (release, updater test) | ||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' && matrix.os != 'ubuntu-latest' }} | ||||
|         env: | ||||
|           TAURI_CONF_ARGS: "-c ${{ matrix.os == 'windows-latest' && 'src-tauri\\tauri.release.conf.json' || 'src-tauri/tauri.release.conf.json' }}" | ||||
|           TAURI_BUNDLE_ARGS: "-b ${{ matrix.os == 'windows-latest' && 'msi' || 'dmg' }}" | ||||
|         run: "yarn tauri build ${{ env.TAURI_CONF_ARGS }} ${{ env.TAURI_BUNDLE_ARGS }} ${{ env.TAURI_ARGS_MACOS }}" | ||||
|  | ||||
|       - uses: actions/upload-artifact@v3 | ||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' && matrix.os != 'ubuntu-latest' }} | ||||
|         with: | ||||
|           path: "${{ matrix.os == 'macos-14' && 'src-tauri/target/universal-apple-darwin/release/bundle/dmg/*.dmg' || 'src-tauri/target/release/bundle/msi/*.msi' }}" | ||||
|           name: updater-test | ||||
|  | ||||
|  | ||||
|   publish-apps-release: | ||||
|     permissions: | ||||
|       contents: write | ||||
|     runs-on: ubuntu-latest | ||||
|     if: ${{ github.event_name == 'release' || github.event_name == 'schedule' }} | ||||
|     needs: [check-format, check-types, check-typos, build-test-web, prepare-json-files, build-test-apps] | ||||
| @ -450,7 +535,7 @@ jobs: | ||||
|           project_id: kittycadapi | ||||
|  | ||||
|       - name: Upload release files to public bucket | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.0 | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.1 | ||||
|         with: | ||||
|           path: artifact | ||||
|           glob: '*/Zoo*' | ||||
| @ -458,13 +543,13 @@ jobs: | ||||
|           destination: ${{ env.BUCKET_DIR }}/${{ env.VERSION }} | ||||
|  | ||||
|       - name: Upload update endpoint to public bucket | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.0 | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.1 | ||||
|         with: | ||||
|           path: last_update.json | ||||
|           destination: ${{ env.BUCKET_DIR }} | ||||
|  | ||||
|       - name: Upload download endpoint to public bucket | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.0 | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.1.1 | ||||
|         with: | ||||
|           path: last_download.json | ||||
|           destination: ${{ env.BUCKET_DIR }} | ||||
|  | ||||
							
								
								
									
										49
									
								
								.github/workflows/generate-machine-api-types.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								.github/workflows/generate-machine-api-types.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,49 @@ | ||||
| name: generate machine-api types | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     paths: | ||||
|       - 'openapi/machine-api.json' | ||||
|       - '.github/workflows/generate-machine-api-types.yml' | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
| jobs: | ||||
|   generate: | ||||
|     runs-on: 'ubuntu-latest' | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'yarn' | ||||
|       - run: yarn install | ||||
|       - run: yarn generate:machine-api | ||||
|       - run: yarn fmt | ||||
|       - name: check for changes | ||||
|         id: git-check | ||||
|         run: | | ||||
|             git add . | ||||
|             if git status | grep -q "Changes to be committed" | ||||
|             then echo "modified=true" >> $GITHUB_OUTPUT | ||||
|             else echo "modified=false" >> $GITHUB_OUTPUT | ||||
|             fi | ||||
|       - name: Commit changes, if any | ||||
|         if: steps.git-check.outputs.modified == 'true' | ||||
|         run: | | ||||
|           git add . | ||||
|           git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||||
|           git config --local user.name "github-actions[bot]" | ||||
|           git remote set-url origin https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git | ||||
|           git fetch origin | ||||
|           echo ${{ github.head_ref }} | ||||
|           git checkout ${{ github.head_ref }} | ||||
|           git commit -am "New machine-api types" || true | ||||
|           git push | ||||
|           git push origin ${{ github.head_ref }} | ||||
|  | ||||
							
								
								
									
										234
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										234
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							| @ -13,7 +13,7 @@ permissions: | ||||
|   contents: write | ||||
|   pull-requests: write | ||||
|   actions: read | ||||
|    | ||||
|  | ||||
|  | ||||
| jobs: | ||||
|  | ||||
| @ -34,10 +34,17 @@ jobs: | ||||
|               - 'src/wasm-lib/**' | ||||
|  | ||||
|   playwright-ubuntu: | ||||
|     timeout-minutes: 60 | ||||
|     timeout-minutes: 30 | ||||
|     runs-on: ubuntu-latest-8-cores | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         shardIndex: [1, 2, 3, 4] | ||||
|         shardTotal: [4] | ||||
|     needs: check-rust-changes | ||||
|     steps: | ||||
|     - name: Tune GitHub-hosted runner network | ||||
|       uses: smorimoto/tune-github-hosted-runner-network@v1 | ||||
|     - uses: actions/checkout@v4 | ||||
|     - uses: actions/setup-node@v4 | ||||
|       with: | ||||
| @ -46,12 +53,18 @@ jobs: | ||||
|     - uses: KittyCAD/action-install-cli@main | ||||
|     - name: Install dependencies | ||||
|       run: yarn | ||||
|     - name: Cache Playwright Browsers | ||||
|       uses: actions/cache@v4 | ||||
|       with: | ||||
|         path: | | ||||
|           ~/.cache/ms-playwright/ | ||||
|         key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} | ||||
|     - name: Install Playwright Browsers | ||||
|       run: yarn playwright install --with-deps | ||||
|     - name: Download Wasm Cache | ||||
|       id: download-wasm | ||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||
|       uses: dawidd6/action-download-artifact@v3 | ||||
|       uses: dawidd6/action-download-artifact@v6 | ||||
|       continue-on-error: true | ||||
|       with: | ||||
|         github_token: ${{secrets.GITHUB_TOKEN}} | ||||
| @ -75,6 +88,20 @@ jobs: | ||||
|       uses: Swatinem/rust-cache@v2 | ||||
|       with: | ||||
|         workspaces: './src/wasm-lib' | ||||
|     - name: Install vector | ||||
|       run: | | ||||
|         curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | ||||
|         chmod +x /tmp/vector.sh | ||||
|         /tmp/vector.sh -y -no-modify-path | ||||
|         mkdir -p /tmp/vector | ||||
|         cp .github/workflows/vector.toml /tmp/vector.toml | ||||
|         sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | ||||
|         sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | ||||
|         sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | ||||
|         sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | ||||
|         sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | ||||
|         cat /tmp/vector.toml | ||||
|         ${HOME}/.vector/bin/vector --config /tmp/vector.toml & | ||||
|     - name: Build Wasm (because rust diff) | ||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||
|       run: yarn build:wasm | ||||
| @ -84,26 +111,30 @@ jobs: | ||||
|     - name: build web | ||||
|       run: yarn build:local | ||||
|     - name: Run ubuntu/chrome snapshots | ||||
|       run: yarn playwright test --project="Google Chrome" --update-snapshots e2e/playwright/snapshot-tests.spec.ts | ||||
|       run: | | ||||
|         yarn playwright test --project="Google Chrome" --retries="3" --update-snapshots --grep=@snapshot  --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} | ||||
|       env: | ||||
|         CI: true | ||||
|         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|         snapshottoken: ${{ secrets.KITTYCAD_API_TOKEN }} | ||||
|     - uses: actions/upload-artifact@v3 | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: always() | ||||
|       with: | ||||
|         name: playwright-report | ||||
|         name: playwright-report-ubuntu-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: playwright-report/ | ||||
|         retention-days: 30 | ||||
|         overwrite: true | ||||
|     - name: Clean up test-results | ||||
|       if: always() | ||||
|       continue-on-error: true | ||||
|       run: rm -r test-results | ||||
|     - name: check for changes | ||||
|       id: git-check | ||||
|       run: | | ||||
|           git add . | ||||
|           if git status | grep -q "Changes to be committed" | ||||
|           then | ||||
|             echo "::set-output name=modified::true" | ||||
|           else | ||||
|             echo "::set-output name=modified::false" | ||||
|           then echo "modified=true" >> $GITHUB_OUTPUT | ||||
|           else echo "modified=false" >> $GITHUB_OUTPUT | ||||
|           fi | ||||
|     - name: Commit changes, if any | ||||
|       if: steps.git-check.outputs.modified == 'true' | ||||
| @ -119,23 +150,101 @@ jobs: | ||||
|         git commit -am "A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu)" || true | ||||
|         git push | ||||
|         git push origin ${{ github.head_ref }} | ||||
|     - name: Run ubuntu/chrome flow | ||||
|       run: yarn playwright test --project="Google Chrome" e2e/playwright/flow-tests.spec.ts | ||||
|     # only upload artifacts if there's actually changes | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: steps.git-check.outputs.modified == 'true' | ||||
|       with: | ||||
|         name: playwright-report-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: playwright-report/ | ||||
|         retention-days: 30 | ||||
|     # if have previous run results, use them | ||||
|     - uses: actions/download-artifact@v4 | ||||
|       if: always() | ||||
|       continue-on-error: true | ||||
|       with: | ||||
|         name: test-results-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: test-results/ | ||||
|     - name: Run ubuntu/chrome flow (with retries) | ||||
|       id: retry | ||||
|       if: always() | ||||
|       run: | | ||||
|         if [[ ! -f "test-results/.last-run.json" ]]; then | ||||
|             # if no last run artifact, than run plawright normally | ||||
|             echo "run playwright normally" | ||||
|             yarn playwright test --project="Google Chrome" --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} --grep-invert=@snapshot || true | ||||
|             # # send to axiom | ||||
|             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|         fi | ||||
|  | ||||
|         retry=1 | ||||
|         max_retrys=4 | ||||
|  | ||||
|         # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||
|         while [[ $retry -le $max_retrys ]]; do | ||||
|             if [[ -f "test-results/.last-run.json" ]]; then | ||||
|                 failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|                 if [[ $failed_tests -gt 0 ]]; then | ||||
|                     echo "retried=true" >>$GITHUB_OUTPUT | ||||
|                     echo "run playwright with last failed tests and retry $retry" | ||||
|                     yarn playwright test --project="Google Chrome" --last-failed --grep-invert=@snapshot || true | ||||
|                     # send to axiom | ||||
|                     node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|                     retry=$((retry + 1)) | ||||
|                 else | ||||
|                     echo "retried=false" >>$GITHUB_OUTPUT | ||||
|                     exit 0 | ||||
|                 fi | ||||
|             else | ||||
|                 echo "retried=false" >>$GITHUB_OUTPUT | ||||
|                 exit 0 | ||||
|             fi | ||||
|         done | ||||
|  | ||||
|         echo "retried=false" >>$GITHUB_OUTPUT | ||||
|  | ||||
|         if [[ -f "test-results/.last-run.json" ]]; then | ||||
|             failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|             if [[ $failed_tests -gt 0 ]]; then | ||||
|                 # if it still fails after 3 retrys, then fail the job | ||||
|                 exit 1 | ||||
|             fi | ||||
|         fi | ||||
|         exit 0 | ||||
|       env: | ||||
|         CI: true | ||||
|         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|     - uses: actions/upload-artifact@v3 | ||||
|     - name: send to axiom | ||||
|       if: always() | ||||
|       shell: bash | ||||
|       run: | | ||||
|         node playwrightProcess.mjs | tee /tmp/github-actions.log | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: always() | ||||
|       with: | ||||
|         name: playwright-report | ||||
|         name: test-results-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: test-results/ | ||||
|         retention-days: 30 | ||||
|         overwrite: true | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: always() | ||||
|       with: | ||||
|         name: playwright-report-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: playwright-report/ | ||||
|         retention-days: 30 | ||||
|         overwrite: true | ||||
|  | ||||
|   playwright-macos: | ||||
|     timeout-minutes: 60 | ||||
|     timeout-minutes: 30 | ||||
|     runs-on: macos-14 | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         shardIndex: [1, 2, 3, 4] | ||||
|         shardTotal: [4] | ||||
|     needs: check-rust-changes | ||||
|     steps: | ||||
|     - name: Tune GitHub-hosted runner network | ||||
|       uses: smorimoto/tune-github-hosted-runner-network@v1 | ||||
|     - uses: actions/checkout@v4 | ||||
|     - uses: actions/setup-node@v4 | ||||
|       with: | ||||
| @ -143,12 +252,20 @@ jobs: | ||||
|         cache: 'yarn' | ||||
|     - name: Install dependencies | ||||
|       run: yarn | ||||
|     - name: Cache Playwright Browsers | ||||
|       uses: actions/cache@v4 | ||||
|       with: | ||||
|         path: | | ||||
|           ~/.cache/ms-playwright | ||||
|         key: ${{ runner.os }}-playwright-${{ hashFiles('**/package-lock.json') }} | ||||
|         restore-keys: | | ||||
|           ${{ runner.os }}-playwright- | ||||
|     - name: Install Playwright Browsers | ||||
|       run: yarn playwright install --with-deps | ||||
|     - name: Download Wasm Cache | ||||
|       id: download-wasm | ||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||
|       uses: dawidd6/action-download-artifact@v3 | ||||
|       uses: dawidd6/action-download-artifact@v6 | ||||
|       continue-on-error: true | ||||
|       with: | ||||
|         github_token: ${{secrets.GITHUB_TOKEN}} | ||||
| @ -172,6 +289,20 @@ jobs: | ||||
|       uses: Swatinem/rust-cache@v2 | ||||
|       with: | ||||
|         workspaces: './src/wasm-lib' | ||||
|     - name: Install vector | ||||
|       run: | | ||||
|         curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | ||||
|         chmod +x /tmp/vector.sh | ||||
|         /tmp/vector.sh -y -no-modify-path | ||||
|         mkdir -p /tmp/vector | ||||
|         cp .github/workflows/vector.toml /tmp/vector.toml | ||||
|         sed -i "" "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | ||||
|         sed -i "" "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | ||||
|         sed -i "" "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | ||||
|         sed -i "" "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | ||||
|         sed -i "" "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | ||||
|         cat /tmp/vector.toml | ||||
|         ${HOME}/.vector/bin/vector --config /tmp/vector.toml & | ||||
|     - name: Build Wasm (because rust diff) | ||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||
|       run: yarn build:wasm | ||||
| @ -180,16 +311,73 @@ jobs: | ||||
|       run: yarn build:wasm | ||||
|     - name: build web | ||||
|       run: yarn build:local | ||||
|     - name: Run macos/safari flow | ||||
|       # webkit doesn't work on Ubuntu because of the same reason tauri doesn't (webRTC issues) | ||||
|       # TODO remove this and the matrix and run all tests on ubuntu when this is fixed | ||||
|       run: yarn playwright test --project="webkit" e2e/playwright/flow-tests.spec.ts | ||||
|     # if have previous run results, use them | ||||
|     - uses: actions/download-artifact@v4 | ||||
|       if: ${{ always() }} | ||||
|       continue-on-error: true | ||||
|       with: | ||||
|         name: test-results-macos-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: test-results/ | ||||
|     - name: Run macos/safari flow (with retries) | ||||
|       id: retry | ||||
|       if: always() | ||||
|       run: | | ||||
|         if [[ ! -f "test-results/.last-run.json" ]]; then | ||||
|             # if no last run artifact, than run plawright normally | ||||
|             echo "run playwright normally" | ||||
|             yarn playwright test --project="webkit" --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} --grep-invert=@snapshot || true | ||||
|             # # send to axiom | ||||
|             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|         fi | ||||
|  | ||||
|         retry=1 | ||||
|         max_retrys=4 | ||||
|  | ||||
|         # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||
|         while [[ $retry -le $max_retrys ]]; do | ||||
|             if [[ -f "test-results/.last-run.json" ]]; then | ||||
|                 failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|                 if [[ $failed_tests -gt 0 ]]; then | ||||
|                     echo "retried=true" >>$GITHUB_OUTPUT | ||||
|                     echo "run playwright with last failed tests and retry $retry" | ||||
|                     yarn playwright test --project="webkit" --last-failed --grep-invert=@snapshot || true | ||||
|                     # send to axiom | ||||
|                     node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|                     retry=$((retry + 1)) | ||||
|                 else | ||||
|                     echo "retried=false" >>$GITHUB_OUTPUT | ||||
|                     exit 0 | ||||
|                 fi | ||||
|             else | ||||
|                 echo "retried=false" >>$GITHUB_OUTPUT | ||||
|                 exit 0 | ||||
|             fi | ||||
|         done | ||||
|  | ||||
|         echo "retried=false" >>$GITHUB_OUTPUT | ||||
|  | ||||
|         if [[ -f "test-results/.last-run.json" ]]; then | ||||
|             failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|             if [[ $failed_tests -gt 0 ]]; then | ||||
|                 # if it still fails after 3 retrys, then fail the job | ||||
|                 exit 1 | ||||
|             fi | ||||
|         fi | ||||
|         exit 0 | ||||
|       env: | ||||
|         CI: true | ||||
|         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|     - uses: actions/upload-artifact@v3 | ||||
|       if: always() | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: ${{ always() }} | ||||
|       with: | ||||
|         name: playwright-report | ||||
|         name: test-results-macos-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: test-results/ | ||||
|         retention-days: 30 | ||||
|         overwrite: true | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: ${{ always() }} | ||||
|       with: | ||||
|         name: playwright-report-macos-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|         path: playwright-report/ | ||||
|         retention-days: 30 | ||||
|         overwrite: true | ||||
|  | ||||
							
								
								
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -17,6 +17,7 @@ | ||||
| .env.development.local | ||||
| .env.test.local | ||||
| .env.production.local | ||||
| .direnv | ||||
|  | ||||
| npm-debug.log* | ||||
| yarn-debug.log* | ||||
| @ -38,6 +39,7 @@ src/wasm-lib/grackle/test_json_output | ||||
| e2e/playwright/playwright-secrets.env | ||||
| e2e/playwright/temp1.png | ||||
| e2e/playwright/temp2.png | ||||
| e2e/playwright/temp3.png | ||||
| # exports from snapshot-tests.spec.ts "exports of each format should work" | ||||
| e2e/playwright/export-snapshots/* | ||||
| !e2e/playwright/export-snapshots/*.png | ||||
| @ -47,6 +49,7 @@ e2e/playwright/export-snapshots/* | ||||
| /playwright-report/ | ||||
| /blob-report/ | ||||
| /playwright/.cache/ | ||||
| /src/lang/std/artifactMapCache | ||||
|  | ||||
|  | ||||
| ## generated files | ||||
| @ -55,3 +58,7 @@ src-tauri/gen | ||||
|  | ||||
| src/wasm-lib/grackle/stdlib_cube_partial.json | ||||
| Mac_App_Distribution.provisionprofile | ||||
|  | ||||
| *.tsbuildinfo | ||||
|  | ||||
| venv | ||||
|  | ||||
| @ -1,5 +1,6 @@ | ||||
| # Ignore artifacts: | ||||
| build | ||||
| dist | ||||
| coverage | ||||
|  | ||||
| # Ignore Rust projects: | ||||
| @ -9,5 +10,6 @@ src/wasm-lib/pkg | ||||
| src/wasm-lib/kcl/bindings | ||||
| e2e/playwright/export-snapshots | ||||
|  | ||||
|  | ||||
| # XState generated files | ||||
| src/machines/**.typegen.ts | ||||
|  | ||||
							
								
								
									
										7
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @ -1,7 +0,0 @@ | ||||
| { | ||||
|     "cSpell.words": [ | ||||
|         "geos" | ||||
|     ], | ||||
|     "editor.tabSize": 2, | ||||
|     "editor.insertSpaces": true, | ||||
| } | ||||
							
								
								
									
										17
									
								
								Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								Makefile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| .PHONY: dev | ||||
|  | ||||
| WASM_LIB_FILES := $(wildcard src/wasm-lib/**/*.rs) | ||||
| TS_SRC := $(wildcard src/**/*.tsx) $(wildcard src/**/*.ts) | ||||
| XSTATE_TYPEGENS := $(wildcard src/machines/*.typegen.ts) | ||||
|  | ||||
| dev: node_modules public/wasm_lib_bg.wasm $(XSTATE_TYPEGENS) | ||||
| 	yarn start | ||||
|  | ||||
| $(XSTATE_TYPEGENS): $(TS_SRC) | ||||
| 	yarn xstate typegen 'src/**/*.ts?(x)' | ||||
|  | ||||
| public/wasm_lib_bg.wasm: $(WASM_LIB_FILES) | ||||
| 	yarn build:wasm-dev | ||||
|  | ||||
| node_modules: package.json yarn.lock | ||||
| 	yarn install | ||||
							
								
								
									
										168
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										168
									
								
								README.md
									
									
									
									
									
								
							| @ -89,25 +89,6 @@ enable third-party cookies. You can enable third-party cookies by clicking on | ||||
| the eye with a slash through it in the URL bar, and clicking on "Enable | ||||
| Third-Party Cookies". | ||||
|  | ||||
| ## Running tests | ||||
|  | ||||
| First, start the dev server following "Running a development build" above. | ||||
|  | ||||
| Then in another terminal tab, run: | ||||
|  | ||||
| ``` | ||||
| yarn test | ||||
| ``` | ||||
|  | ||||
| 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. | ||||
|  | ||||
| For running the rust (not tauri rust though) only, you can | ||||
|  | ||||
| ```bash | ||||
| cd src/wasm-lib | ||||
| cargo test | ||||
| ``` | ||||
|  | ||||
| ## Tauri | ||||
|  | ||||
| To spin up up tauri dev, `yarn install` and `yarn build:wasm-dev` need to have been done before hand then | ||||
| @ -129,6 +110,17 @@ Note that these became separate apps on Macos, so make sure you open the right o | ||||
|  | ||||
| <img width="1232" alt="image (1)" src="https://user-images.githubusercontent.com/29681384/211947073-e76b4933-bef5-4636-bc4d-e930ac8e290f.png"> | ||||
|  | ||||
| ## Checking out commits / Bisecting | ||||
|  | ||||
| Which commands from setup are one off vs need to be run every time? | ||||
|  | ||||
| The following will need to be run when checking out a new commit and guarantees the build is not stale: | ||||
| ```bash | ||||
| yarn install | ||||
| yarn build:wasm-dev # or yarn build:wasm for slower but more production-like build | ||||
| yarn start # or yarn build:local && yarn serve for slower but more production-like build | ||||
| ``` | ||||
|  | ||||
| ## Before submitting a PR | ||||
|  | ||||
| Before you submit a contribution PR to this repo, please ensure that: | ||||
| @ -143,36 +135,40 @@ Before you submit a contribution PR to this repo, please ensure that: | ||||
|  | ||||
| ## Release a new version | ||||
|  | ||||
| 1. Bump the versions in the .json files by creating a `Cut release v{x}.{y}.{z}` PR, committing the changes from | ||||
| #### 1. Bump the versions by running `./make-release.sh` and create a Cut Release PR | ||||
|  | ||||
| ```bash | ||||
| VERSION=x.y.z yarn run bump-jsons | ||||
| ``` | ||||
| That will create the branch with the updated json files for you: | ||||
| - run `./make-release.sh` or `./make-release.sh patch` for a patch update; | ||||
| - run `./make-release.sh minor` for minor; or | ||||
| - run `./make-release.sh major` for major. | ||||
|  | ||||
| Alternatively you can try the experimental `make-release.sh` bash script that will create the branch with the updated json files for you. | ||||
| run `./make-release.sh` for a patch update | ||||
| run `./make-release.sh "minor"` for minor | ||||
| run `./make-release.sh "major"` for major | ||||
| After it runs you should just need the push the branch and open a PR. | ||||
|  | ||||
| The PR may serve as a place to discuss the human-readable changelog and extra QA. A quick way of getting PR's merged since the last bump is to [use this PR filter](https://github.com/KittyCAD/modeling-app/pulls?q=is%3Apr+sort%3Aupdated-desc+is%3Amerged+), open up the browser console and paste in the following | ||||
| **Important:** It needs to be prefixed with `Cut release v` to build in release mode and a few other things to test in the best context possible, the intent would be for instance to have `Cut release v1.2.3` for the `v1.2.3` release candidate. | ||||
|  | ||||
| ```typescript | ||||
| console.log( | ||||
|   '- ' + | ||||
|     Array.from( | ||||
|       document.querySelectorAll('[data-hovercard-type="pull_request"]') | ||||
|     ).map((a) => `[${a.innerText}](${a.href})`).join(` | ||||
| - `) | ||||
| ) | ||||
| ``` | ||||
| The PR may then serve as a place to discuss the human-readable changelog and extra QA. The `make-release.sh` tool suggests a changelog for you too to be used as PR description, just make sure to delete lines that are not user facing. | ||||
|  | ||||
| grab the md list and delete any that are older than the last bump | ||||
| #### 2. Smoke test artifacts from the Cut Release PR | ||||
|  | ||||
| 2. Merge the PR | ||||
| The release builds can be find under the `artifact` zip, at the very bottom of the `ci` action page for each commit on this branch. | ||||
|  | ||||
| 3. Create a new release and tag pointing to the bump version commit using semantic versioning `v{x}.{y}.{z}` | ||||
| We don't have a strict process, but click around and check for anything obvious, posting results as comments in the Cut Release PR. | ||||
|  | ||||
| The other `ci` output in Cut Release PRs is `updater-test`, because we don't have a way to test this fully automated, we have a semi-automated process. Download updater-test zip file, install the app, run it, expect an updater prompt to a dummy v0.99.99, install it and check that the app comes back at that version (on both macOS and Windows). | ||||
|  | ||||
| #### 3. Merge the Cut Release PR | ||||
|  | ||||
| This will kick the `create-release` action, that creates a _Draft_ release out of this Cut Release PR merge after less than a minute, with the new version as title and Cut Release PR as description. | ||||
|  | ||||
|  | ||||
| #### 4. Publish the release | ||||
|  | ||||
| Head over to https://github.com/KittyCAD/modeling-app/releases, the draft release corresponding to the merged Cut Release PR should show up at the top as _Draft_. Click on it, verify the content, and hit _Publish_. | ||||
|  | ||||
| #### 5. Profit | ||||
|  | ||||
| A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, which can be found under `release` event filter. | ||||
|  | ||||
| 4. A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, uploading artifacts to the release | ||||
|  | ||||
| ## Fuzzing the parser | ||||
|  | ||||
| @ -195,30 +191,36 @@ $ cargo +nightly fuzz run parser | ||||
| For more information on fuzzing you can check out | ||||
| [this guide](https://rust-fuzz.github.io/book/cargo-fuzz.html). | ||||
|  | ||||
| ### Playwright | ||||
| ## Tests | ||||
|  | ||||
| First time running plawright locally, you'll need to add the secrets file | ||||
| ### Playwright tests | ||||
|  | ||||
| For a portable way to run Playwright you'll need Docker. | ||||
|  | ||||
| After that, open a terminal and run: | ||||
|  | ||||
| ```bash | ||||
| touch ./e2e/playwright/playwright-secrets.env | ||||
| printf 'token="your-token"\nsnapshottoken="your-snapshot-token"' > ./e2e/playwright/playwright-secrets.env | ||||
| docker run --network host  --rm --init -it playwright/chrome:playwright-1.43.1 | ||||
| ``` | ||||
|  | ||||
| and in another terminal, run: | ||||
|  | ||||
| ```bash | ||||
| PW_TEST_CONNECT_WS_ENDPOINT=ws://127.0.0.1:4444/ yarn playwright test --project="Google Chrome" <test suite> | ||||
| ``` | ||||
|  | ||||
| An example of a `<test suite>` is: `e2e/playwright/flow-tests.spec.ts` | ||||
|  | ||||
| YOU WILL NEED A PLAYWRIGHT-SECRETS.ENV FILE: | ||||
|  | ||||
|  | ||||
| ```bash | ||||
| # ./e2e/playwright/playwright-secrets.env | ||||
| token=<your-token> | ||||
| snapshottoken=<your-snapshot-token> | ||||
| ``` | ||||
| then replace "your-token" with a dev token from dev.zoo.dev/account/api-tokens | ||||
|  | ||||
| then: | ||||
| run playwright | ||||
|  | ||||
| ``` | ||||
| yarn playwright test | ||||
| ``` | ||||
|  | ||||
| run a specific test suite | ||||
|  | ||||
| ``` | ||||
| yarn playwright test src/e2e-tests/example.spec.ts | ||||
| ``` | ||||
|  | ||||
| run a specific test change the test from `test('...` to `test.only('...` | ||||
| (note if you commit this, the tests will instantly fail without running any of the tests) | ||||
|  | ||||
| @ -280,6 +282,37 @@ Where `./store` should look like this | ||||
|  | ||||
| However because much of our tests involve clicking in the stream at specific locations, it's code-gen looks `await page.locator('video').click();` when really we need to use a pixel coord, so I think it's of limited use. | ||||
|  | ||||
| ### Unit and component tests | ||||
|  | ||||
| If you already haven't, run the following: | ||||
|  | ||||
| ``` | ||||
| yarn | ||||
| yarn build:wasm | ||||
| yarn start | ||||
| ``` | ||||
|  | ||||
| and finally: | ||||
|  | ||||
| ``` | ||||
| yarn test:nowatch | ||||
| ``` | ||||
|  | ||||
| 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. | ||||
|  | ||||
| ### Rust tests | ||||
|  | ||||
| ```bash | ||||
| cd src/wasm-lib | ||||
| cargo test | ||||
| ``` | ||||
|  | ||||
| #### Some notes on CI | ||||
|  | ||||
| The tests are broken into snapshot tests and non-snapshot tests, and they run in that order, they automatically commit new snap shots, so if you see an image commit check it was an intended change. If we have non-determinism in the snapshots such that they are always committing new images, hopefully this annoyance makes us fix them asap, if you notice this happening let Kurt know. But for the odd occasion `git reset --hard HEAD~ && git push -f` is your friend. | ||||
| @ -309,6 +342,25 @@ PS: for the debug panel, the following JSON is useful for snapping the camera | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Tauri e2e tests | ||||
|  | ||||
| #### Windows (local only until the CI edge version mismatch is fixed) | ||||
|  | ||||
| ``` | ||||
| yarn install | ||||
| yarn build:wasm-dev | ||||
| cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||
| yarn vite build --mode development | ||||
| yarn tauri build --debug -b | ||||
| $env:KITTYCAD_API_TOKEN="<YOUR_KITTYCAD_API_TOKEN>" | ||||
| $env:VITE_KC_API_BASE_URL="https://api.dev.zoo.dev" | ||||
| $env:E2E_TAURI_ENABLED="true" | ||||
| $env:TS_NODE_COMPILER_OPTIONS='{"module": "commonjs"}' | ||||
| $env:E2E_APPLICATION=".\src-tauri\target\debug\Zoo Modeling App.exe" | ||||
| Stop-Process -Name msedgedriver | ||||
| yarn wdio run wdio.conf.ts | ||||
| ``` | ||||
|  | ||||
| ## KCL | ||||
|  | ||||
| For how to contribute to KCL, [see our KCL README](https://github.com/KittyCAD/modeling-app/tree/main/src/wasm-lib/kcl). | ||||
|  | ||||
| @ -17,4 +17,13 @@ once fixed in engine will just start working here with no language changes. | ||||
|     currently move or transform the imported objects at all, once we have assemblies | ||||
|     this will work. | ||||
|  | ||||
| - **Fillets**: Fillets cannot intersect, you will get an error. Only simple fillet cases work currently. | ||||
| - **Fillets**: Fillets cannot intersect, you will get an error. Only simple fillet | ||||
|     cases work currently. | ||||
|  | ||||
| - **Chamfers**: Chamfers cannot intersect, you will get an error. Only simple | ||||
|     chamfer cases work currently. | ||||
|  | ||||
|     Sketching on the chamfered face does not currently work. | ||||
|  | ||||
| - **Shell**: Shell is only working for `end` faces, not for `side` or `start`  | ||||
|     faces. We are tracking the engine side bug on this. | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "acos" | ||||
| excerpt: "Computes the arccosine of a number (in radians)." | ||||
| excerpt: "Compute the arccosine of a number (in radians)." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Computes the arccosine of a number (in radians). | ||||
| Compute the arccosine of a number (in radians). | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										682
									
								
								docs/kcl/arc.md
									
									
									
									
									
								
							
							
						
						
									
										682
									
								
								docs/kcl/arc.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										34
									
								
								docs/kcl/assert.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								docs/kcl/assert.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										37
									
								
								docs/kcl/assertEqual.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								docs/kcl/assertEqual.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										34
									
								
								docs/kcl/assertGreaterThan.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								docs/kcl/assertGreaterThan.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										35
									
								
								docs/kcl/assertGreaterThanOrEq.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								docs/kcl/assertGreaterThanOrEq.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										34
									
								
								docs/kcl/assertLessThan.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								docs/kcl/assertLessThan.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										35
									
								
								docs/kcl/assertLessThanOrEq.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								docs/kcl/assertLessThanOrEq.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										942
									
								
								docs/kcl/chamfer.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										942
									
								
								docs/kcl/chamfer.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										986
									
								
								docs/kcl/hole.md
									
									
									
									
									
								
							
							
						
						
									
										986
									
								
								docs/kcl/hole.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -20,9 +20,16 @@ layout: manual | ||||
| * [`angledLineToY`](kcl/angledLineToY) | ||||
| * [`arc`](kcl/arc) | ||||
| * [`asin`](kcl/asin) | ||||
| * [`assert`](kcl/assert) | ||||
| * [`assertEqual`](kcl/assertEqual) | ||||
| * [`assertGreaterThan`](kcl/assertGreaterThan) | ||||
| * [`assertGreaterThanOrEq`](kcl/assertGreaterThanOrEq) | ||||
| * [`assertLessThan`](kcl/assertLessThan) | ||||
| * [`assertLessThanOrEq`](kcl/assertLessThanOrEq) | ||||
| * [`atan`](kcl/atan) | ||||
| * [`bezierCurve`](kcl/bezierCurve) | ||||
| * [`ceil`](kcl/ceil) | ||||
| * [`chamfer`](kcl/chamfer) | ||||
| * [`circle`](kcl/circle) | ||||
| * [`close`](kcl/close) | ||||
| * [`cos`](kcl/cos) | ||||
| @ -30,13 +37,13 @@ layout: manual | ||||
| * [`extrude`](kcl/extrude) | ||||
| * [`fillet`](kcl/fillet) | ||||
| * [`floor`](kcl/floor) | ||||
| * [`getEdge`](kcl/getEdge) | ||||
| * [`getNextAdjacentEdge`](kcl/getNextAdjacentEdge) | ||||
| * [`getOppositeEdge`](kcl/getOppositeEdge) | ||||
| * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) | ||||
| * [`helix`](kcl/helix) | ||||
| * [`hole`](kcl/hole) | ||||
| * [`import`](kcl/import) | ||||
| * [`int`](kcl/int) | ||||
| * [`lastSegX`](kcl/lastSegX) | ||||
| * [`lastSegY`](kcl/lastSegY) | ||||
| * [`legAngX`](kcl/legAngX) | ||||
| @ -54,7 +61,9 @@ layout: manual | ||||
| * [`patternCircular3d`](kcl/patternCircular3d) | ||||
| * [`patternLinear2d`](kcl/patternLinear2d) | ||||
| * [`patternLinear3d`](kcl/patternLinear3d) | ||||
| * [`patternTransform`](kcl/patternTransform) | ||||
| * [`pi`](kcl/pi) | ||||
| * [`polar`](kcl/polar) | ||||
| * [`pow`](kcl/pow) | ||||
| * [`profileStart`](kcl/profileStart) | ||||
| * [`profileStartX`](kcl/profileStartX) | ||||
| @ -64,6 +73,7 @@ layout: manual | ||||
| * [`segEndX`](kcl/segEndX) | ||||
| * [`segEndY`](kcl/segEndY) | ||||
| * [`segLen`](kcl/segLen) | ||||
| * [`shell`](kcl/shell) | ||||
| * [`sin`](kcl/sin) | ||||
| * [`sqrt`](kcl/sqrt) | ||||
| * [`startProfileAt`](kcl/startProfileAt) | ||||
|  | ||||
							
								
								
									
										43
									
								
								docs/kcl/int.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								docs/kcl/int.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "legAngX" | ||||
| excerpt: "Returns the angle of the given leg for x." | ||||
| excerpt: "Compute the angle of the given leg for x." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Returns the angle of the given leg for x. | ||||
| Compute the angle of the given leg for x. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "legAngY" | ||||
| excerpt: "Returns the angle of the given leg for y." | ||||
| excerpt: "Compute the angle of the given leg for y." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Returns the angle of the given leg for y. | ||||
| Compute the angle of the given leg for y. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "legLen" | ||||
| excerpt: "Returns the length of the given leg." | ||||
| excerpt: "Compute the length of the given leg." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Returns the length of the given leg. | ||||
| Compute the length of the given leg. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										674
									
								
								docs/kcl/line.md
									
									
									
									
									
								
							
							
						
						
									
										674
									
								
								docs/kcl/line.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "log" | ||||
| excerpt: "Computes the logarithm of the number with respect to an arbitrary base." | ||||
| excerpt: "Compute the logarithm of the number with respect to an arbitrary base." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Computes the logarithm of the number with respect to an arbitrary base. | ||||
| Compute the logarithm of the number with respect to an arbitrary base. | ||||
|  | ||||
| The result might not be correctly rounded owing to implementation details; `log2()` can produce more accurate results for base 2, and `log10()` can produce more accurate results for base 10. | ||||
|  | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "log2" | ||||
| excerpt: "Computes the base 2 logarithm of the number." | ||||
| excerpt: "Compute the base 2 logarithm of the number." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Computes the base 2 logarithm of the number. | ||||
| Compute the base 2 logarithm of the number. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										452
									
								
								docs/kcl/patternTransform.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										452
									
								
								docs/kcl/patternTransform.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										48
									
								
								docs/kcl/polar.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								docs/kcl/polar.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,12 +1,12 @@ | ||||
| --- | ||||
| title: "profileStartX" | ||||
| excerpt: "" | ||||
| excerpt: "Extract the provided 2-dimensional sketch group's profile's origin's 'x'" | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Extract the provided 2-dimensional sketch group's profile's origin's 'x' | ||||
|  | ||||
|  | ||||
|  | ||||
| value. | ||||
|  | ||||
| ```js | ||||
| profileStartX(sketch_group: SketchGroup) -> number | ||||
| @ -29,9 +29,7 @@ const sketch001 = startSketchOn('XY') | ||||
| * `sketch_group`: `SketchGroup` - A sketch group is a collection of paths. (REQUIRED) | ||||
| ```js | ||||
| { | ||||
| 	// The plane id or face id of the sketch group. | ||||
| 	entityId: uuid, | ||||
| 	// The id of the sketch group. | ||||
| 	// The id of the sketch group (this will change when the engine's reference to it changes. | ||||
| 	id: uuid, | ||||
| 	// What the sketch is on (can be a plane or a face). | ||||
| 	on: { | ||||
| @ -66,12 +64,236 @@ const sketch001 = startSketchOn('XY') | ||||
| }, | ||||
| } | | ||||
| { | ||||
| 	// the face id the sketch is on | ||||
| 	// The extrude group the face is on. | ||||
| 	extrudeGroup: { | ||||
| 	// The id of the extrusion end cap | ||||
| 	endCapId: uuid, | ||||
| 	// Chamfers or fillets on this extrude group. | ||||
| 	filletOrChamfers: [{ | ||||
| 	// The engine id of the edge to fillet. | ||||
| 	edgeId: uuid, | ||||
| 	// The id of the engine command that called this fillet. | ||||
| 	id: uuid, | ||||
| 	radius: number, | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "fillet", | ||||
| } | | ||||
| { | ||||
| 	// The engine id of the edge to chamfer. | ||||
| 	edgeId: uuid, | ||||
| 	// The id of the engine command that called this chamfer. | ||||
| 	id: uuid, | ||||
| 	length: number, | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "chamfer", | ||||
| }], | ||||
| 	// The height of the extrude group. | ||||
| 	height: number, | ||||
| 	// The id of the extrude group. | ||||
| 	id: uuid, | ||||
| 	// The sketch group. | ||||
| 	sketchGroup: { | ||||
| 	// The id of the sketch group (this will change when the engine's reference to it changes. | ||||
| 	id: uuid, | ||||
| 	// What the sketch is on (can be a plane or a face). | ||||
| 	on: SketchSurface, | ||||
| 	// The starting path. | ||||
| 	start: { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| }, | ||||
| 	// Tag identifiers that have been declared in this sketch group. | ||||
| 	tags: { | ||||
| }, | ||||
| 	// The paths in the sketch group. | ||||
| 	value: [{ | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "ToPoint", | ||||
| } | | ||||
| { | ||||
| 	// arc's direction | ||||
| 	ccw: string, | ||||
| 	// the arc's center | ||||
| 	center: [number, number], | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "TangentialArcTo", | ||||
| } | | ||||
| { | ||||
| 	// arc's direction | ||||
| 	ccw: string, | ||||
| 	// the arc's center | ||||
| 	center: [number, number], | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "TangentialArc", | ||||
| } | | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "Horizontal", | ||||
| 	// The x coordinate. | ||||
| 	x: number, | ||||
| } | | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "AngledLineTo", | ||||
| 	// The x coordinate. | ||||
| 	x: number, | ||||
| 	// The y coordinate. | ||||
| 	y: number, | ||||
| } | | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "Base", | ||||
| }], | ||||
| }, | ||||
| 	// The id of the extrusion start cap | ||||
| 	startCapId: uuid, | ||||
| 	// The extrude surfaces. | ||||
| 	value: [{ | ||||
| 	// The face id for the extrude plane. | ||||
| 	faceId: uuid, | ||||
| 	// The id of the geometry. | ||||
| 	id: uuid, | ||||
| 	// The source range. | ||||
| 	sourceRange: [number, number], | ||||
| 	// The tag. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "extrudePlane", | ||||
| } | | ||||
| { | ||||
| 	// The face id for the extrude plane. | ||||
| 	faceId: uuid, | ||||
| 	// The id of the geometry. | ||||
| 	id: uuid, | ||||
| 	// The source range. | ||||
| 	sourceRange: [number, number], | ||||
| 	// The tag. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "extrudeArc", | ||||
| } | | ||||
| { | ||||
| 	// The id for the chamfer surface. | ||||
| 	faceId: uuid, | ||||
| 	// The id of the geometry. | ||||
| 	id: uuid, | ||||
| 	// The source range. | ||||
| 	sourceRange: [number, number], | ||||
| 	// The tag. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "chamfer", | ||||
| } | | ||||
| { | ||||
| 	// The id for the fillet surface. | ||||
| 	faceId: uuid, | ||||
| 	// The id of the geometry. | ||||
| 	id: uuid, | ||||
| 	// The source range. | ||||
| 	sourceRange: [number, number], | ||||
| 	// The tag. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	type: "fillet", | ||||
| }], | ||||
| }, | ||||
| 	// The id of the face. | ||||
| 	id: uuid, | ||||
| 	// The original sketch group id of the object we are sketching on. | ||||
| 	sketchGroupId: uuid, | ||||
| 	type: "face", | ||||
| 	// The tag of the face. | ||||
| 	value: string, | ||||
| @ -94,25 +316,34 @@ const sketch001 = startSketchOn('XY') | ||||
| 	z: number, | ||||
| }, | ||||
| }, | ||||
| 	// The position of the sketch group. | ||||
| 	position: [number, number, number], | ||||
| 	// The rotation of the sketch group base plane. | ||||
| 	rotation: [number, number, number, number], | ||||
| 	// The starting path. | ||||
| 	start: { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| }, | ||||
| 	// Tag identifiers that have been declared in this sketch group. | ||||
| 	tags: { | ||||
| }, | ||||
| 	// The paths in the sketch group. | ||||
| 	value: [{ | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "ToPoint", | ||||
| @ -124,17 +355,31 @@ const sketch001 = startSketchOn('XY') | ||||
| 	center: [number, number], | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "TangentialArcTo", | ||||
| } | | ||||
| { | ||||
| 	// arc's direction | ||||
| 	ccw: string, | ||||
| 	// the arc's center | ||||
| 	center: [number, number], | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "TangentialArc", | ||||
| @ -142,8 +387,13 @@ const sketch001 = startSketchOn('XY') | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "Horizontal", | ||||
| @ -153,8 +403,13 @@ const sketch001 = startSketchOn('XY') | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "AngledLineTo", | ||||
| @ -166,30 +421,17 @@ const sketch001 = startSketchOn('XY') | ||||
| { | ||||
| 	// The from point. | ||||
| 	from: [number, number], | ||||
| 	// The name of the path. | ||||
| 	name: string, | ||||
| 	// The tag of the path. | ||||
| 	tag: { | ||||
| 	digest: [number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number], | ||||
| 	end: number, | ||||
| 	start: number, | ||||
| 	value: string, | ||||
| }, | ||||
| 	// The to point. | ||||
| 	to: [number, number], | ||||
| 	type: "Base", | ||||
| }], | ||||
| 	// The x-axis of the sketch group base plane in the 3D space | ||||
| 	xAxis: { | ||||
| 	x: number, | ||||
| 	y: number, | ||||
| 	z: number, | ||||
| }, | ||||
| 	// The y-axis of the sketch group base plane in the 3D space | ||||
| 	yAxis: { | ||||
| 	x: number, | ||||
| 	y: number, | ||||
| 	z: number, | ||||
| }, | ||||
| 	// The z-axis of the sketch group base plane in the 3D space | ||||
| 	zAxis: { | ||||
| 	x: number, | ||||
| 	y: number, | ||||
| 	z: number, | ||||
| }, | ||||
| } | ||||
| ``` | ||||
|  | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										921
									
								
								docs/kcl/shell.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										921
									
								
								docs/kcl/shell.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										225342
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
							
						
						
									
										225342
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -74,6 +74,107 @@ You can nest expressions in parenthesis as well: | ||||
| let myMathExpression = 3 + (1 * 2 / (3 - 7)) | ||||
| ``` | ||||
|  | ||||
| Please if you find any issues using any of the above expressions or syntax | ||||
| ## Tags | ||||
|  | ||||
| Tags are used to give a name (tag) to a specific path. | ||||
|  | ||||
| ### Tag Declaration | ||||
|  | ||||
| The syntax for declaring a tag is `$myTag` you would use it in the following | ||||
| way: | ||||
|  | ||||
| ``` | ||||
| startSketchOn('XZ') | ||||
|   |> startProfileAt(origin, %) | ||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %) - 90, | ||||
|        196.99 | ||||
|      ], %, $rectangleSegmentB001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %), | ||||
|        -segLen(rectangleSegmentA001, %) | ||||
|      ], %, $rectangleSegmentC001) | ||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||
|   |> close(%) | ||||
| ``` | ||||
|  | ||||
| ### Tag Identifier | ||||
|  | ||||
| As per the example above you can use the tag identifier to get a reference to the  | ||||
| tagged object. The syntax for this is `myTag`. | ||||
|  | ||||
| In the example above we use the tag identifier to get the angle of the segment | ||||
| `segAng(rectangleSegmentA001, %)`. | ||||
|  | ||||
|  | ||||
| ### Tag Scope | ||||
|  | ||||
| Tags are scoped globally if in the root context meaning in this example you can  | ||||
| use the tag `rectangleSegmentA001` in any function or expression in the file. | ||||
|  | ||||
| However if the code was written like this: | ||||
|  | ||||
| ``` | ||||
| fn rect = (origin) => { | ||||
|   return startSketchOn('XZ') | ||||
|   |> startProfileAt(origin, %) | ||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %) - 90, | ||||
|        196.99 | ||||
|      ], %, $rectangleSegmentB001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %), | ||||
|        -segLen(rectangleSegmentA001, %) | ||||
|      ], %, $rectangleSegmentC001) | ||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||
|   |> close(%) | ||||
| } | ||||
|  | ||||
| rect([0, 0]) | ||||
| rect([20, 0]) | ||||
| ```  | ||||
|  | ||||
| Those tags would only be available in the `rect` function and not globally. | ||||
|  | ||||
| However you likely want to use those tags somewhere outside the `rect` function. | ||||
|  | ||||
| Tags are accessible through the sketch group they are declared in. | ||||
| For example the following code works. | ||||
|  | ||||
| ``` | ||||
| fn rect = (origin) => { | ||||
|   return startSketchOn('XZ') | ||||
|   |> startProfileAt(origin, %) | ||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %) - 90, | ||||
|        196.99 | ||||
|      ], %, $rectangleSegmentB001) | ||||
|   |> angledLine([ | ||||
|        segAng(rectangleSegmentA001, %), | ||||
|        -segLen(rectangleSegmentA001, %) | ||||
|      ], %, $rectangleSegmentC001) | ||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||
|   |> close(%) | ||||
| } | ||||
|  | ||||
| rect([0, 0]) | ||||
| const myRect = rect([20, 0]) | ||||
|  | ||||
| myRect  | ||||
|   |> extrude(10, %) | ||||
|   |> fillet({radius: 0.5, tags: [myRect.tags.rectangleSegmentA001]}, %) | ||||
| ``` | ||||
|  | ||||
| See how we use the tag `rectangleSegmentA001` in the `fillet` function outside | ||||
| the `rect` function. This is because the `rect` function is returning the | ||||
| sketch group that contains the tags. | ||||
|  | ||||
|  | ||||
| --- | ||||
|  | ||||
| If you find any issues using any of the above expressions or syntax, | ||||
| please file an issue with the `ast` label on the [modeling-app | ||||
| repo](https://github.com/KittyCAD/modeling-app/issues/new). | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	![dependabot[bot]](/assets/img/avatar_default.png)