Compare commits
	
		
			470 Commits
		
	
	
		
			franknoiro
			...
			franknoiro
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 176774295e | |||
| 7e64054a8c | |||
| 1b02104614 | |||
| 66d0556389 | |||
| d5d8322ae6 | |||
| 938eb749ad | |||
| 6d4127f0ef | |||
| d592794ce3 | |||
| 2a6904d37c | |||
| de33a3a854 | |||
| 4f4c44e7c7 | |||
| 1b75020686 | |||
| fba62dab98 | |||
| a85a534d6b | |||
| 6ddbb7a31d | |||
| 051bb0589e | |||
| 7f9851ae28 | |||
| fbcbb341e2 | |||
| 4a080d1583 | |||
| 85c721fb49 | |||
| 27af2d08a3 | |||
| fb8b975b5e | |||
| 62d8d45a58 | |||
| ae3440df0a | |||
| af658c909d | |||
| 7ec11d23c8 | |||
| 30000a1eac | |||
| cb3b45747c | |||
| fe66310f2d | |||
| fefb6cfe87 | |||
| 0f8375cbb4 | |||
| 107adc77b3 | |||
| 4356885aa2 | |||
| 6a2027cd51 | |||
| f49cf8281c | |||
| 7de27c648f | |||
| 344fb6f84d | |||
| df808b3e58 | |||
| e1ab6bbc48 | |||
| 0a1f35b89a | |||
| 78278d6889 | |||
| 6f1a539e83 | |||
| 0ad619e1d2 | |||
| 8d876a806e | |||
| c7f0a6c2a0 | |||
| e4941cb524 | |||
| 1b687a82a6 | |||
| 1bb882acf8 | |||
| 478bf34f2b | |||
| dbc87292e4 | |||
| bb3a74076f | |||
| 0cd6031aae | |||
| 1e1bdbd6e7 | |||
| 631b63b1b6 | |||
| eabcf86436 | |||
| 7ce0ef770a | |||
| 599ab33e40 | |||
| c584d942d4 | |||
| 35b8872678 | |||
| 2f245fe445 | |||
| 4b95980e9e | |||
| 53d6613d0d | |||
| 416d0b37a2 | |||
| 5f2a10ec7e | |||
| 24edb66b3c | |||
| 903ba33c46 | |||
| c5bf6ad42d | |||
| eeaa71142a | |||
| 0d1fc1b513 | |||
| d510e58ebc | |||
| 23a01e86e6 | |||
| 9dd6e3e852 | |||
| 9eaacc2a51 | |||
| de6e0f6b18 | |||
| d02a9f59ae | |||
| 92f930dfc0 | |||
| e651e0c2cf | |||
| 6358eed7e4 | |||
| fe581ff1d2 | |||
| b301fbba22 | |||
| 0c702e4bab | |||
| 25b9a34640 | |||
| b2152a5684 | |||
| 832bf77c92 | |||
| acb43fc82c | |||
| 7486d25cf1 | |||
| 1a4a030671 | |||
| 3049d939e1 | |||
| ad9822e8ac | |||
| aae34cf1e5 | |||
| d6278cf075 | |||
| 4159cc0047 | |||
| 3936017f10 | |||
| 2b0ced179a | |||
| c2f6ce065d | |||
| b3bdc35da2 | |||
| 8fe4f67a29 | |||
| c6b1d11700 | |||
| 2ef84382a6 | |||
| 939c2c77b0 | |||
| 31ec0184a1 | |||
| 62c4546658 | |||
| 383b38c2d2 | |||
| e0025f7fad | |||
| 2a13888c54 | |||
| 1443f3ab39 | |||
| bf87c23ea8 | |||
| 5d23b0e487 | |||
| df6c81b0b4 | |||
| 5f1f579d4b | |||
| 9a549ff379 | |||
| 851ea28bd3 | |||
| ff15c7b9db | |||
| f304577d5d | |||
| b03b0d3b53 | |||
| dd4d0f6d98 | |||
| 1cd742df5d | |||
| 6460ed8ea8 | |||
| 5c51b27f29 | |||
| 77690b4419 | |||
| 6996670020 | |||
| 1fd4e93091 | |||
| a1ac029333 | |||
| 29cf16d744 | |||
| 9b3afccf53 | |||
| 231ca0fa35 | |||
| 4608c02442 | |||
| de6184c622 | |||
| 0bce7d3c1c | |||
| c43ec280f2 | |||
| 8e6483a47b | |||
| e116bbaae8 | |||
| 18b458fbca | |||
| 4d1524f03b | |||
| 11d8179368 | |||
| 3c23cada8e | |||
| 81782b04ec | |||
| 9ade6676b7 | |||
| 86e5c37678 | |||
| 8c36d742e5 | |||
| f6a3a3d0cd | |||
| b5f81cb84a | |||
| 4bb17c192f | |||
| 51ce55e782 | |||
| 427d55d13e | |||
| 4575b32dbc | |||
| 9136fb0d1b | |||
| 33d5a9cdc1 | |||
| c25dfabc94 | |||
| 4502ad62b2 | |||
| 5235a731ba | |||
| 5ceb92d117 | |||
| ff92c73ac4 | |||
| bbb6fffbcc | |||
| 37fca0d1df | |||
| e3694e4781 | |||
| f97bdaf8b7 | |||
| 3f3693e12d | |||
| 73660d1db8 | |||
| c373f33507 | |||
| 2dc76a71cc | |||
| ce42966f2b | |||
| b47b9c9613 | |||
| 2af2144f89 | |||
| bd37c488ee | |||
| a3551e4b2f | |||
| d3979edb41 | |||
| 095a7a575b | |||
| b5c8ca05a5 | |||
| 33f7badf41 | |||
| 569935c21f | |||
| 7680605085 | |||
| 2bb6c74f42 | |||
| faf4d42b6a | |||
| 8dd2a86191 | |||
| 13c4de77c3 | |||
| e29ee9d1ca | |||
| b7437e949a | |||
| 08781ff010 | |||
| eb79b1f746 | |||
| 8df81b2753 | |||
| e75a604c64 | |||
| 0624e42822 | |||
| 1c07e8af5b | |||
| 5fccaad0e7 | |||
| a506f7f698 | |||
| 1bb96cd878 | |||
| b63b0e538a | |||
| 5118198cec | |||
| 1611244b94 | |||
| 227ad31fc2 | |||
| 80e3dc9095 | |||
| 46b6707e3a | |||
| 0eebb76bfd | |||
| 464372e7ed | |||
| 75dff9f775 | |||
| 5f6d810fbb | |||
| 55e1ec7dad | |||
| b123dacc41 | |||
| 87e3588ceb | |||
| c4d2e33a99 | |||
| 2ac05508bc | |||
| 5c6d4fbf5a | |||
| aaff027830 | |||
| 355a450c09 | |||
| 21f4fcb041 | |||
| 37aea72a88 | |||
| 783b6ed76c | |||
| 9dfb67cf61 | |||
| 889c72ec60 | |||
| 067e193780 | |||
| 77730196ae | |||
| dba0173cc3 | |||
| 8f4327ab6b | |||
| cc2769e907 | |||
| 91b6db0ba5 | |||
| 8bae76000c | |||
| f502e445cc | |||
| 083bfe6ec2 | |||
| 2c1a5ff5c4 | |||
| 0c2785df67 | |||
| fa9d5a0104 | |||
| 678433d2b3 | |||
| 30bd307931 | |||
| 08dfaba7f7 | |||
| eb2327827b | |||
| 1f53dd1357 | |||
| 034366e65e | |||
| cd537cd9c2 | |||
| 22f92942f6 | |||
| 4eee50d79e | |||
| 125b2c44d4 | |||
| db9e35d686 | |||
| d0958220fe | |||
| fa4b3cfd1b | |||
| 8972f8f109 | |||
| 85ccc6900c | |||
| 4e2deca5d8 | |||
| 04a2c184d7 | |||
| 2c7701e2d4 | |||
| ae569b61db | |||
| 0a0e6abd3f | |||
| 9c7aee32bd | |||
| ed979d807b | |||
| f5c244dbb1 | |||
| 0ea1e9a6da | |||
| a36530d6df | |||
| 825d34718a | |||
| d90d445d84 | |||
| 5976a0cba6 | |||
| b50f2f5a2a | |||
| f877b52898 | |||
| 4a585db637 | |||
| 4d404bf137 | |||
| e644b7e1fc | |||
| aff1684064 | |||
| d9afc50f91 | |||
| eb7b4ccda6 | |||
| bbf4f1d251 | |||
| 3cc7859ca5 | |||
| ab63345c57 | |||
| 3df02e02fa | |||
| 35f5c62633 | |||
| 0f0fc39d07 | |||
| a13b6b2b70 | |||
| 4212b95232 | |||
| 38a73a603b | |||
| c48d9fd4d7 | |||
| 0753987b5a | |||
| 815ff7dc2b | |||
| 46684d420d | |||
| eca09984a3 | |||
| ce63c6423e | |||
| 09699afe82 | |||
| 36c8ad439d | |||
| 5dc77ceed5 | |||
| c7baa26b2d | |||
| 4d0454abcd | |||
| 1dafbf105e | |||
| 773f013115 | |||
| c5cd460595 | |||
| 845352046b | |||
| 597f1087f9 | |||
| 511334683a | |||
| 223a4ad45d | |||
| edf31ec1d3 | |||
| 1539557005 | |||
| 1d3ba4e3ac | |||
| 4110aa00db | |||
| 7eb52cda36 | |||
| 7872fb9cbd | |||
| 651181e62c | |||
| 38a245f2fc | |||
| 1b4289f93f | |||
| d0697c24fd | |||
| 8c24e29081 | |||
| 2b9d26e2ff | |||
| ab148a7654 | |||
| 553e650fbe | |||
| 9690a24c68 | |||
| 978d5d44a2 | |||
| 9df476543a | |||
| cf303ebe97 | |||
| b1d1d89ca5 | |||
| 3a599d0a0a | |||
| 8340f6b906 | |||
| ddb034b14d | |||
| bfa2f67393 | |||
| 447069a97b | |||
| 49b78d726a | |||
| 5b4cddd0b0 | |||
| 8878c148ed | |||
| c3c2ded795 | |||
| fb35fdcc38 | |||
| e76ba9921c | |||
| b19acd550d | |||
| f3e9d110c0 | |||
| 658497da1d | |||
| bd01059a92 | |||
| 57a977e6be | |||
| 94b0cc1f3e | |||
| 5734cc7fc3 | |||
| 3168c22de7 | |||
| 3c94fe9047 | |||
| cdd6b56d42 | |||
| 75ac3bc61b | |||
| 29d511d085 | |||
| b0a41939e8 | |||
| 7d2c1061ba | |||
| d768073d17 | |||
| dc8496c62e | |||
| 416de9a9fb | |||
| da65426ddc | |||
| 585b485852 | |||
| e85f16ff9c | |||
| e7d2289a14 | |||
| d35531758d | |||
| 729e0a7949 | |||
| 620b7401aa | |||
| e3e67b00d5 | |||
| 49d4f8e5c3 | |||
| 47b159c605 | |||
| c7b086fa69 | |||
| 203db79204 | |||
| 48a4fd8373 | |||
| 17eb84325f | |||
| ebf048478d | |||
| 28a8cd2421 | |||
| 1506de92f5 | |||
| 8a03413643 | |||
| f59b806a88 | |||
| 23a0085c78 | |||
| a280a8c3f0 | |||
| 11620dfa6b | |||
| f6e26e0bab | |||
| f6b3a55cbf | |||
| 74939e5cd6 | |||
| 9906c9947a | |||
| 48d6a21f0a | |||
| dd6a980915 | |||
| 2516df3a39 | |||
| 52125f0566 | |||
| e489222b6a | |||
| d93a57d7bf | |||
| d34aea345b | |||
| 0b6102b0ac | |||
| 9e0873ed84 | |||
| 8587eb5fea | |||
| b898c27e74 | |||
| 3026866a16 | |||
| 92fc294eae | |||
| 21e967ea7f | |||
| 3f00e7186c | |||
| d3a4fd8b55 | |||
| 2be7107cca | |||
| 94f194a984 | |||
| 4fe880a970 | |||
| 8f5fbfc273 | |||
| e660f52bb0 | |||
| d74fdd9369 | |||
| 334145f0be | |||
| c24073b6ae | |||
| 078b7f3bf7 | |||
| 3d65676ccb | |||
| ce566fb6e5 | |||
| b23fc9f623 | |||
| 5c2dfb8e40 | |||
| 0e341d7863 | |||
| 6a03ff9596 | |||
| d7bd0c937d | |||
| d3b2483f4f | |||
| 7838b7c9fd | |||
| 130ecf1f88 | |||
| 550d8b3753 | |||
| 696222a070 | |||
| edb424988d | |||
| 1e487ef3bd | |||
| 811ef3e72d | |||
| 980e3c4bc2 | |||
| 78b6854c6b | |||
| 068b9129cf | |||
| 05fba3c50c | |||
| 7944a4ce41 | |||
| 4640f1a3ad | |||
| cd79059d97 | |||
| 2d95e19048 | |||
| d047587bc1 | |||
| 128e1093fb | |||
| afdc305e3e | |||
| 4bc5439996 | |||
| be14022f97 | |||
| eda78ef5ae | |||
| 0cc833e687 | |||
| 33e83747f3 | |||
| c3a8fc6d93 | |||
| 8ff84e269c | |||
| 99cb6a6179 | |||
| 13dbfdfaa4 | |||
| 8603f5c53a | |||
| d5cc9e8386 | |||
| 533e17466b | |||
| 01c7b69f50 | |||
| 47feae3bd9 | |||
| e7ecd655c4 | |||
| d9e538c6ea | |||
| e297f8286f | |||
| b3bc90bbe4 | |||
| 95a02cbcd7 | |||
| a049768f1c | |||
| 818d9a0d77 | |||
| 1a8f80a7dc | |||
| 566c9eaf10 | |||
| e6485c2da1 | |||
| 0479edd36a | |||
| 87c1e92134 | |||
| 8f950ac1b0 | |||
| 78e4f43708 | |||
| 270436f404 | |||
| 57e61632a9 | |||
| 884191b8bb | |||
| 21b92f5f13 | |||
| 5599a75dbd | |||
| 3a06ae6e34 | |||
| 22857d77e9 | |||
| 1a325d0b29 | |||
| 1240b23080 | |||
| 8445080d7a | |||
| bbe89f56a7 | |||
| 86e8bcfe0b | |||
| 21ccf129d6 | |||
| dfc4b7d0c5 | |||
| 17b1120a27 | |||
| 2b509a515b | |||
| 97594b9a9e | |||
| c65190a158 | |||
| 0621e1a53e | |||
| f36b69f4f0 | |||
| 92f7a62af2 | |||
| f73831ac27 | |||
| 09f39499e9 | |||
| 7ac4a9507b | |||
| 3956958452 | |||
| 0fe866ad8b | |||
| cca498be04 | |||
| 039cb38d56 | |||
| 4fb7065ddf | |||
| 39f512d32d | |||
| 85469f2d7d | |||
| 3e24e2c9e8 | |||
| 2d9f6c7b2a | 
| @ -7,8 +7,8 @@ VITE_KC_API_WS_MODELING_URL=wss://api.dev.zoo.dev/ws/modeling/commands | ||||
| VITE_KC_API_BASE_URL=https://api.dev.zoo.dev | ||||
| VITE_KC_SITE_BASE_URL=https://dev.zoo.dev | ||||
| VITE_KC_SITE_APP_URL=https://app.dev.zoo.dev | ||||
| VITE_KC_SKIP_AUTH=false | ||||
| VITE_KC_CONNECTION_TIMEOUT_MS=5000 | ||||
| #VITE_WASM_URL="optional way of overriding the wasm url, particular for unit tests which need this if you running not on the default 3000 port" | ||||
| #VITE_KC_DEV_TOKEN="optional token to skip auth in the app" | ||||
| #token="required token for playwright. TODO: clean up env vars in #3973" | ||||
|  | ||||
|  | ||||
| @ -3,5 +3,4 @@ VITE_KC_API_WS_MODELING_URL=wss://api.zoo.dev/ws/modeling/commands | ||||
| VITE_KC_API_BASE_URL=https://api.zoo.dev | ||||
| VITE_KC_SITE_BASE_URL=https://zoo.dev | ||||
| VITE_KC_SITE_APP_URL=https://app.zoo.dev | ||||
| VITE_KC_SKIP_AUTH=false | ||||
| VITE_KC_CONNECTION_TIMEOUT_MS=15000 | ||||
|  | ||||
							
								
								
									
										3
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| * @KittyCAD/frontend | ||||
| /src/ @KittyCAD/frontend | ||||
| /rust/ @KittyCAD/kcl | ||||
							
								
								
									
										41
									
								
								.github/ISSUE_TEMPLATE/release.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								.github/ISSUE_TEMPLATE/release.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | ||||
| --- | ||||
| name: Release | ||||
| about: Create a new release for the Zoo Design Studio | ||||
| title: "Cut release v1.?.?" | ||||
| labels: [meta/release] | ||||
| --- | ||||
|  | ||||
| > Instructions: https://github.com/KittyCAD/modeling-app/blob/main/CONTRIBUTING.md#shipping-releases | ||||
|  | ||||
| --- | ||||
|  | ||||
| # Manual Checklist | ||||
|  | ||||
| Release builds URL: ??? | ||||
|  | ||||
| ## Windows via ??? | ||||
|  | ||||
| * [ ] Download the release build for this platform | ||||
| * [ ] Confirm the application opens (dismiss the updater) | ||||
| * [ ] Create a project with a basic Text-to-CAD prompt | ||||
| * [ ] Confirm the result is viewable in an engine stream | ||||
| * [ ] Use 'Check for updates' to bring back the updater toast | ||||
| * [ ] Confirm the app can update to the previous release | ||||
|  | ||||
| ## macOS via ??? | ||||
|  | ||||
| * [ ] Download the release build for this platform | ||||
| * [ ] Confirm the application opens (dismiss the updater) | ||||
| * [ ] Create a project with a basic Text-to-CAD prompt | ||||
| * [ ] Confirm the result is viewable in an engine stream | ||||
| * [ ] Use 'Check for updates' to bring back the updater toast | ||||
| * [ ] Confirm the app can update to the previous release | ||||
|  | ||||
| ## Linux via ??? | ||||
|  | ||||
| * [ ] Download the release build for this platform | ||||
| * [ ] Confirm the application opens (dismiss the updater) | ||||
| * [ ] Create a project with a basic Text-to-CAD prompt | ||||
| * [ ] Confirm the result is viewable in an engine stream | ||||
| * [ ] Use 'Check for updates' to bring back the updater toast | ||||
| * [ ] Confirm the app can update to the previous release | ||||
							
								
								
									
										12
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							| @ -7,11 +7,11 @@ if [[ ! -f "test-results/.last-run.json" ]]; then | ||||
|     # If no last run artifact, than run Playwright normally | ||||
|     echo "run playwright normally" | ||||
|     if [[ "$3" == *ubuntu* ]]; then | ||||
|         xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- npm run test:playwright:electron -- --shard=$1/$2 || true | ||||
|         xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- npm run test:e2e:desktop -- --shard=$1/$2 || true | ||||
|     elif [[ "$3" == *windows* ]]; then | ||||
|         npm run test:playwright:electron -- --grep=@windows --shard=$1/$2 || true | ||||
|         npm run test:e2e:desktop -- --grep=@windows --shard=$1/$2 || true | ||||
|     elif [[ "$3" == *macos* ]]; then | ||||
|         npm run test:playwright:electron -- --grep=@macos --shard=$1/$2 || true | ||||
|         npm run test:e2e:desktop -- --grep=@macos --shard=$1/$2 || true | ||||
|     else | ||||
|         echo "Do not run Playwright. Unable to detect os runtime." | ||||
|         exit 1 | ||||
| @ -31,11 +31,11 @@ while [[ $retry -le $max_retries ]]; do | ||||
|             echo "retried=true" >>$GITHUB_OUTPUT | ||||
|             echo "run playwright with last failed tests and retry $retry" | ||||
|             if [[ "$3" == *ubuntu* ]]; then | ||||
|                 xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- npm run test:playwright:electron -- --last-failed || true | ||||
|                 xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- npm run test:e2e:desktop -- --last-failed || true | ||||
|             elif [[ "$3" == *windows* ]]; then | ||||
|                 npm run test:playwright:electron -- --grep=@windows --last-failed || true | ||||
|                 npm run test:e2e:desktop -- --grep=@windows --last-failed || true | ||||
|             elif [[ "$3" == *macos* ]]; then | ||||
|                 npm run test:playwright:electron -- --grep=@macos --last-failed || true | ||||
|                 npm run test:e2e:desktop -- --grep=@macos --last-failed || true | ||||
|             else | ||||
|                 echo "Do not run playwright. Unable to detect os runtime." | ||||
|                 exit 1 | ||||
|  | ||||
							
								
								
									
										43
									
								
								.github/ci-cd-scripts/upload-results.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										43
									
								
								.github/ci-cd-scripts/upload-results.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @ -0,0 +1,43 @@ | ||||
| #!/bin/bash | ||||
| set -euo pipefail | ||||
|  | ||||
| if [ -z "${TAB_API_URL:-}" ] || [ -z "${TAB_API_KEY:-}" ]; then | ||||
|     exit 0 | ||||
| fi | ||||
|  | ||||
| project="https://github.com/KittyCAD/modeling-app" | ||||
| suite="${CI_SUITE:-unit}" | ||||
| branch="${GITHUB_HEAD_REF:-${GITHUB_REF_NAME:-}}" | ||||
| commit="${CI_COMMIT_SHA:-${GITHUB_SHA:-}}" | ||||
|  | ||||
| echo "Uploading batch results" | ||||
| curl --silent --request POST \ | ||||
|   --header "X-API-Key: ${TAB_API_KEY}" \ | ||||
|   --form "project=${project}" \ | ||||
|   --form "suite=${suite}" \ | ||||
|   --form "branch=${branch}" \ | ||||
|   --form "commit=${commit}" \ | ||||
|   --form "tests=@test-results/junit.xml" \ | ||||
|   --form "CI_COMMIT_SHA=${CI_COMMIT_SHA:-}" \ | ||||
|   --form "CI_PR_NUMBER=${CI_PR_NUMBER:-}" \ | ||||
|   --form "GITHUB_BASE_REF=${GITHUB_BASE_REF:-}" \ | ||||
|   --form "GITHUB_EVENT_NAME=${GITHUB_EVENT_NAME:-}" \ | ||||
|   --form "GITHUB_HEAD_REF=${GITHUB_HEAD_REF:-}" \ | ||||
|   --form "GITHUB_REF_NAME=${GITHUB_REF_NAME:-}" \ | ||||
|   --form "GITHUB_REF=${GITHUB_REF:-}" \ | ||||
|   --form "GITHUB_SHA=${GITHUB_SHA:-}" \ | ||||
|   --form "GITHUB_WORKFLOW=${GITHUB_WORKFLOW:-}" \ | ||||
|   --form "RUNNER_ARCH=${RUNNER_ARCH:-}" \ | ||||
|   ${TAB_API_URL}/api/results/bulk | ||||
|  | ||||
| echo | ||||
| echo "Sharing updated report" | ||||
| curl --silent --request POST \ | ||||
|   --header "Content-Type: application/json" \ | ||||
|   --header "X-API-Key: ${TAB_API_KEY}" \ | ||||
|   --data "{ | ||||
|     \"project\": \"${project}\", | ||||
|     \"branch\": \"${branch}\", | ||||
|     \"commit\": \"${commit}\" | ||||
|   }" \ | ||||
|   ${TAB_API_URL}/api/share | ||||
							
								
								
									
										853
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										853
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										149
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										149
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							| @ -7,14 +7,13 @@ on: | ||||
|       - main | ||||
|     tags: | ||||
|       - 'v[0-9]+.[0-9]+.[0-9]+' | ||||
|       - 'nightly-v[0-9]+.[0-9]+.[0-9]+' | ||||
|  | ||||
| env: | ||||
|   IS_RELEASE: ${{ github.ref_type == 'tag' && startsWith(github.ref_name, 'v') }} | ||||
|   IS_NIGHTLY: ${{ github.ref_type == 'tag' && startsWith(github.ref_name, 'nightly-v') }} | ||||
|   IS_STAGING: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   group: ${{ github.workflow }}-${{ github.ref }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| jobs: | ||||
| @ -44,7 +43,7 @@ jobs: | ||||
|       - name: Download Wasm Cache | ||||
|         id: download-wasm | ||||
|         if: ${{ github.event_name == 'pull_request' && steps.filter.outputs.rust == 'false' }} | ||||
|         uses: dawidd6/action-download-artifact@v7 | ||||
|         uses: dawidd6/action-download-artifact@v11 | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           github_token: ${{secrets.GITHUB_TOKEN}} | ||||
| @ -92,12 +91,14 @@ jobs: | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         run: "npm run build:wasm" | ||||
|  | ||||
|       - name: Set nightly version, product name, release notes, and icons | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|       - name: Set staging version, product name, release notes, and icons | ||||
|         if: ${{ env.IS_STAGING == 'true' }} | ||||
|         run: | | ||||
|           export VERSION=${GITHUB_REF_NAME#nightly-v} | ||||
|           COMMIT=$(git rev-parse --short HEAD) | ||||
|           DATE=$(date +'%-y.%-m.%-d') | ||||
|           export VERSION=$DATE-main.$COMMIT | ||||
|           npm run files:set-version | ||||
|           npm run files:flip-to-nightly | ||||
|           npm run files:flip-to-staging | ||||
|  | ||||
|       - name: Set release version | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
| @ -122,18 +123,6 @@ jobs: | ||||
|       - id: export_notes | ||||
|         run: echo "notes=`cat release-notes.md`" >> "$GITHUB_OUTPUT" | ||||
|  | ||||
|       - name: Prepare electron-builder.yml file for updater test | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         run: | | ||||
|           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test"' electron-builder.yml | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         with: | ||||
|           name: prepared-files-updater-test | ||||
|           path: | | ||||
|             electron-builder.yml | ||||
|  | ||||
|  | ||||
|   build-apps: | ||||
|     needs: [prepare-files] | ||||
| @ -141,13 +130,14 @@ jobs: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         include: | ||||
|           - os: macos-14 | ||||
|             platform: mac | ||||
|           - os: windows-2022 | ||||
|             platform: win | ||||
|           - os: namespace-profile-macos-6-cores | ||||
|             platform: macos | ||||
|           - os: namespace-profile-windows-4-cores | ||||
|             platform: windows | ||||
|           - os: ubuntu-22.04 | ||||
|             platform: linux | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     name: build-apps (${{ matrix.platform }}) | ||||
|     env: | ||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||
|     steps: | ||||
| @ -177,14 +167,14 @@ jobs: | ||||
|       - run: npm install | ||||
|  | ||||
|       - name: Prepare certificate and variables (Windows only) | ||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} | ||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_STAGING == 'true') && matrix.platform == 'windows' }} | ||||
|         run: | | ||||
|           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 | ||||
|           cat /d/Certificate_pkcs12.p12 | ||||
|           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /c/Certificate_pkcs12.p12 | ||||
|           cat /c/Certificate_pkcs12.p12 | ||||
|           echo "::set-output name=version::${GITHUB_REF#refs/tags/v}" | ||||
|           echo "SM_HOST=${{ secrets.SM_HOST }}" >> "$GITHUB_ENV" | ||||
|           echo "SM_API_KEY=${{ secrets.SM_API_KEY }}" >> "$GITHUB_ENV" | ||||
|           echo "SM_CLIENT_CERT_FILE=D:\\Certificate_pkcs12.p12" >> "$GITHUB_ENV" | ||||
|           echo "SM_CLIENT_CERT_FILE=C:\\Certificate_pkcs12.p12" >> "$GITHUB_ENV" | ||||
|           echo "SM_CLIENT_CERT_PASSWORD=${{ secrets.SM_CLIENT_CERT_PASSWORD }}" >> "$GITHUB_ENV" | ||||
|           echo "C:\Program Files (x86)\Windows Kits\10\App Certification Kit" >> $GITHUB_PATH | ||||
|           echo "C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools" >> $GITHUB_PATH | ||||
| @ -192,7 +182,7 @@ jobs: | ||||
|         shell: bash | ||||
|  | ||||
|       - name: Setup certicate with SSM KSP (Windows only) | ||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} | ||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_STAGING == 'true') && matrix.platform == 'windows' }} | ||||
|         run: | | ||||
|           curl -X GET  https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download -H "x-api-key:%SM_API_KEY%" -o smtools-windows-x64.msi | ||||
|           msiexec /i smtools-windows-x64.msi /quiet /qn | ||||
| @ -202,7 +192,7 @@ jobs: | ||||
|           smksp_cert_sync.exe | ||||
|           smctl windows certsync | ||||
|         # This last line `smctl windows certsync` was added after windows codesign failures started happening | ||||
|         # with nightly-v25.4.10. It looks like `smksp_cert_sync.exe` used to do the sync to the local cert store, | ||||
|         # with staging-v25.4.10. It looks like `smksp_cert_sync.exe` used to do the sync to the local cert store, | ||||
|         # but stopped doing it overnight. This extra call that I randomly got from this azure-related doc page | ||||
|         # https://docs.digicert.com/en/digicert-keylocker/code-signing/sign-with-third-party-signing-tools/windows-applications/sign-azure-apps-with-signtool-using-ksp-library.html#sync-certificates--windows-only--618365 | ||||
|         # seems to be doing that extra sync that we need for scripts/sign-win.js to work. | ||||
| @ -210,13 +200,13 @@ jobs: | ||||
|         shell: cmd | ||||
|  | ||||
|       - name: Build the app (debug) | ||||
|         if: ${{ env.IS_RELEASE == 'false' && env.IS_NIGHTLY == 'false' }} | ||||
|         if: ${{ env.IS_RELEASE == 'false' && env.IS_STAGING == 'false' }} | ||||
|         # electron-builder doesn't have a concept of release vs debug, | ||||
|         # this is just not doing any codesign or release yml generation, and points to dev infra | ||||
|         run: npm run tronb:package:dev | ||||
|  | ||||
|       - name: Build the app (release) | ||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} | ||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_STAGING == 'true' }} | ||||
|         env: | ||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||
| @ -226,7 +216,7 @@ jobs: | ||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||
|         run: npm run tronb:package:prod | ||||
|         run: npm run tronb:package:${{ env.IS_STAGING == 'true' && 'dev' || 'prod' }} | ||||
|  | ||||
|       - name: List artifacts in out/ | ||||
|         run: ls -R out | ||||
| @ -250,63 +240,21 @@ jobs: | ||||
|             out/*-x86_64-linux.* | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} | ||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_STAGING == 'true' }} | ||||
|         with: | ||||
|           name: out-yml-${{ matrix.platform }} | ||||
|           path: | | ||||
|             out/latest*.yml | ||||
|  | ||||
|       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back | ||||
|  | ||||
|       # The steps below are for updater-test builds, only on release | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         name: prepared-files-updater-test | ||||
|  | ||||
|       - name: Copy updated electron-builder.yml file for updater test | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         run: | | ||||
|           ls -R prepared-files-updater-test | ||||
|           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml | ||||
|  | ||||
|       - name: Build the app (updater-test) | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         env: | ||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||
|           APPLE_APP_SPECIFIC_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||
|           APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }} | ||||
|           CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} | ||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||
|         run: npm run tronb:package:prod | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         with: | ||||
|           name: updater-test-arm64-${{ matrix.platform }} | ||||
|           path: | | ||||
|             out/*-arm64-win.exe | ||||
|             out/*-arm64-mac.dmg | ||||
|             out/*-arm64-linux.AppImage | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ env.IS_RELEASE == 'true' }} | ||||
|         with: | ||||
|           name: updater-test-x64-${{ matrix.platform }} | ||||
|           path: | | ||||
|             out/*-x64-win.exe | ||||
|             out/*-x64-mac.dmg | ||||
|             out/*-x86_64-linux.AppImage | ||||
|       # TODO: add the 'Build for Mac TestFlight' stage back | ||||
|  | ||||
|  | ||||
|   upload-apps-release: | ||||
|     runs-on: ubuntu-22.04 | ||||
|     permissions: | ||||
|       contents: write | ||||
|     if: ${{ github.ref_type == 'tag' }} | ||||
|     # Equivalent to IS_RELEASE || IS_STAGING (but we can't access those env vars here) | ||||
|     if: ${{ (github.ref_type == 'tag' && startsWith(github.ref_name, 'v')) || (github.event_name == 'push' && github.ref == 'refs/heads/main') }} | ||||
|     env: | ||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||
|       VERSION: ${{ format('v{0}', needs.prepare-files.outputs.version) }} | ||||
| @ -316,32 +264,32 @@ jobs: | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-arm64-win | ||||
|           name: out-arm64-windows | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-x64-win | ||||
|           name: out-x64-windows | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-yml-win | ||||
|           name: out-yml-windows | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-arm64-mac | ||||
|           name: out-arm64-macos | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-x64-mac | ||||
|           name: out-x64-macos | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-yml-mac | ||||
|           name: out-yml-macos | ||||
|           path: out | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
| @ -363,8 +311,8 @@ jobs: | ||||
|         env: | ||||
|           NOTES: ${{ needs.prepare-files.outputs.notes }} | ||||
|           PUB_DATE: ${{ github.event.repository.updated_at }} | ||||
|           WEBSITE_DIR: ${{ env.IS_NIGHTLY == 'true' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} | ||||
|           URL_CODED_NAME: ${{ env.IS_NIGHTLY == 'true' && 'Zoo%20Design%20Studio%20%28Nightly%29' || 'Zoo%20Design%20Studio' }} | ||||
|           WEBSITE_DIR: ${{ env.IS_STAGING == 'true' && 'dl.zoo.dev/releases/modeling-app/staging' || 'dl.zoo.dev/releases/modeling-app' }} | ||||
|           URL_CODED_NAME: ${{ env.IS_STAGING == 'true' && 'Zoo%20Design%20Studio%20%28Staging%29' || 'Zoo%20Design%20Studio' }} | ||||
|         run: | | ||||
|           RELEASE_DIR=https://${WEBSITE_DIR} | ||||
|           jq --null-input \ | ||||
| @ -412,38 +360,27 @@ jobs: | ||||
|       - name: List artifacts | ||||
|         run: "ls -R out" | ||||
|  | ||||
|       - name: Set more complete nightly release notes | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|         run: | | ||||
|           # Note: preferred going this way instead of a full clone in the checkout step, | ||||
|           # see https://github.com/actions/checkout/issues/1471 | ||||
|           git fetch --prune --unshallow --tags | ||||
|           export TAG="nightly-${VERSION}" | ||||
|           export PREVIOUS_TAG=$(git tag --list --sort=-committerdate "nightly-v[0-9]*" | head -n2 | tail -n1) | ||||
|           export NOTES=$(./scripts/get-nightly-changelog.sh) | ||||
|           npm run files:set-notes | ||||
|  | ||||
|       - name: Authenticate to Google Cloud | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|         uses: 'google-github-actions/auth@v2.1.8' | ||||
|         if: ${{ env.IS_STAGING == 'true' }} | ||||
|         uses: 'google-github-actions/auth@v2.1.10' | ||||
|         with: | ||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||
|  | ||||
|       - name: Set up Google Cloud SDK | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|         if: ${{ env.IS_STAGING == 'true' }} | ||||
|         uses: google-github-actions/setup-gcloud@v2.1.4 | ||||
|         with: | ||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} | ||||
|  | ||||
|       - name: Upload nightly files to public bucket | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|       - name: Upload staging files to public bucket | ||||
|         if: ${{ env.IS_STAGING == 'true' }} | ||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.2 | ||||
|         with: | ||||
|           path: out | ||||
|           glob: '*' | ||||
|           parent: false | ||||
|           destination: 'dl.kittycad.io/releases/modeling-app/nightly' | ||||
|           destination: 'dl.kittycad.io/releases/modeling-app/staging' | ||||
|  | ||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files | ||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||
|         run: npm run files:invalidate-bucket:nightly | ||||
|         if: ${{ env.IS_STAGING == 'true' }} | ||||
|         run: npm run files:invalidate-bucket:staging | ||||
|  | ||||
							
								
								
									
										56
									
								
								.github/workflows/build-wasm.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								.github/workflows/build-wasm.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,56 @@ | ||||
| name: Build WASM | ||||
|  | ||||
| on: | ||||
|   workflow_call: | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   npm-build-wasm: | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|  | ||||
|       - name: Install rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # configured below | ||||
|  | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Use Rust cache | ||||
|         uses: Swatinem/rust-cache@v2 | ||||
|         with: | ||||
|           workspaces: './rust' | ||||
|  | ||||
|       - name: Build Wasm | ||||
|         shell: bash | ||||
|         run: npm run build:wasm | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: prepared-wasm | ||||
|           path: | | ||||
|             rust/kcl-wasm-lib/pkg/kcl_wasm_lib* | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: prepared-ts-rs-bindings | ||||
|           path: | | ||||
|             rust/kcl-lib/bindings/* | ||||
							
								
								
									
										6
									
								
								.github/workflows/cargo-fmt.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/cargo-fmt.yml
									
									
									
									
										vendored
									
									
								
							| @ -31,15 +31,15 @@ jobs: | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|           cp .github/workflows/nightly-rust-toolchain.toml rust-toolchain.toml | ||||
|       - name: Install rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache-workspaces: rust | ||||
|           components: rustfmt | ||||
|  | ||||
|       - name: Run cargo fmt | ||||
|       - name: Run nightly cargo fmt | ||||
|         run: | | ||||
|           cd rust | ||||
|           cargo fmt -- --check | ||||
|           cargo +nightly fmt -- --check | ||||
|         shell: bash | ||||
|  | ||||
							
								
								
									
										87
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										87
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,16 +1,22 @@ | ||||
| name: cargo test | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|   pull_request: | ||||
|   workflow_dispatch: | ||||
|   schedule: | ||||
|     - cron: 0 * * * *  # hourly | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|   pull-requests: write | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
| name: cargo test | ||||
|  | ||||
| jobs: | ||||
|   build-test-artifacts: | ||||
|     name: Build test artifacts | ||||
| @ -19,8 +25,8 @@ jobs: | ||||
|       - runner=8cpu-linux-x64 | ||||
|       - extras=s3-cache | ||||
|     steps: | ||||
|       - uses: runs-on/action@v1 | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
|       - uses: runs-on/action@v2 | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
| @ -88,6 +94,7 @@ jobs: | ||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} | ||||
|           ZOO_HOST: https://api.dev.zoo.dev | ||||
|           RUST_BACKTRACE: full | ||||
|           RUST_MIN_STACK: 10485760000 | ||||
|       - name: Commit differences | ||||
|         if: steps.path-changes.outputs.outside-kcl-samples == 'false' && steps.cargo-test-kcl-samples.outcome == 'failure' | ||||
|         shell: bash | ||||
| @ -98,9 +105,7 @@ jobs: | ||||
|           popd | ||||
|           git add \ | ||||
|             rust/kcl-lib/tests \ | ||||
|             public/kcl-samples/manifest.json \ | ||||
|             public/kcl-samples/README.md \ | ||||
|             public/kcl-samples/screenshots | ||||
|             public/kcl-samples | ||||
|           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 | ||||
| @ -121,6 +126,7 @@ jobs: | ||||
|           # Configure nextest when it's run by insta (via just). | ||||
|           NEXTEST_PROFILE: ci | ||||
|           RUST_BACKTRACE: full | ||||
|           RUST_MIN_STACK: 10485760000 | ||||
|       - name: Build and archive tests | ||||
|         run: | | ||||
|           cd rust | ||||
| @ -143,8 +149,8 @@ jobs: | ||||
|         partitionIndex: [1, 2, 3, 4, 5, 6] | ||||
|         partitionTotal: [6] | ||||
|     steps: | ||||
|       - uses: runs-on/action@v1 | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
|       - uses: runs-on/action@v2 | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
| @ -157,7 +163,7 @@ jobs: | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|       - name: Install rust | ||||
|       - name: Install Rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
| @ -177,13 +183,72 @@ jobs: | ||||
|           cp nextest-archive.tar.zst rust/nextest-archive.tar.zst | ||||
|           ls -lah | ||||
|           cd rust | ||||
|           cargo nextest run\ | ||||
|            --retries=10 --no-fail-fast --profile ci --archive-file nextest-archive.tar.zst \ | ||||
|           cargo nextest run \ | ||||
|            --retries=10 --no-fail-fast --profile=ci --archive-file nextest-archive.tar.zst \ | ||||
|            --partition count:${{ matrix.partitionIndex}}/${{ matrix.partitionTotal }} \ | ||||
|            2>&1 | tee /tmp/github-actions.log | ||||
|         env: | ||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} | ||||
|           ZOO_HOST: https://api.dev.zoo.dev | ||||
|           RUST_MIN_STACK: 10485760000 | ||||
|       - name: Upload results | ||||
|         if: always() | ||||
|         run: .github/ci-cd-scripts/upload-results.sh | ||||
|         env: | ||||
|           TAB_API_URL: ${{ secrets.TAB_API_URL }} | ||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|           CI_SUITE: e2e:kcl | ||||
|   run-internal-kcl-samples: | ||||
|     name: cargo test (internal-kcl-samples) | ||||
|     runs-on: | ||||
|       - runs-on=${{ github.run_id }} | ||||
|       - runner=32cpu-linux-x64 | ||||
|       - extras=s3-cache | ||||
|     steps: | ||||
|       - uses: runs-on/action@v2 | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
|           private-key: ${{ secrets.MODELING_APP_GH_APP_PRIVATE_KEY }} | ||||
|           owner: ${{ github.repository_owner }} | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ steps.app-token.outputs.token }} | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|       - name: Install Rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|       - name: Start Vector | ||||
|         run: .github/ci-cd-scripts/start-vector-ubuntu.sh | ||||
|         env: | ||||
|           GH_ACTIONS_AXIOM_TOKEN: ${{ secrets.GH_ACTIONS_AXIOM_TOKEN }} | ||||
|           OS_NAME: ${{ env.OS_NAME }} | ||||
|       - uses: taiki-e/install-action@nextest | ||||
|       - name: Download internal KCL samples | ||||
|         run: git clone --depth=1 https://x-access-token:${{ secrets.GH_PAT_KCL_SAMPLES_INTERNAL }}@github.com/KittyCAD/kcl-samples-internal public/kcl-samples/internal | ||||
|       - name: Run tests | ||||
|         shell: bash | ||||
|         run: |- | ||||
|           cd rust/kcl-lib | ||||
|           cargo nextest run \ | ||||
|            --retries=10 --no-fail-fast --features artifact-graph --profile=ci \ | ||||
|            internal \ | ||||
|            2>&1 | tee /tmp/github-actions.log | ||||
|         env: | ||||
|           TWENTY_TWENTY: overwrite | ||||
|           INSTA_UPDATE: always | ||||
|           EXPECTORATE: overwrite | ||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} | ||||
|           ZOO_HOST: https://api.dev.zoo.dev | ||||
|           MODELING_APP_INTERNAL_SAMPLES_SECRET: ${{secrets.MODELING_APP_INTERNAL_SAMPLES_SECRET}} | ||||
|           RUST_MIN_STACK: 10485760000 | ||||
|   run-wasm-tests: | ||||
|     name: Run wasm tests | ||||
|     strategy: | ||||
|  | ||||
							
								
								
									
										47
									
								
								.github/workflows/check-exampleKcl.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										47
									
								
								.github/workflows/check-exampleKcl.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,47 +0,0 @@ | ||||
| name: Check Onboarding KCL | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     types: [opened, synchronize] | ||||
|     paths: | ||||
|       - 'src/lib/exampleKcl.ts' | ||||
|       - 'public/kcl-samples/bracket/main.kcl' | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|   issues: write | ||||
|   pull-requests: write | ||||
|  | ||||
| jobs: | ||||
|   comment: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|  | ||||
|       - name: Comment on PR | ||||
|         uses: actions/github-script@v7 | ||||
|         with: | ||||
|           script: | | ||||
|             const message = '`public/kcl-samples/bracket/main.kcl` or `src/lib/exampleKcl.ts` has been updated in this PR, please review and update the `src/routes/onboarding`, if needed.'; | ||||
|             const issue_number = context.payload.pull_request.number; | ||||
|             const owner = context.repo.owner; | ||||
|             const repo = context.repo.repo; | ||||
|  | ||||
|             const { data: comments } = await github.rest.issues.listComments({ | ||||
|               owner, | ||||
|               repo, | ||||
|               issue_number | ||||
|             }); | ||||
|  | ||||
|             const commentExists = comments.some(comment => comment.body === message); | ||||
|  | ||||
|             if (!commentExists) { | ||||
|               // Post a comment on the PR | ||||
|               await github.rest.issues.createComment({ | ||||
|                 owner, | ||||
|                 repo, | ||||
|                 issue_number, | ||||
|                 body: message, | ||||
|               }); | ||||
|             } | ||||
							
								
								
									
										314
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										314
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,4 +1,5 @@ | ||||
| name: E2E Tests | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
| @ -18,73 +19,15 @@ permissions: | ||||
|  | ||||
| jobs: | ||||
|  | ||||
|   conditions: | ||||
|     runs-on: ubuntu-latest | ||||
|     outputs: | ||||
|       significant: ${{ steps.path-changes.outputs.significant }} | ||||
|       should-run: ${{ steps.should-run.outputs.should-run }} | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - name: Fetch the base branch | ||||
|         if: ${{ github.event_name == 'pull_request' }} | ||||
|         run: git fetch origin ${{ github.base_ref }} --depth=1 | ||||
|  | ||||
|       - name: Check for path changes | ||||
|         id: path-changes | ||||
|         shell: bash | ||||
|         run: | | ||||
|           set -euo pipefail | ||||
|  | ||||
|           # Manual runs or push should run all tests. | ||||
|           if [[ ${{ github.event_name }} != 'pull_request' ]]; then | ||||
|             echo "significant=true" >> $GITHUB_OUTPUT | ||||
|             exit 0 | ||||
|           fi | ||||
|  | ||||
|           changed_files=$(git diff --name-only origin/${{ github.base_ref }}) | ||||
|           echo "$changed_files" | ||||
|           if grep -Evq '^README.md|^public/kcl-samples/|^rust/kcl-lib/tests/kcl_samples/' <<< "$changed_files" ; then | ||||
|             echo "significant=true" >> $GITHUB_OUTPUT | ||||
|           else | ||||
|             echo "significant=false" >> $GITHUB_OUTPUT | ||||
|           fi | ||||
|  | ||||
|       - name: Should run | ||||
|         id: should-run | ||||
|         shell: bash | ||||
|         run: | | ||||
|           set -euo pipefail | ||||
|           # We should run when this is a scheduled run or if there are | ||||
|           # significant changes in the diff. | ||||
|           if [[ ${{ github.event_name }} == 'schedule' || ${{ steps.path-changes.outputs.significant }} == 'true' ]]; then | ||||
|             echo "should-run=true" >> $GITHUB_OUTPUT | ||||
|           else | ||||
|             echo "should-run=false" >> $GITHUB_OUTPUT | ||||
|           fi | ||||
|  | ||||
|       - name: Display conditions | ||||
|         shell: bash | ||||
|         run: | | ||||
|           # For debugging purposes | ||||
|           set -euo pipefail | ||||
|           echo "GITHUB_REF: $GITHUB_REF" | ||||
|           echo "GITHUB_HEAD_REF: $GITHUB_HEAD_REF" | ||||
|           echo "GITHUB_BASE_REF: $GITHUB_BASE_REF" | ||||
|           echo "significant: ${{ steps.path-changes.outputs.significant }}" | ||||
|           echo "should-run: ${{ steps.should-run.outputs.should-run }}" | ||||
|  | ||||
|   prepare-wasm: | ||||
|  | ||||
|     # separate job on Ubuntu to build or fetch the wasm blob once on the fastest runner | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     needs: conditions | ||||
|     steps: | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|  | ||||
|       - id: filter | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         name: Check for Rust changes | ||||
|         uses: dorny/paths-filter@v3 | ||||
|         with: | ||||
| @ -93,19 +36,17 @@ jobs: | ||||
|               - 'rust/**' | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Download Wasm Cache | ||||
|       - name: Download Wasm cache | ||||
|         id: download-wasm | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && github.event_name != 'schedule' && steps.filter.outputs.rust == 'false' }} | ||||
|         uses: dawidd6/action-download-artifact@v7 | ||||
|         if: ${{ github.event_name != 'schedule' && steps.filter.outputs.rust == 'false' }} | ||||
|         uses: dawidd6/action-download-artifact@v11 | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           github_token: ${{secrets.GITHUB_TOKEN}} | ||||
| @ -114,9 +55,8 @@ jobs: | ||||
|           branch: main | ||||
|           path: rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Build WASM condition | ||||
|       - name: Build Wasm condition | ||||
|         id: wasm | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: | | ||||
|           set -euox pipefail | ||||
|           # Build wasm if this is a scheduled run, there are Rust changes, or | ||||
| @ -128,47 +68,49 @@ jobs: | ||||
|           fi | ||||
|  | ||||
|       - name: Use correct Rust toolchain | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|  | ||||
|       - name: Install rust | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|       - name: Install Rust | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|  | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Rust Cache | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|       - name: Use Rust cache | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         uses: Swatinem/rust-cache@v2 | ||||
|         with: | ||||
|           workspaces: './rust' | ||||
|  | ||||
|       - name: Build Wasm | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         shell: bash | ||||
|         run: npm run build:wasm | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Upload compiled wasm artifacts | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: prepared-wasm | ||||
|           path: | | ||||
|             rust/kcl-wasm-lib/pkg/kcl_wasm_lib* | ||||
|  | ||||
|   snapshots: | ||||
|     name: playwright:snapshots:ubuntu | ||||
|     needs: [prepare-wasm] | ||||
|  | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     needs: [conditions, prepare-wasm] | ||||
|     name: e2e:snapshots | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|  | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
| @ -176,16 +118,13 @@ jobs: | ||||
|           owner: ${{ github.repository_owner }} | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         with: | ||||
|           token: ${{ steps.app-token.outputs.token }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         name: prepared-wasm | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Copy prepared Wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
| @ -193,34 +132,24 @@ jobs: | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         id: deps-install | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Cache Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Download browser cache | ||||
|         uses: actions/cache@v4 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/.cache/ms-playwright/ | ||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} | ||||
|  | ||||
|       - name: Install Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Install browsers | ||||
|         run: npm run playwright install --with-deps | ||||
|  | ||||
|       - name: build web | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: npm run tronb:vite:dev | ||||
|  | ||||
|       - name: Run ubuntu/chrome snapshots | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: npm run test:snapshots | ||||
|         uses: nick-fields/retry@v3.0.2 | ||||
|         with: | ||||
|           shell: bash | ||||
| @ -233,31 +162,44 @@ jobs: | ||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|           CI_SUITE: e2e:snapshots | ||||
|           TARGET: web | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} | ||||
|       - name: Update snapshots | ||||
|         if: always() | ||||
|         run: npm run test:snapshots -- --last-failed --update-snapshots | ||||
|         env: | ||||
|           token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|           TAB_API_URL: ${{ secrets.TAB_API_URL }} | ||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|           CI_SUITE: e2e:snapshots | ||||
|           TARGET: web | ||||
|  | ||||
|       - name: Upload playwright report | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         if: ${{ !cancelled() }} | ||||
|         with: | ||||
|           name: playwright-report-ubuntu-snapshot-${{ github.sha }} | ||||
|           name: playwright-report-snapshot-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|           overwrite: true | ||||
|  | ||||
|       - name: Check for changes | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && github.ref != 'refs/heads/main' }} | ||||
|       - name: Check diff | ||||
|         if: ${{ always() && github.ref != 'refs/heads/main' }} | ||||
|         shell: bash | ||||
|         id: git-check | ||||
|         run: | | ||||
|             git add e2e/playwright/snapshot-tests.spec.ts-snapshots e2e/playwright/snapshots | ||||
|             if git status | grep -q "Changes to be committed" | ||||
|             if git status | grep --quiet "Changes to be committed" | ||||
|             then echo "modified=true" >> $GITHUB_OUTPUT | ||||
|             else echo "modified=false" >> $GITHUB_OUTPUT | ||||
|             fi | ||||
|  | ||||
|       - name: Commit changes, if any | ||||
|         # TODO: find a more reliable way to detect visual changes | ||||
|         if: ${{ false && needs.conditions.outputs.should-run == 'true' && steps.git-check.outputs.modified == 'true' }} | ||||
|       - name: Commit changes | ||||
|         if: ${{ always() && steps.git-check.outputs.modified == 'true' }} | ||||
|         shell: bash | ||||
|         run: | | ||||
|           git add e2e/playwright/snapshot-tests.spec.ts-snapshots e2e/playwright/snapshots | ||||
| @ -267,20 +209,105 @@ jobs: | ||||
|           git fetch origin | ||||
|           echo ${{ github.head_ref }} | ||||
|           git checkout ${{ github.head_ref }} | ||||
|           git commit -m "A snapshot a day keeps the bugs away! 📷🐛" || true | ||||
|           git commit --message "Update snapshots" || true | ||||
|           git push | ||||
|           git push origin ${{ github.head_ref }} | ||||
|  | ||||
|   electron: | ||||
|     needs: [conditions, prepare-wasm] | ||||
|     timeout-minutes: 60 | ||||
|     env: | ||||
|       OS_NAME: ${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} | ||||
|     name: playwright:electron:${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} (shard ${{ matrix.shardIndex }}) | ||||
|   web: | ||||
|     needs: [prepare-wasm] | ||||
|  | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         include: | ||||
|           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" | ||||
|           - os: namespace-profile-macos-8-cores | ||||
|           - os: namespace-profile-windows-8-cores | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     name: e2e:web (${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}) | ||||
|     env: | ||||
|       OS_NAME: ${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} | ||||
|  | ||||
|     steps: | ||||
|  | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
|           private-key: ${{ secrets.MODELING_APP_GH_APP_PRIVATE_KEY }} | ||||
|           owner: ${{ github.repository_owner }} | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ steps.app-token.outputs.token }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         name: prepared-wasm | ||||
|  | ||||
|       - name: Copy prepared Wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Download browser cache | ||||
|         uses: actions/cache@v4 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/.cache/ms-playwright/ | ||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} | ||||
|  | ||||
|       - name: Install browsers | ||||
|         run: npm run playwright install --with-deps | ||||
|  | ||||
|       - name: Start Vector | ||||
|         if: ${{ !contains(matrix.os, 'windows') }} | ||||
|         run: .github/ci-cd-scripts/start-vector-${{ env.OS_NAME }}.sh | ||||
|         env: | ||||
|           GH_ACTIONS_AXIOM_TOKEN: ${{ secrets.GH_ACTIONS_AXIOM_TOKEN }} | ||||
|           OS_NAME: ${{ env.OS_NAME }} | ||||
|  | ||||
|       - name: npm run test:e2e:web | ||||
|         uses: nick-fields/retry@v3.0.2 | ||||
|         with: | ||||
|           shell: bash | ||||
|           command: npm run test:e2e:web | ||||
|           timeout_minutes: 5 | ||||
|           max_attempts: 5 | ||||
|         env: | ||||
|           token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|           TAB_API_URL: ${{ secrets.TAB_API_URL }} | ||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|           CI_SUITE: e2e:web | ||||
|           TARGET: web | ||||
|  | ||||
|       - name: Upload playwright report | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         if: ${{ !cancelled() && (success() || failure()) }} | ||||
|         with: | ||||
|           name: playwright-report-web-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|           overwrite: true | ||||
|  | ||||
|   desktop: | ||||
|     needs: [prepare-wasm] | ||||
|  | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         # TODO: enable namespace-profile-windows-latest once available | ||||
|         include: | ||||
|           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" | ||||
|             shardIndex: 1 | ||||
| @ -308,21 +335,28 @@ jobs: | ||||
|             shardTotal: 8 | ||||
|           - os: namespace-profile-macos-8-cores | ||||
|             shardIndex: 1 | ||||
|             shardTotal: 1 | ||||
|           - os: windows-latest-8-cores | ||||
|             shardTotal: 2 | ||||
|           - os: namespace-profile-macos-8-cores | ||||
|             shardIndex: 2 | ||||
|             shardTotal: 2 | ||||
|           - os: namespace-profile-windows-8-cores | ||||
|             shardIndex: 1 | ||||
|             shardTotal: 1 | ||||
|             shardTotal: 2 | ||||
|           - os: namespace-profile-windows-8-cores | ||||
|             shardIndex: 2 | ||||
|             shardTotal: 2 | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     name: e2e:desktop (${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}, shard ${{ matrix.shardIndex }}) | ||||
|     env: | ||||
|       OS_NAME: ${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         name: prepared-wasm | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Copy prepared Wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
| @ -330,49 +364,44 @@ jobs: | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         id: deps-install | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Cache Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Download browser cache | ||||
|         uses: actions/cache@v4 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/.cache/ms-playwright/ | ||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} | ||||
|  | ||||
|       - name: Install Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|       - name: Install browsers | ||||
|         run: npm run playwright install --with-deps | ||||
|  | ||||
|       - name: Build web | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: npm run tronb:vite:dev | ||||
|  | ||||
|       - name: Start Vector | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !contains(matrix.os, 'windows') }} | ||||
|         if: ${{ !contains(matrix.os, 'windows') }} | ||||
|         run: .github/ci-cd-scripts/start-vector-${{ env.OS_NAME }}.sh | ||||
|         env: | ||||
|           GH_ACTIONS_AXIOM_TOKEN: ${{ secrets.GH_ACTIONS_AXIOM_TOKEN }} | ||||
|           OS_NAME: ${{ env.OS_NAME }} | ||||
|  | ||||
|       - name: Build app | ||||
|         run: npm run tronb:vite:dev | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} | ||||
|         if: ${{ !cancelled() && (success() || failure()) }} | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: test-results/ | ||||
|  | ||||
|       - name: Run playwright/electron flow (with retries) | ||||
|       - name: npm run test:e2e:desktop | ||||
|         id: retry | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && steps.deps-install.outcome == 'success' }} | ||||
|         if:  ${{ !cancelled() && steps.deps-install.outcome == 'success' }} | ||||
|         uses: nick-fields/retry@v3.0.2 | ||||
|         with: | ||||
|           shell: bash | ||||
| @ -386,21 +415,24 @@ jobs: | ||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|           CI_SUITE: e2e:desktop | ||||
|           TARGET: desktop | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} | ||||
|       - name: Upload test report | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         if: always() | ||||
|         with: | ||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: test-results-desktop-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: test-results/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|           overwrite: true | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} | ||||
|       - name: Upload playwright report | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         if: always() | ||||
|         with: | ||||
|           name: playwright-report-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: playwright-report-desktop-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/generate-website-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/generate-website-docs.yml
									
									
									
									
										vendored
									
									
								
							| @ -20,7 +20,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
|       - uses: actions/create-github-app-token@v2 | ||||
|         id: app-token | ||||
|         with: | ||||
|           # required | ||||
|  | ||||
							
								
								
									
										101
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										101
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							| @ -21,14 +21,11 @@ on: | ||||
|       - '**.rs' | ||||
|       - .github/workflows/kcl-language-server.yml | ||||
|   workflow_dispatch: | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| env: | ||||
|   CARGO_INCREMENTAL: 0 | ||||
|   CARGO_NET_RETRY: 10 | ||||
| @ -38,10 +35,9 @@ env: | ||||
|   MACOSX_DEPLOYMENT_TARGET: 10.15 | ||||
|   CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER: aarch64-linux-gnu-gcc | ||||
|   CARGO_TARGET_ARM_UNKNOWN_LINUX_GNUEABIHF_LINKER: arm-linux-gnueabihf-gcc | ||||
|  | ||||
| jobs: | ||||
|   test: | ||||
|     name: vscode tests | ||||
|     name: kcl-language-server (vscode tests) | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
| @ -77,22 +73,20 @@ jobs: | ||||
|         include: | ||||
|           - os: windows-latest | ||||
|             target: x86_64-pc-windows-msvc | ||||
|             code-target: | ||||
|               win32-x64 | ||||
|               #- os: windows-latest | ||||
|               #target: i686-pc-windows-msvc | ||||
|               #code-target: | ||||
|               #win32-ia32 | ||||
|               #- os: windows-latest | ||||
|               #target: aarch64-pc-windows-msvc | ||||
|               #code-target: win32-arm64 | ||||
|             code-target: win32-x64 | ||||
|             #- os: windows-latest | ||||
|             #target: i686-pc-windows-msvc | ||||
|             #code-target: | ||||
|             #win32-ia32 | ||||
|             #- os: windows-latest | ||||
|             #target: aarch64-pc-windows-msvc | ||||
|             #code-target: win32-arm64 | ||||
|           - os: ubuntu-latest | ||||
|             target: x86_64-unknown-linux-gnu | ||||
|             code-target: | ||||
|               linux-x64 | ||||
|               #- os: ubuntu-latest | ||||
|               #target: aarch64-unknown-linux-musl | ||||
|               #code-target: linux-arm64 | ||||
|             code-target: linux-x64 | ||||
|             #- os: ubuntu-latest | ||||
|             #target: aarch64-unknown-linux-musl | ||||
|             #code-target: linux-arm64 | ||||
|           - os: ubuntu-latest | ||||
|             target: aarch64-unknown-linux-gnu | ||||
|             code-target: linux-arm64 | ||||
| @ -105,41 +99,33 @@ jobs: | ||||
|           - os: macos-latest | ||||
|             target: aarch64-apple-darwin | ||||
|             code-target: darwin-arm64 | ||||
|  | ||||
|     name: build-release (${{ matrix.target }}) | ||||
|     name: kcl-language-server build-release (${{ matrix.target }}) | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     container: ${{ matrix.container }} | ||||
|  | ||||
|     env: | ||||
|       RA_TARGET: ${{ matrix.target }} | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||
|  | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           rm rust/rust-toolchain.toml | ||||
|  | ||||
|       - name: Install rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: rust | ||||
|           components: rust-src | ||||
|           target: ${{ matrix.target }} | ||||
|  | ||||
|       - name: Install Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: ".nvmrc" | ||||
|  | ||||
|       - name: Update apt repositories | ||||
|         if: matrix.target == 'aarch64-unknown-linux-gnu' || matrix.target == 'arm-unknown-linux-gnueabihf' || matrix.os == 'ubuntu-latest' | ||||
|         run: sudo apt-get update | ||||
|  | ||||
|       - if: ${{ matrix.os == 'ubuntu-latest' }} | ||||
|         name: Install deps | ||||
|         shell: bash | ||||
| @ -164,64 +150,53 @@ jobs: | ||||
|             zlib1g-dev | ||||
|  | ||||
|           cargo install cross | ||||
|  | ||||
|       - name: Install AArch64 target toolchain | ||||
|         if: matrix.target == 'aarch64-unknown-linux-gnu' | ||||
|         run: sudo apt-get install gcc-aarch64-linux-gnu | ||||
|  | ||||
|       - name: Install ARM target toolchain | ||||
|         if: matrix.target == 'arm-unknown-linux-gnueabihf' | ||||
|         run: sudo apt-get install gcc-arm-linux-gnueabihf | ||||
|  | ||||
|       - name: build | ||||
|         run: | | ||||
|           cd rust | ||||
|           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           # npm will symlink which will cause issues w tarballing later | ||||
|           yarn install | ||||
|  | ||||
|       - name: Package Extension (release) | ||||
|         if: startsWith(github.event.ref, 'refs/tags/') | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} | ||||
|  | ||||
|       - name: Package Extension (nightly) | ||||
|         if: startsWith(github.event.ref, 'refs/tags/') == false | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} --pre-release | ||||
|  | ||||
|       - name: remove server | ||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           rm -rf server | ||||
|  | ||||
|       - name: Package Extension (no server, release) | ||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix | ||||
|  | ||||
|       - name: Package Extension (no server, nightly) | ||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') == false | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix --pre-release | ||||
|  | ||||
|       - name: Upload artifacts | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: release-${{ matrix.target }} | ||||
|           path: ./rust/build | ||||
|  | ||||
|   build-release-x86_64-unknown-linux-musl: | ||||
|     name: build-release (x86_64-unknown-linux-musl) | ||||
|     name: kcl-language-server build-release (x86_64-unknown-linux-musl) | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       RA_TARGET: x86_64-unknown-linux-musl | ||||
| @ -231,7 +206,6 @@ jobs: | ||||
|       image: alpine:latest | ||||
|       volumes: | ||||
|         - /usr/local/cargo/registry:/usr/local/cargo/registry | ||||
|  | ||||
|     steps: | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
| @ -245,55 +219,46 @@ jobs: | ||||
|             nodejs \ | ||||
|             npm \ | ||||
|             yarn | ||||
|  | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||
|  | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           rm rust/rust-toolchain.toml | ||||
|  | ||||
|       - name: Install rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: rust | ||||
|           components: rust-src | ||||
|           target: ${{ matrix.target }} | ||||
|  | ||||
|       - name: build | ||||
|         run: | | ||||
|           cd rust | ||||
|           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           # npm will symlink which will cause issues w tarballing later | ||||
|           yarn install | ||||
|  | ||||
|       - name: Package Extension (release) | ||||
|         if: startsWith(github.event.ref, 'refs/tags/') | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 | ||||
|  | ||||
|       - name: Package Extension (release) | ||||
|         if: startsWith(github.event.ref, 'refs/tags/') == false | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 --pre-release | ||||
|  | ||||
|       - name: Upload artifacts | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: release-x86_64-unknown-linux-musl | ||||
|           path: ./rust/build | ||||
|  | ||||
|   publish: | ||||
|     name: publish | ||||
|     name: kcl-language-server (publish) | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: ["build-release", "build-release-x86_64-unknown-linux-musl"] | ||||
|     if: startsWith(github.event.ref, 'refs/tags') | ||||
| @ -301,22 +266,17 @@ jobs: | ||||
|       contents: write | ||||
|     steps: | ||||
|       - run: echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV | ||||
|  | ||||
|       - run: 'echo "TAG: $TAG"' | ||||
|  | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||
|  | ||||
|       - name: Install Nodejs | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: ".nvmrc" | ||||
|  | ||||
|       - run: echo "HEAD_SHA=$(git rev-parse HEAD)" >> $GITHUB_ENV | ||||
|       - run: 'echo "HEAD_SHA: $HEAD_SHA"' | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: release-aarch64-apple-darwin | ||||
| @ -344,35 +304,31 @@ jobs: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: release-x86_64-pc-windows-msvc | ||||
|           path: | ||||
|             rust/build | ||||
|             #- uses: actions/download-artifact@v4 | ||||
|             #with: | ||||
|             #name: release-i686-pc-windows-msvc | ||||
|             #path: | ||||
|             #build | ||||
|             #- uses: actions/download-artifact@v4 | ||||
|             #with: | ||||
|             #name: release-aarch64-pc-windows-msvc | ||||
|             #path: rust/build | ||||
|           path: rust/build | ||||
|           #- uses: actions/download-artifact@v4 | ||||
|           #with: | ||||
|           #name: release-i686-pc-windows-msvc | ||||
|           #path: | ||||
|           #build | ||||
|           #- uses: actions/download-artifact@v4 | ||||
|           #with: | ||||
|           #name: release-aarch64-pc-windows-msvc | ||||
|           #path: rust/build | ||||
|       - run: ls -al ./rust/build | ||||
|  | ||||
|       - name: Publish Release | ||||
|         uses: ./.github/actions/github-release | ||||
|         with: | ||||
|           files: "rust/build/*" | ||||
|           name: ${{ env.TAG }} | ||||
|           token: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       - name: move files to dir for upload | ||||
|         shell: bash | ||||
|         run: | | ||||
|           cd rust | ||||
|           mkdir -p releases/language-server/${{ env.TAG }} | ||||
|           cp -r build/* releases/language-server/${{ env.TAG }} | ||||
|  | ||||
|       - name: "Authenticate to Google Cloud" | ||||
|         uses: "google-github-actions/auth@v2.1.8" | ||||
|         uses: "google-github-actions/auth@v2.1.10" | ||||
|         with: | ||||
|           credentials_json: "${{ secrets.GOOGLE_CLOUD_DL_SA }}" | ||||
|       - name: Set up Cloud SDK | ||||
| @ -385,15 +341,12 @@ jobs: | ||||
|         with: | ||||
|           path: rust/releases | ||||
|           destination: dl.kittycad.io | ||||
|  | ||||
|       - run: rm rust/build/kcl-language-server-no-server.vsix | ||||
|  | ||||
|       - name: Publish Extension (Code Marketplace, release) | ||||
|         # token from https://dev.azure.com/kcl-language-server/ | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|           npx vsce publish --pat ${{ secrets.VSCE_PAT }} --packagePath ../build/kcl-language-server-*.vsix | ||||
|  | ||||
|       - name: Publish Extension (OpenVSX, release) | ||||
|         run: | | ||||
|           cd rust/kcl-language-server | ||||
|  | ||||
							
								
								
									
										38
									
								
								.github/workflows/kcl-python-bindings.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								.github/workflows/kcl-python-bindings.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,6 @@ | ||||
| #    maturin generate-ci github | ||||
| # | ||||
| name: kcl-python-bindings | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
| @ -27,16 +26,14 @@ on: | ||||
|       - '**.rs' | ||||
|       - .github/workflows/kcl-python-bindings.yml | ||||
|   workflow_dispatch: | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| jobs: | ||||
|   linux-x86_64: | ||||
|     name: kcl-python-bindings (linux-x86_64) | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
| @ -58,8 +55,8 @@ jobs: | ||||
|         with: | ||||
|           name: wheels-linux-x86_64 | ||||
|           path: rust/kcl-python-bindings/dist | ||||
|  | ||||
|   windows: | ||||
|     name: kcl-python-bindings (windows) | ||||
|     runs-on: windows-16-cores | ||||
|     strategy: | ||||
|       matrix: | ||||
| @ -84,8 +81,8 @@ jobs: | ||||
|         with: | ||||
|           name: wheels-windows-${{ matrix.target }} | ||||
|           path: rust/kcl-python-bindings/dist | ||||
|  | ||||
|   macos: | ||||
|     name: kcl-python-bindings (macos) | ||||
|     runs-on: macos-latest | ||||
|     strategy: | ||||
|       matrix: | ||||
| @ -110,13 +107,13 @@ jobs: | ||||
|         with: | ||||
|           name: wheels-macos-${{ matrix.target }} | ||||
|           path: rust/kcl-python-bindings/dist | ||||
|  | ||||
|   test: | ||||
|     name: kcl-python-bindings (test) | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: Install uv | ||||
|         uses: astral-sh/setup-uv@v5 | ||||
|         uses: astral-sh/setup-uv@v6 | ||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|       - uses: taiki-e/install-action@just | ||||
|       - name: Run tests | ||||
| @ -127,19 +124,19 @@ jobs: | ||||
|         env: | ||||
|           KITTYCAD_API_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|           ZOO_HOST: https://api.dev.zoo.dev | ||||
|  | ||||
|   sdist: | ||||
|     name: kcl-python-bindings (sdist) | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: Install the latest version of uv | ||||
|         uses: astral-sh/setup-uv@v5 | ||||
|         uses: astral-sh/setup-uv@v6 | ||||
|       - name: Install codespell | ||||
|         run: | | ||||
|             uv venv .venv | ||||
|             echo "VIRTUAL_ENV=.venv" >> $GITHUB_ENV | ||||
|             echo "$PWD/.venv/bin" >> $GITHUB_PATH | ||||
|             uv pip install pip --upgrade | ||||
|           uv venv .venv | ||||
|           echo "VIRTUAL_ENV=.venv" >> $GITHUB_ENV | ||||
|           echo "$PWD/.venv/bin" >> $GITHUB_PATH | ||||
|           uv pip install pip --upgrade | ||||
|       - name: Build sdist | ||||
|         uses: PyO3/maturin-action@v1 | ||||
|         with: | ||||
| @ -151,7 +148,6 @@ jobs: | ||||
|         with: | ||||
|           name: wheels-sdist | ||||
|           path: rust/kcl-python-bindings/dist | ||||
|  | ||||
|   release: | ||||
|     name: Release | ||||
|     runs-on: ubuntu-latest | ||||
| @ -165,14 +161,14 @@ jobs: | ||||
|         with: | ||||
|           path: rust/kcl-python-bindings | ||||
|       - name: Install the latest version of uv | ||||
|         uses: astral-sh/setup-uv@v5 | ||||
|         uses: astral-sh/setup-uv@v6 | ||||
|       - name: do uv things | ||||
|         run: | | ||||
|             cd rust/kcl-python-bindings | ||||
|             uv venv .venv | ||||
|             echo "VIRTUAL_ENV=.venv" >> $GITHUB_ENV | ||||
|             echo "$PWD/.venv/bin" >> $GITHUB_PATH | ||||
|             uv pip install pip --upgrade | ||||
|           cd rust/kcl-python-bindings | ||||
|           uv venv .venv | ||||
|           echo "VIRTUAL_ENV=.venv" >> $GITHUB_ENV | ||||
|           echo "$PWD/.venv/bin" >> $GITHUB_PATH | ||||
|           uv pip install pip --upgrade | ||||
|       - name: Publish to PyPI | ||||
|         uses: PyO3/maturin-action@v1 | ||||
|         env: | ||||
|  | ||||
							
								
								
									
										3
									
								
								.github/workflows/nightly-rust-toolchain.toml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/nightly-rust-toolchain.toml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| [toolchain] | ||||
| channel = "nightly" | ||||
| components = ["rustfmt"] | ||||
							
								
								
									
										14
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							| @ -31,42 +31,42 @@ jobs: | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-arm64-win | ||||
|           name: out-arm64-windows | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|            | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-x64-win | ||||
|           name: out-x64-windows | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-yml-win | ||||
|           name: out-yml-windows | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-arm64-mac | ||||
|           name: out-arm64-macos | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-x64-mac | ||||
|           name: out-x64-macos | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: out-yml-mac | ||||
|           name: out-yml-macos | ||||
|           path: out | ||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
| @ -108,7 +108,7 @@ jobs: | ||||
|         run: npm run files:set-notes | ||||
|  | ||||
|       - name: Authenticate to Google Cloud | ||||
|         uses: 'google-github-actions/auth@v2.1.8' | ||||
|         uses: 'google-github-actions/auth@v2.1.10' | ||||
|         with: | ||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||
|  | ||||
|  | ||||
							
								
								
									
										191
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										191
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -28,53 +28,7 @@ jobs: | ||||
|       - run: npm run fmt:check | ||||
|  | ||||
|   npm-build-wasm: | ||||
|     # Build the wasm blob once on the fastest runner. | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         run: npm install | ||||
|  | ||||
|       - name: Use correct Rust toolchain | ||||
|         shell: bash | ||||
|         run: | | ||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||
|  | ||||
|       - name: Install rust | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|  | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Rust Cache | ||||
|         uses: Swatinem/rust-cache@v2 | ||||
|         with: | ||||
|           workspaces: './rust' | ||||
|  | ||||
|       - name: Build Wasm | ||||
|         shell: bash | ||||
|         run: npm run build:wasm | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: prepared-wasm | ||||
|           path: | | ||||
|             rust/kcl-wasm-lib/pkg/kcl_wasm_lib* | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: prepared-ts-rs-bindings | ||||
|           path: | | ||||
|             rust/kcl-lib/bindings/* | ||||
|     uses: ./.github/workflows/build-wasm.yml | ||||
|  | ||||
|   npm-tsc: | ||||
|     runs-on: ubuntu-latest | ||||
| @ -166,6 +120,36 @@ jobs: | ||||
|  | ||||
|       - run: npm run circular-deps:diff | ||||
|  | ||||
|   npm-url-checker: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: npm-build-wasm | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|       - run: npm install | ||||
|  | ||||
|       - name: Download all artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Copy prepared ts-rs bindings | ||||
|         run: | | ||||
|           ls -R prepared-ts-rs-bindings | ||||
|           mkdir rust/kcl-lib/bindings | ||||
|           cp -r prepared-ts-rs-bindings/* rust/kcl-lib/bindings/ | ||||
|  | ||||
|       - run: npm run url-checker:diff | ||||
|  | ||||
|   python-codespell: | ||||
|     runs-on: ubuntu-22.04 | ||||
|     steps: | ||||
| @ -173,116 +157,3 @@ jobs: | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Run codespell | ||||
|         uses: crate-ci/typos@v1.32.0 | ||||
|  | ||||
|   npm-unit-test-kcl-samples: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: npm-build-wasm | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - run: npm install | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Download all artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Copy prepared ts-rs bindings | ||||
|         run: | | ||||
|           ls -R prepared-ts-rs-bindings | ||||
|           mkdir rust/kcl-lib/bindings | ||||
|           cp -r prepared-ts-rs-bindings/* rust/kcl-lib/bindings/ | ||||
|  | ||||
|       - run: npm run simpleserver:bg | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|  | ||||
|       - name: Install Chromium Browser | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: npm run playwright install chromium --with-deps | ||||
|  | ||||
|       - name: run unit tests for kcl samples | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: npm run test:unit:kcl-samples | ||||
|         env: | ||||
|           VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||
|  | ||||
|   npm-unit-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: npm-build-wasm | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - run: npm install | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Download all artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Copy prepared ts-rs bindings | ||||
|         run: | | ||||
|           ls -R prepared-ts-rs-bindings | ||||
|           mkdir rust/kcl-lib/bindings | ||||
|           cp -r prepared-ts-rs-bindings/* rust/kcl-lib/bindings/ | ||||
|  | ||||
|       - run: npm run simpleserver:bg | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|  | ||||
|       - name: Install Chromium Browser | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: npm run playwright install chromium --with-deps | ||||
|  | ||||
|       - name: Run unit tests | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: xvfb-run -a npm run test:unit | ||||
|         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 }} | ||||
|  | ||||
							
								
								
									
										39
									
								
								.github/workflows/tag-nightly.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								.github/workflows/tag-nightly.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,39 +0,0 @@ | ||||
| name: tag-nightly | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
| on: | ||||
|   schedule: | ||||
|     - cron: '0 4 * * *' | ||||
|   # Daily at 04:00 AM UTC | ||||
|   # Will checkout the last commit from the default branch (main as of 2023-10-04) | ||||
|    | ||||
| jobs: | ||||
|   tag-nightly: | ||||
|     runs-on: ubuntu-22.04 | ||||
|     steps: | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
|         id: app-token | ||||
|         with: | ||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||
|           private-key: ${{ secrets.MODELING_APP_GH_APP_PRIVATE_KEY }} | ||||
|           owner: ${{ github.repository_owner }} | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ steps.app-token.outputs.token }} | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|  | ||||
|       - run: npm install | ||||
|  | ||||
|       - name: Push tag | ||||
|         run: | | ||||
|           VERSION_NO_V=$(date +'%-y.%-m.%-d') | ||||
|           TAG="nightly-v$VERSION_NO_V" | ||||
|           git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||||
|           git config --local user.name "github-actions[bot]" | ||||
|           git tag $TAG | ||||
|           git push origin tag $TAG | ||||
							
								
								
									
										124
									
								
								.github/workflows/unit-tests.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								.github/workflows/unit-tests.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,124 @@ | ||||
| name: Unit Tests | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|   pull-requests: write | ||||
|   actions: read | ||||
|  | ||||
| jobs: | ||||
|   npm-build-wasm: | ||||
|     uses: ./.github/workflows/build-wasm.yml | ||||
|  | ||||
|   npm-test-unit: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: npm-build-wasm | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - run: npm install | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Download all artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Copy prepared ts-rs bindings | ||||
|         run: | | ||||
|           ls -R prepared-ts-rs-bindings | ||||
|           mkdir rust/kcl-lib/bindings | ||||
|           cp -r prepared-ts-rs-bindings/* rust/kcl-lib/bindings/ | ||||
|  | ||||
|       - run: npm run simpleserver:bg | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|  | ||||
|       - name: Install Chromium Browser | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: npm run playwright install chromium --with-deps | ||||
|  | ||||
|       - name: Run unit tests | ||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||
|         run: xvfb-run -a npm run test:unit | ||||
|         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 }} | ||||
|  | ||||
|   npm-test-unit-components: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: npm-build-wasm | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'npm' | ||||
|  | ||||
|       - run: npm install | ||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
|       - name: Download all artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|  | ||||
|       - name: Copy prepared wasm | ||||
|         run: | | ||||
|           ls -R prepared-wasm | ||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||
|           mkdir rust/kcl-wasm-lib/pkg | ||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||
|  | ||||
|       - name: Copy prepared ts-rs bindings | ||||
|         run: | | ||||
|           ls -R prepared-ts-rs-bindings | ||||
|           mkdir rust/kcl-lib/bindings | ||||
|           cp -r prepared-ts-rs-bindings/* rust/kcl-lib/bindings/ | ||||
|  | ||||
|       - name: Run component tests | ||||
|         run: npm run test:unit:components | ||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -58,6 +58,8 @@ trace.zip | ||||
| /public/kcl-samples/.github | ||||
| /public/kcl-samples/screenshots/main.kcl | ||||
| /public/kcl-samples/step/main.kcl | ||||
| /public/kcl-samples/internal | ||||
| /rust/kcl-lib/tests/kcl_samples/internal | ||||
| /test-results/ | ||||
| /playwright-report/ | ||||
| /blob-report/ | ||||
| @ -85,4 +87,4 @@ venv | ||||
|  | ||||
| .vscode-test | ||||
| .biome/ | ||||
| .million | ||||
| .million | ||||
							
								
								
									
										251
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										251
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| # Contributor Guide | ||||
|  | ||||
| ## Running a development build | ||||
| ## Installing dependencies | ||||
|  | ||||
| Install a node version manager such as [fnm](https://github.com/Schniz/fnm?tab=readme-ov-#installation). | ||||
|  | ||||
| @ -31,7 +31,9 @@ npm run install:rust:windows | ||||
| npm run install:wasm-pack:cargo | ||||
| ``` | ||||
|  | ||||
| Then to build the WASM layer, run: | ||||
| ## Building the app | ||||
|  | ||||
| To build the WASM layer, run: | ||||
|  | ||||
| ``` | ||||
| # macOS/Linux | ||||
| @ -74,7 +76,7 @@ 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". | ||||
|  | ||||
| ## Desktop | ||||
| ### Developing with Electron | ||||
|  | ||||
| To spin up the desktop app, `npm install` and `npm run build:wasm` need to have been done before hand then: | ||||
|  | ||||
| @ -88,113 +90,7 @@ Devtools can be opened with the usual Command-Option-I (macOS) or Ctrl-Shift-I ( | ||||
|  | ||||
| To package the app for your platform with electron-builder, run `npm run tronb:package:dev` (or `npm run tronb:package:prod` to point to the .env.production variables). | ||||
|  | ||||
| ## 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 | ||||
| npm install | ||||
| npm run build:wasm | ||||
| npm start | ||||
| ``` | ||||
|  | ||||
| ## Before submitting a PR | ||||
|  | ||||
| Before you submit a contribution PR to this repo, please ensure that: | ||||
|  | ||||
| - There is a corresponding issue for the changes you want to make, so that discussion of approach can be had before work begins. | ||||
| - You have separated out refactoring commits from feature commits as much as possible | ||||
| - You have run all of the following commands locally: | ||||
|   - `npm run fmt` | ||||
|   - `npm run tsc` | ||||
|   - `npm run test` | ||||
|   - Here they are all together: `npm run fmt && npm run tsc && npm run test` | ||||
|  | ||||
| ## Release a new version | ||||
|  | ||||
| #### 1. Create a 'Cut release $VERSION' issue | ||||
|  | ||||
| It will be used to document changelog discussions and release testing. | ||||
|  | ||||
| https://github.com/KittyCAD/modeling-app/issues/new | ||||
|  | ||||
| #### 2. Push a new tag | ||||
|  | ||||
| Create a new tag and push it to the repo. The `semantic-release.sh` script will automatically bump the minor part, which we use the most. For instance going from `v0.27.0` to `v0.28.0`. | ||||
|  | ||||
| ``` | ||||
| VERSION=$(./scripts/semantic-release.sh) | ||||
| git tag $VERSION | ||||
| git push origin --tags | ||||
| ``` | ||||
|  | ||||
| This will trigger the `build-apps` workflow, set the version, build & sign the apps, and generate release files as well as updater-test artifacts. | ||||
|  | ||||
| The workflow should be listed right away [in this list](https://github.com/KittyCAD/modeling-app/actions/workflows/build-apps.yml?query=event%3Apush)). | ||||
|  | ||||
| #### 3. Manually test artifacts | ||||
|  | ||||
| ##### Release builds | ||||
|  | ||||
| The release builds can be found under the `out-{arch}-{platform}` zip files, at the very bottom of the `build-apps` summary page for the workflow (triggered by the tag in 2.). | ||||
|  | ||||
| Manually test against this [list](https://github.com/KittyCAD/modeling-app/issues/3588) across Windows, MacOS, Linux and posting results as comments in the issue. | ||||
|  | ||||
| ##### Updater-test builds | ||||
|  | ||||
| The other `build-apps` output in the release `build-apps` workflow (triggered by 2.) is `updater-test-{arch}-{platform}`. It's a semi-automated process: for macOS, Windows, and Linux, download the corresponding updater-test artifact file, install the app, run it, expect an updater prompt to a dummy v0.255.255, install it and check that the app comes back at that version. | ||||
|  | ||||
| The only difference with these builds is that they point to a different update location on the release bucket, with this dummy v0.255.255 always available. This helps ensuring that the version we release will be able to update to the next one available. | ||||
|  | ||||
| If the prompt doesn't show up, start the app in command line to grab the electron-updater logs. This is likely an issue with the current build that needs addressing (or the updater-test location in the storage bucket). | ||||
|  | ||||
| ``` | ||||
| # Windows (PowerShell) | ||||
| & 'C:\Program Files\Zoo Design Studio\Zoo Design Studio.exe' | ||||
|  | ||||
| # macOS | ||||
| /Applications/Zoo\ Modeling\ App.app/Contents/MacOS/Zoo\ Modeling\ App | ||||
|  | ||||
| # Linux | ||||
| ./Zoo Design Studio-{version}-{arch}-linux.AppImage | ||||
| ``` | ||||
|  | ||||
| #### 4. Publish the release | ||||
|  | ||||
| Head over to https://github.com/KittyCAD/modeling-app/releases/new, pick the newly created tag and type it in the _Release title_ field as well. | ||||
|  | ||||
| Hit _Generate release notes_ as a starting point to discuss the changelog in the issue. Once done, make sure _Set as the latest release_ is checked, and hit _Publish release_. | ||||
|  | ||||
| A new `publish-apps-release` will kick in and you should be able to find it [here](https://github.com/KittyCAD/modeling-app/actions?query=event%3Arelease). On success, the files will be uploaded to the public bucket as well as to the GitHub release, and the announcement on Discord will be sent. | ||||
|  | ||||
| #### 5. Close the issue | ||||
|  | ||||
| If everything is well and the release is out to the public, the issue tracking the release shall be closed. | ||||
|  | ||||
| ## Fuzzing the parser | ||||
|  | ||||
| Make sure you install cargo fuzz: | ||||
|  | ||||
| ```bash | ||||
| $ cargo install cargo-fuzz | ||||
| ``` | ||||
|  | ||||
| ```bash | ||||
| $ cd rust/kcl-lib | ||||
|  | ||||
| # list the fuzz targets | ||||
| $ cargo fuzz list | ||||
|  | ||||
| # run the parser fuzzer | ||||
| $ 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). | ||||
|  | ||||
| ## Tests | ||||
| ## Running tests | ||||
|  | ||||
| ### Playwright tests | ||||
|  | ||||
| @ -204,7 +100,7 @@ Prepare these system dependencies: | ||||
|  | ||||
| #### Snapshot tests (Google Chrome on Ubuntu only) | ||||
|  | ||||
| Only Ubunu and Google Chrome is supported for the set of tests evaluating screenshot snapshots. | ||||
| Only Ubuntu and Google Chrome is supported for the set of tests evaluating screenshot snapshots. | ||||
| If you don't run Ubuntu locally or in a VM, you may use a GitHub Codespace. | ||||
| ``` | ||||
| npm run playwright -- install chrome | ||||
| @ -212,14 +108,21 @@ npm run test:snapshots | ||||
| ``` | ||||
| You may use `-- --update-snapshots` as needed. | ||||
|  | ||||
| #### Electron flow tests (Chromium on Ubuntu, macOS, Windows) | ||||
| #### Desktop tests (Electron on all platforms) | ||||
|  | ||||
| ``` | ||||
| npm run playwright -- install chromium | ||||
| npm run test:playwright:electron:local | ||||
| npm run test:e2e:desktop:local | ||||
| ``` | ||||
|  | ||||
| You may use `-- -g "my test"` to match specific test titles, or `-- path/to/file.spec.ts` for a test file. | ||||
|  | ||||
| #### Web tests (Google Chrome on all platforms) | ||||
|  | ||||
| ``` | ||||
| npm run test:e2e:web | ||||
| ``` | ||||
|  | ||||
| #### Debugger | ||||
|  | ||||
| However, if you want a debugger I recommend using VSCode and the `playwright` extension, as the above command is a cruder debugger that steps into every function call which is annoying. | ||||
| @ -305,8 +208,130 @@ then run tests that target the KCL language: | ||||
| npm run test:rust | ||||
| ``` | ||||
|  | ||||
| ### Fuzzing the parser | ||||
|  | ||||
| Make sure you install cargo fuzz: | ||||
|  | ||||
| ```bash | ||||
| $ cargo install cargo-fuzz | ||||
| ``` | ||||
|  | ||||
| ```bash | ||||
| $ cd rust/kcl-lib | ||||
|  | ||||
| # list the fuzz targets | ||||
| $ cargo fuzz list | ||||
|  | ||||
| # run the parser fuzzer | ||||
| $ 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). | ||||
|  | ||||
| ### Logging | ||||
|  | ||||
| To display logging (to the terminal or console) set `ZOO_LOG=1`. This will log some warnings and simple performance metrics. To view these in test runs, use `-- --nocapture`. | ||||
|  | ||||
| To enable memory metrics, build with `--features dhat-heap`. | ||||
|  | ||||
| ## Running scripts | ||||
|  | ||||
| There are multiple scripts under the folder path `./scripts` which can be used in various settings. | ||||
|  | ||||
| ### Pattern for a static file, npm run commands, and CI-CD checks | ||||
|  | ||||
| If you want to implement a static checker follow this pattern. Two static checkers we have are circular dependency checks in our typescript code and url checker to see if any hard coded URL is the typescript application 404s. We have a set of known files in `./scripts/known/*.txt` which is the baseline. | ||||
|  | ||||
| If you improve the baseline, run the overwrite command and commit the new smaller baseline. Try not to make the baseline bigger, the CI CD will complain. | ||||
| These baselines are to hold us to higher standards and help implement automated testing against the repository | ||||
|  | ||||
| #### Output result to stdout | ||||
| - `npm run circular-deps` | ||||
| - `npm run url-checker` | ||||
|  | ||||
| - create a `<name>.sh` file that will run the static checker then output the result to `stdout` | ||||
|  | ||||
| #### Overwrite result to known .txt file on disk | ||||
|  | ||||
| If the application needs to overwrite the known file on disk use this pattern. This known .txt file will be source controlled as the baseline | ||||
|  | ||||
| - `npm run circular-deps:overwrite` | ||||
| - `npm run url-checker:overwrite` | ||||
|  | ||||
| #### Diff baseline and current  | ||||
|  | ||||
| These commands will write a /tmp/ file on disk and compare it to the known file in the repository. This command will also be used in the CI CD pipeline for automated checks | ||||
|  | ||||
| - create a `diff-<name>.sh` file that is the script to diff your tmp file to the baseline | ||||
| e.g. `diff-url-checker.sh` | ||||
| ```bash | ||||
| #!/bin/bash | ||||
| set -euo pipefail | ||||
|  | ||||
| npm run url-checker > /tmp/urls.txt | ||||
| diff --ignore-blank-lines -w /tmp/urls.txt ./scripts/known/urls.txt | ||||
| ``` | ||||
|  | ||||
| - `npm run circular-deps:diff` | ||||
| - `npm run url-checker:diff` | ||||
|  | ||||
| ## Proposing changes | ||||
|  | ||||
| Before you submit a contribution PR to this repo, please ensure that: | ||||
|  | ||||
| - There is a corresponding issue for the changes you want to make, so that discussion of approach can be had before work begins. | ||||
| - You have separated out refactoring commits from feature commits as much as possible | ||||
| - You have run all of the following commands locally: | ||||
|   - `npm run fmt` | ||||
|   - `npm run tsc` | ||||
|   - `npm run test` | ||||
|   - Here they are all together: `npm run fmt && npm run tsc && npm run test` | ||||
|  | ||||
| ## Shipping releases | ||||
|  | ||||
| #### 1. Create a 'Cut release $VERSION' issue | ||||
|  | ||||
| Use the **Release** issue template. | ||||
| This will be used to facilitate changelog discussions and release testing. | ||||
|  | ||||
| https://github.com/KittyCAD/modeling-app/issues/new | ||||
|  | ||||
| #### 2. Push a new tag | ||||
|  | ||||
| Decide on a `v`-prefixed semver `VERSION` (e.g. `v1.2.3`) with the team and tag the repo on the latest main: | ||||
|  | ||||
| ``` | ||||
| git tag $VERSION --message="" | ||||
| git push origin $VERSION | ||||
| ``` | ||||
|  | ||||
| This will trigger the `build-apps` workflow to set the version, build & sign the apps, and generate release files. | ||||
|  | ||||
| The workflow should be listed right away [in this list](https://github.com/KittyCAD/modeling-app/actions/workflows/build-apps.yml?query=event%3Apush). | ||||
|  | ||||
| #### 3. Manually test artifacts | ||||
|  | ||||
| The release builds can be found under the `out-{arch}-{platform}` zip files, at the very bottom of the `build-apps` summary page for the workflow (triggered by the tag in step 2). | ||||
|  | ||||
| Assign someone to each section of the manual checklist generated by the issue template. | ||||
|  | ||||
| #### 4. Bump the KCL version | ||||
|  | ||||
| Follow the instructions [here](./rust/README.md) to publish new crates. | ||||
| This ensures that the KCL accepted by the app is also accepted by the CLI. | ||||
|  | ||||
| If there are documentation changes, merge the corresponding Dependabot PRs [here](https://github.com/KittyCAD/website/pulls/app%2Fdependabot) for the website. | ||||
| You can trigger Dependabot to check for updates [here](https://github.com/KittyCAD/website/network/updates/17261214/jobs). | ||||
|  | ||||
| #### 5. Publish the release | ||||
|  | ||||
| Head over to https://github.com/KittyCAD/modeling-app/releases/new, pick the newly created tag and type it in the **Release title** field as well. | ||||
|  | ||||
| Click **Generate release notes** as a starting point to discuss the changelog in the issue. Once done, make sure **Set as the latest release** is checked, and click **Publish release**. | ||||
|  | ||||
| A new `publish-apps-release` workflow will start and you should be able to find it [here](https://github.com/KittyCAD/modeling-app/actions?query=event%3Arelease). On success, the files will be uploaded to the public bucket as well as to the GitHub release, and the announcement on Discord will be sent. | ||||
|  | ||||
| #### 6. Close the issue | ||||
|  | ||||
| If everything is well and the release is out to the public, the issue tracking the release shall be closed. | ||||
|  | ||||
							
								
								
									
										10
									
								
								INSTALL.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								INSTALL.md
									
									
									
									
									
								
							| @ -4,7 +4,7 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | ||||
|  | ||||
| ## Windows | ||||
|  | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/modeling-app/download) for Windows and for your processor type. | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/design-studio/download) for Windows and for your processor type. | ||||
|  | ||||
| 2. Once downloaded, run the installer `Zoo Design Studio-{version}-{arch}-win.exe` which should take a few seconds. | ||||
|  | ||||
| @ -12,16 +12,16 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | ||||
|  | ||||
| ## macOS | ||||
|  | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/modeling-app/download) for macOS and for your processor type. | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/design-studio/download) for macOS and for your processor type. | ||||
|  | ||||
| 2. Once downloaded, open the disk image `Zoo Design Studio-{version}-{arch}-mac.dmg` and drag the applications to your `Applications` directory. | ||||
|  | ||||
| 3. You can then open your `Applications` directory and double-click on `Zoo Design Studio` to open. | ||||
|  | ||||
|  | ||||
| ## Linux  | ||||
| ## Linux | ||||
|  | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/modeling-app/download) for Linux and for your processor type. | ||||
| 1. Download the [Zoo Design Studio installer](https://zoo.dev/design-studio/download) for Linux and for your processor type. | ||||
|  | ||||
| 2. Install the dependencies needed to run the [AppImage format](https://appimage.org/). | ||||
|     -  On Ubuntu, install the FUSE library with these commands in a terminal. | ||||
| @ -29,7 +29,7 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | ||||
|        sudo apt update | ||||
|        sudo apt install libfuse2 | ||||
|        ``` | ||||
|     - Optionally, follow [these steps](https://github.com/probonopd/go-appimage/blob/master/src/appimaged/README.md#initial-setup) to install `appimaged`. It is a daemon that makes interacting with AppImage files more seamless.  | ||||
|     - Optionally, follow [these steps](https://github.com/probonopd/go-appimage/blob/master/src/appimaged/README.md#initial-setup) to install `appimaged`. It is a daemon that makes interacting with AppImage files more seamless. | ||||
|     - Once installed, copy the downloaded `Zoo Design Studio-{version}-{arch}-linux.AppImage` to the directory of your choice, for instance `~/Applications`. | ||||
|  | ||||
|    - `appimaged` should automatically find it and make it executable. If not, run: | ||||
|  | ||||
							
								
								
									
										21
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								Makefile
									
									
									
									
									
								
							| @ -23,6 +23,7 @@ endif | ||||
| install: node_modules/.package-lock.json $(CARGO) $(WASM_PACK) ## Install dependencies | ||||
|  | ||||
| node_modules/.package-lock.json: package.json package-lock.json | ||||
| 	npm prune | ||||
| 	npm install | ||||
|  | ||||
| $(CARGO): | ||||
| @ -43,15 +44,15 @@ endif | ||||
| # BUILD | ||||
|  | ||||
| CARGO_SOURCES := rust/.cargo/config.toml $(wildcard rust/Cargo.*) $(wildcard rust/**/Cargo.*) | ||||
| KCL_SOURCES := $(wildcard public/kcl-samples/**/*.kcl) | ||||
| RUST_SOURCES := $(wildcard rust/**/*.rs) | ||||
|  | ||||
| REACT_SOURCES := $(wildcard src/*.tsx) $(wildcard src/**/*.tsx) | ||||
| TYPESCRIPT_SOURCES := tsconfig.* $(wildcard src/*.ts) $(wildcard src/**/*.ts) | ||||
| VITE_SOURCES := $(wildcard vite.*) $(wildcard vite/**/*.tsx) | ||||
|  | ||||
|  | ||||
| .PHONY: build | ||||
| build: install public/kcl_wasm_lib_bg.wasm .vite/build/main.js | ||||
| build: install public/kcl_wasm_lib_bg.wasm public/kcl-samples/manifest.json .vite/build/main.js | ||||
|  | ||||
| public/kcl_wasm_lib_bg.wasm: $(CARGO_SOURCES) $(RUST_SOURCES) | ||||
| ifdef WINDOWS | ||||
| @ -60,6 +61,12 @@ else | ||||
| 	npm run build:wasm:dev | ||||
| endif | ||||
|  | ||||
| public/kcl-samples/manifest.json: $(KCL_SOURCES) | ||||
| ifndef WINDOWS | ||||
| 	cd rust/kcl-lib && EXPECTORATE=overwrite cargo test generate_manifest | ||||
| 	@ touch $@ | ||||
| endif | ||||
|  | ||||
| .vite/build/main.js: $(REACT_SOURCES) $(TYPESCRIPT_SOURCES) $(VITE_SOURCES) | ||||
| 	npm run tronb:vite:dev | ||||
|  | ||||
| @ -107,6 +114,7 @@ test: test-unit test-e2e | ||||
| .PHONY: test-unit | ||||
| test-unit: install ## Run the unit tests | ||||
| 	npm run test:rust | ||||
| 	npm run test:unit:components | ||||
| 	@ curl -fs localhost:3000 >/dev/null || ( echo "Error: localhost:3000 not available, 'make run-web' first" && exit 1 ) | ||||
| 	npm run test:unit | ||||
|  | ||||
| @ -115,19 +123,18 @@ test-e2e: test-e2e-$(TARGET) | ||||
|  | ||||
| .PHONY: test-e2e-web | ||||
| test-e2e-web: install build ## Run the web e2e tests | ||||
| 	@ curl -fs localhost:3000 >/dev/null || ( echo "Error: localhost:3000 not available, 'make run-web' first" && exit 1 ) | ||||
| ifdef E2E_GREP | ||||
| 	npm run chrome:test -- --headed --grep="$(E2E_GREP)" --max-failures=$(E2E_FAILURES) | ||||
| 	npm run test:e2e:web -- --headed --grep="$(E2E_GREP)" --max-failures=$(E2E_FAILURES) | ||||
| else | ||||
| 	npm run chrome:test -- --headed --workers='100%' | ||||
| 	npm run test:e2e:web -- --headed --workers='100%' | ||||
| endif | ||||
|  | ||||
| .PHONY: test-e2e-desktop | ||||
| test-e2e-desktop: install build ## Run the desktop e2e tests | ||||
| ifdef E2E_GREP | ||||
| 	npm run test:playwright:electron -- --grep="$(E2E_GREP)" --max-failures=$(E2E_FAILURES) | ||||
| 	npm run test:e2e:desktop -- --grep="$(E2E_GREP)" --max-failures=$(E2E_FAILURES) | ||||
| else | ||||
| 	npm run test:playwright:electron -- --workers='100%' | ||||
| 	npm run test:e2e:desktop -- --workers='100%' | ||||
| endif | ||||
|  | ||||
| ############################################################################### | ||||
|  | ||||
							
								
								
									
										14
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								README.md
									
									
									
									
									
								
							| @ -2,7 +2,7 @@ | ||||
|  | ||||
| # Zoo Design Studio | ||||
|  | ||||
| [zoo.dev/modeling-app](https://zoo.dev/modeling-app) | ||||
| [zoo.dev/design-studio](https://zoo.dev/design-studio) | ||||
|  | ||||
| A CAD application from the future, brought to you by the [Zoo team](https://zoo.dev). | ||||
|  | ||||
| @ -34,20 +34,14 @@ The 3D view in Design Studio is just a video stream from our hosted geometry eng | ||||
|   - WebSockets (via [KittyCAD TS client](https://github.com/KittyCAD/kittycad.ts)) | ||||
| - Code Editor | ||||
|   - [CodeMirror](https://codemirror.net/) | ||||
|   - Custom WASM LSP Server | ||||
|   - [Custom WASM LSP Server](https://github.com/KittyCAD/modeling-app/tree/main/rust/kcl-lib/src/lsp/kcl) | ||||
| - Modeling | ||||
|   - [KittyCAD TypeScript client](https://github.com/KittyCAD/kittycad.ts) | ||||
|  | ||||
| ## Get Started | ||||
|  | ||||
| We recommend downloading the latest application binary from our [releases](https://github.com/KittyCAD/modeling-app/releases) page. If you don't see your platform or architecture supported there, please file an issue. | ||||
|  | ||||
| If you'd like to try out upcoming changes sooner, you can also download those from our [nightly releases](https://zoo.dev/modeling-app/download/nightly) page. | ||||
| We recommend downloading the latest application binary from our [website](https://zoo.dev/design-studio/download). If you don't see your platform or architecture supported there, please file an issue. See the [installation guide](INSTALL.md) for additional instructions. | ||||
|  | ||||
| ## Developing | ||||
|  | ||||
| Finally, if you'd like to run a development build or contribute to the project, please visit our [contributor guide](CONTRIBUTING.md) to get started. | ||||
|  | ||||
| ## KCL | ||||
|  | ||||
| To contribute to the KittyCAD Language, see the [README](https://github.com/KittyCAD/modeling-app/tree/main/rust/kcl-lib) for KCL. | ||||
| Finally, if you'd like to run a development build or contribute to the project, please visit our [contributor guide](CONTRIBUTING.md) to get started. To contribute to the KittyCAD Language, see the dedicated [readme](rust/kcl-lib/README.md) for KCL. | ||||
|  | ||||
| @ -21,7 +21,7 @@ extend-exclude = [ | ||||
| ] | ||||
|  | ||||
| [default.extend-words] | ||||
| metalness = "metalness" # appearance API  | ||||
| metalness = "metalness" # appearance API | ||||
| Hom = "Hom" # short for homogenous | ||||
| typ = "typ" # used to declare a variable named 'type' which is a reserved keyword in Rust | ||||
| ue = "ue" # short for UnaryExpression | ||||
| @ -29,6 +29,7 @@ THRE = "THRE" # Weird bug that wrongly detects THREEjs as a typo | ||||
| nwo = "nwo" # don't know what this is about tbh | ||||
| "ot" = "ot" # some abbreviation, idk what | ||||
| "oe" = "oe" # some abbreviation, idk what | ||||
| "colinear" = "colinear" # some engine shit, kidding | ||||
|  | ||||
| [default] | ||||
| extend-ignore-identifiers-re = [ | ||||
|  | ||||
| Before Width: | Height: | Size: 119 KiB After Width: | Height: | Size: 119 KiB | 
| Before Width: | Height: | Size: 259 KiB After Width: | Height: | Size: 259 KiB | 
							
								
								
									
										53
									
								
								docs/kcl-lang/arithmetic.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								docs/kcl-lang/arithmetic.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| --- | ||||
| title: "Arithmetic and logic" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| KCL supports the usual arithmetic operators on numbers and logic operators on booleans: | ||||
|  | ||||
| | Operator | Meaning | | ||||
| |----------|---------| | ||||
| | `+` | Addition | | ||||
| | `-` | Subtraction or unary negation | | ||||
| | `*` | Multiplication | | ||||
| | `/` | Division | | ||||
| | `%` | Modulus aka remainder | | ||||
| | `^` | Power, e.g., `x ^ 2` means `x` squared | | ||||
| | `&` | Logical 'and' | | ||||
| | `|` | Logical 'or' | | ||||
| | `!` | Unary logical 'not' | | ||||
|  | ||||
| KCL also supports comparsion operators which operate on numbers and produce booleans: | ||||
|  | ||||
| | Operator | Meaning | | ||||
| |----------|---------| | ||||
| | `==` | Equal | | ||||
| | `!=` | Not equal | | ||||
| | `<` | Less than | | ||||
| | `>` | Greater than | | ||||
| | `<=` | Less than or equal | | ||||
| | `>=` | Greater than or equal | | ||||
|  | ||||
| Arithmetics and logic expressions can be arbitrairly combined with the usual rules of associativity and precedence, e.g., | ||||
|  | ||||
| ``` | ||||
| myMathExpression = 3 + 1 * 2 / 3 - 7 | ||||
| ``` | ||||
|  | ||||
| You can also nest expressions in parenthesis: | ||||
|  | ||||
| ``` | ||||
| myMathExpression = 3 + (1 * 2 / (3 - 7)) | ||||
| ``` | ||||
|  | ||||
| KCL numbers are implemented using [floating point numbers](https://en.wikipedia.org/wiki/Floating-point_arithmetic). This means that there are occasionally representation and rounding issues, and some oddities such as supporting positive and negative zero. | ||||
|  | ||||
| Some operators can be applied to other types: | ||||
|  | ||||
| - `+` can be used to concatenate strings, e.g., `'hello' + ' ' + 'world!'` | ||||
| - Unary `-` can be used with planes or line-like objects such as axes to produce an object with opposite orientation, e.g., `-XY` is a plain which is aligned with `XY` but whose normal aligns with the negative Z axis. | ||||
| - The following operators can be used with solids as shorthand for CSG operations: | ||||
|   - `+` or `|` for [`union`](/docs/kcl-std/union). | ||||
|   - `-` for [`subtract`](/docs/kcl-std/subtract). | ||||
|   - `&` for [`intersect`](/docs/kcl-std/intersect) | ||||
							
								
								
									
										33
									
								
								docs/kcl-lang/arrays.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								docs/kcl-lang/arrays.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| --- | ||||
| title: "Arrays and ranges" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Arrays are sequences of values. | ||||
|  | ||||
| Arrays can be written out as *array literals* using a sequence of expressions surrounded by square brackets, e.g., `['hello', 'world']` is an array of strings, `[x, x + 1, x + 2]` is an array of numbers (assuming `x` is a number), `[]` is an empty array, and `['hello', 42, true]` is a mixed array. | ||||
|  | ||||
| A value in an array can be accessed by indexing using square brackets where the index is a number, for example, `arr[0]`, `arr[42]`, `arr[i]` (where `arr` is an array and `i` is a (whole) number). | ||||
|  | ||||
| There are some useful functions for working with arrays in the standard library, see [std::array](/docs/kcl-std/modules/std-array) for details. | ||||
|  | ||||
| ## Array types | ||||
|  | ||||
| Arrays have their own types: `[T]` where `T` is the type of the elements of the array, for example, `[string]` means an array of `string`s and `[any]` means an array of any values. | ||||
|  | ||||
| Array types can also include length information: `[T; n]` denotes an array of length `n` (where `n` is a number literal) and `[T; n+]` denotes an array whose length is at least `n`. The common case for that is `[T; 1+]`, i.e., a non-empty array. E.g., `[string; 1+]` and `[number(mm); 3]` are valid array types. | ||||
|  | ||||
| ## Ranges | ||||
|  | ||||
| Ranges are a succinct way to create an array of sequential numbers. The syntax is `[start .. end]` where `start` and `end` evaluate to whole numbers (integers). Ranges are inclusive of the start and end. The end must be greater than the start. A range which is exclusive of its end is written with `<end`. Examples: | ||||
|  | ||||
| ```kcl,norun | ||||
| [0..3]      // [0, 1, 2, 3] | ||||
| [3..10]     // [3, 4, 5, 6, 7, 8, 9, 10] | ||||
| [3..<10]    // [3, 4, 5, 6, 7, 8, 9] | ||||
| x = 2 | ||||
| [x..x+1]    // [2, 3] | ||||
| ``` | ||||
|  | ||||
| The units of the start and end numbers must be the same and the result inherits those units.  | ||||
							
								
								
									
										30
									
								
								docs/kcl-lang/attributes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								docs/kcl-lang/attributes.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| --- | ||||
| title: "Attributes" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Attributes are syntax which affects the language item they annotate. In KCL they are indicated using `@`. For example, `@settings` affects the file in which it appears. | ||||
|  | ||||
| There are two kinds of attributes: named and unnamed attributes. Named attributes (e.g., `@settings`) have a name immediately after the `@` (e.g., `settings`) and affect their surrounding scope. Unnamed attributes have no name and affect the following item, e.g., | ||||
|  | ||||
| ```kcl,norun | ||||
| @(lengthUnit = ft, coords = opengl) | ||||
| import "tests/inputs/cube.obj" | ||||
| ``` | ||||
|  | ||||
| has an unnamed attribute on the `import` statement. | ||||
|  | ||||
| Named and unnamed attributes may take a parenthesized list of arguments (like a function). Named attributes may also appear without any arguments (e.g., `@no_std`). | ||||
|  | ||||
| ## Named attributes | ||||
|  | ||||
| The `@settings` attribute affects the current file and accepts the following arguments: `defaultLengthUnit`, `defaultAngleUnit`, and `kclVersion`. See [settings](/docs/kcl-lang/settings) for details. | ||||
|  | ||||
| The `@no_std` attribute affects the current file, takes no arguments, and causes the standard library to not be implicitly available. It can still be used by being explicitly imported. | ||||
|  | ||||
| ## Unnamed attributes | ||||
|  | ||||
| Unnamed attributes may be used on `import` statements when importing non-KCL files. See [projects, modules, and imports](/docs/kcl-lang/modules) for details. | ||||
|  | ||||
| Other unnamed attributes are used on functions inside the standard library, but these are not available in user code. | ||||
							
								
								
									
										99
									
								
								docs/kcl-lang/foreign-imports.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								docs/kcl-lang/foreign-imports.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,99 @@ | ||||
| --- | ||||
| title: "Importing geometry from other CAD systems" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| `import` can also be used to import files from other CAD systems. The format of the statement is the | ||||
| same as for KCL files. You can only import the whole file, not items from it. E.g., | ||||
|  | ||||
| ```norun | ||||
| import "tests/inputs/cube.obj" | ||||
|  | ||||
| // Use `cube` just like a KCL object. | ||||
| ``` | ||||
|  | ||||
| ```kcl | ||||
| import "tests/inputs/cube.sldprt" as cube | ||||
|  | ||||
| // Use `cube` just like a KCL object. | ||||
| ``` | ||||
|  | ||||
| For formats lacking unit data (such as STL, OBJ, or PLY files), the default | ||||
| unit of measurement is millimeters. Alternatively you may specify the unit | ||||
| by using an attribute. Likewise, you can also specify a coordinate system. E.g., | ||||
|  | ||||
| ```kcl | ||||
| @(lengthUnit = ft, coords = opengl) | ||||
| import "tests/inputs/cube.obj" | ||||
| ``` | ||||
|  | ||||
| When importing a GLTF file, the bin file will be imported as well. | ||||
|  | ||||
| Import paths are relative to the current project directory. Imports currently only work when | ||||
| using the native Design Studio, not in the browser. | ||||
|  | ||||
| ### Supported values | ||||
|  | ||||
| File formats: `fbx`, `gltf`/`glb`, `obj`+, `ply`+, `sldprt`, `step`/`stp`, `stl`+. (Those marked with a | ||||
| '+' support customising the length unit and coordinate system). | ||||
|  | ||||
| Length units: `mm` (the default), `cm`, `m`, `inch`, `ft`, `yd`. | ||||
|  | ||||
| Coordinate systems: | ||||
|  | ||||
| - `zoo` (the default), forward: -Y, up: +Z, handedness: right | ||||
| - `opengl`, forward: +Z, up: +Y, handedness: right | ||||
| - `vulkan`, forward: +Z, up: -Y, handedness: left | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Performance deep‑dive for foreign‑file imports | ||||
|  | ||||
| Parallelized foreign‑file imports now let you overlap file reads, initialization, | ||||
| and rendering. To maximize throughput, you need to understand the three distinct | ||||
| stages—reading, initializing (background render start), and invocation (blocking) | ||||
| —and structure your code to defer blocking operations until the end. | ||||
|  | ||||
| ### Foreign import execution stages | ||||
|  | ||||
| 1. **Import (Read / Initialization) Stage** | ||||
|    ```kcl | ||||
|    import "tests/inputs/cube.step" as cube | ||||
|    ``` | ||||
|    - Reads the file from disk and makes its API available. | ||||
|    - Starts engine rendering but **does not block** your script. | ||||
|    - This kick‑starts the render pipeline while you keep executing other code. | ||||
|  | ||||
| 2. **Invocation (Blocking) Stage** | ||||
|    ```kcl | ||||
|    import "tests/inputs/cube.step" as cube | ||||
|  | ||||
|    cube | ||||
|      |> translate(z=10) // ← blocks here only | ||||
|    ``` | ||||
|    - Any method call (e.g., `translate`, `scale`, `rotate`) waits for the background render to finish before applying transformations. | ||||
|  | ||||
| ### Best practices | ||||
|  | ||||
| #### 1. Defer blocking calls | ||||
|  | ||||
| ```kcl | ||||
| import "tests/inputs/cube.step" as cube     // 1) Read / Background render starts | ||||
|  | ||||
|  | ||||
| // --- perform other operations and calculations here --- | ||||
|  | ||||
|  | ||||
| cube | ||||
|   |> translate(z=10)                        // 2) Blocks only here | ||||
| ``` | ||||
|  | ||||
| #### 2. Split heavy work into separate modules | ||||
|  | ||||
| Place computationally expensive or IO‑heavy work into its own module so it can render in parallel while `main.kcl` continues. | ||||
|  | ||||
| #### Future improvements | ||||
|  | ||||
| Upcoming releases will auto‑analyse dependencies and only block when truly necessary. Until then, explicit deferral will give you the best performance. | ||||
|  | ||||
							
								
								
									
										46
									
								
								docs/kcl-lang/functions.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								docs/kcl-lang/functions.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,46 @@ | ||||
| --- | ||||
| title: "Functions" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| We have support for defining your own functions. Functions can take in any | ||||
| type of argument. Below is an example of the syntax: | ||||
|  | ||||
| ``` | ||||
| fn myFn(x) { | ||||
|   return x | ||||
| } | ||||
| ``` | ||||
|  | ||||
| As you can see above `myFn` just returns whatever it is given. | ||||
|  | ||||
| KCL uses keyword arguments: | ||||
|  | ||||
| ``` | ||||
| // If you declare a function like this | ||||
| fn add(left, right) { | ||||
|   return left + right | ||||
| } | ||||
|  | ||||
| // You can call it like this: | ||||
| total = add(left = 1, right = 2) | ||||
| ``` | ||||
|  | ||||
| Functions can also declare one *unlabeled* arg. If you do want to declare an unlabeled arg, it must | ||||
| be the first arg declared. | ||||
|  | ||||
| ``` | ||||
| // The @ indicates an argument is used without a label. | ||||
| // Note that only the first argument can use @. | ||||
| fn increment(@x) { | ||||
|   return x + 1 | ||||
| } | ||||
|  | ||||
| fn add(@x, delta) { | ||||
|   return x + delta | ||||
| } | ||||
|  | ||||
| two = increment(1) | ||||
| three = add(1, delta = 2) | ||||
| ``` | ||||
| @ -1,12 +1,22 @@ | ||||
| --- | ||||
| title: "KCL Language Guide" | ||||
| title: "KCL Language Reference" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| This is a reference for KCL. If you are learning KCL, you may prefer the [guide](https://zoo.dev/docs/kcl-book/intro.html) which explains | ||||
| things in a more tutorial fashion. See also our documentation of the [standard library](/docs/kcl-std). | ||||
|  | ||||
| ## Topics | ||||
|  | ||||
| * [`Types`](/docs/kcl-lang/types) | ||||
| * [`Modules`](/docs/kcl-lang/modules) | ||||
| * [`Settings`](/docs/kcl-lang/settings) | ||||
| * [`Known Issues`](/docs/kcl-lang/known-issues) | ||||
| * [Pipelines](/docs/kcl-lang/pipelines) | ||||
| * [Arithmetic and logic](/docs/kcl-lang/arithmetic) | ||||
| * [Values and types](/docs/kcl-lang/types) | ||||
| * [Numeric types and units](/docs/kcl-lang/numeric) | ||||
| * [Functions](/docs/kcl-lang/functions) | ||||
| * [Arrays and ranges](/docs/kcl-lang/arrays) | ||||
| * [Projects and modules](/docs/kcl-lang/modules) | ||||
| * [Attributes](/docs/kcl-lang/attributes) | ||||
| * [Importing geometry from other CAD systems](/docs/kcl-lang/foreign-imports) | ||||
| * [Settings](/docs/kcl-lang/settings) | ||||
| * [Known Issues](/docs/kcl-lang/known-issues) | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| title: "Modules" | ||||
| excerpt: "Documentation of modules for the KCL language for the Zoo Design Studio." | ||||
| title: "Projects and modules" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| @ -27,9 +27,6 @@ import increment from "util.kcl" | ||||
| answer = increment(41) | ||||
| ``` | ||||
|  | ||||
| Imported files _must_ be in the same project so that units are uniform across | ||||
| modules. This means that it must be in the same directory. | ||||
|  | ||||
| Import statements must be at the top-level of a file. It is not allowed to have | ||||
| an `import` statement inside a function or in the body of an if‑else. | ||||
|  | ||||
| @ -58,6 +55,9 @@ Imported symbols can be renamed for convenience or to avoid name collisions. | ||||
| import increment as inc, decrement as dec from "util.kcl" | ||||
| ``` | ||||
|  | ||||
| You can import files from the current directory or from subdirectories, but if importing from a | ||||
| subdirectory you can only import `main.kcl`. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Functions vs `clone` | ||||
| @ -177,7 +177,7 @@ You can also import the whole module. This is useful if you want to use the | ||||
| result of a module as a variable, like a part. | ||||
|  | ||||
| ```norun | ||||
| import "tests/inputs/cube.kcl" as cube | ||||
| import "cube.kcl" | ||||
| cube | ||||
|   |> translate(x=10) | ||||
| ``` | ||||
| @ -229,6 +229,19 @@ The final statement is what's important because it's the return value of the | ||||
| entire module. The module is expected to return a single object that can be used | ||||
| as a variable by the file that imports it. | ||||
|  | ||||
| The name of the file or subdirectory is used as the name of the variable within the importing program. | ||||
| If you want to use a different name, you can do so by using the `as` keyword: | ||||
|  | ||||
| ```kcl,norun | ||||
| import "cube.kcl"                // Introduces a new variable called `cube`. | ||||
| import "cube.kcl" as block       // Introduces a new variable called `block`. | ||||
| import "cube/main.kcl"           // Introduces a new variable called `cube`. | ||||
| import "cube/main.kcl" as block  // Introduces a new variable called `block`. | ||||
| ``` | ||||
|  | ||||
| If the filename includes hyphens (`-`) or starts with an underscore (`_`), then you must specify a | ||||
| variable name. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Multiple instances of the same import | ||||
| @ -241,7 +254,7 @@ If you want to have multiple instances of the same object, you can use the | ||||
| [`clone`](/docs/kcl/clone) function. This will render a new instance of the object in memory. | ||||
|  | ||||
| ```norun | ||||
| import cube from "tests/inputs/cube.kcl" | ||||
| import cube from "cube.kcl" | ||||
|  | ||||
| cube   | ||||
|   |> translate(x=10) | ||||
| @ -257,109 +270,10 @@ separate objects in memory, and can be manipulated independently. | ||||
| Here is an example with a file from another CAD system: | ||||
|  | ||||
| ```kcl | ||||
| import "tests/inputs/cube.step" as cube | ||||
| import "tests/inputs/cube.step" | ||||
|  | ||||
| cube | ||||
|   |> translate(x=10) | ||||
| clone(cube) | ||||
|   |> translate(x=20) | ||||
| ``` | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Importing files from other CAD systems | ||||
|  | ||||
| `import` can also be used to import files from other CAD systems. The format of the statement is the | ||||
| same as for KCL files. You can only import the whole file, not items from it. E.g., | ||||
|  | ||||
| ```norun | ||||
| import "tests/inputs/cube.obj" | ||||
|  | ||||
| // Use `cube` just like a KCL object. | ||||
| ``` | ||||
|  | ||||
| ```kcl | ||||
| import "tests/inputs/cube.sldprt" as cube | ||||
|  | ||||
| // Use `cube` just like a KCL object. | ||||
| ``` | ||||
|  | ||||
| For formats lacking unit data (such as STL, OBJ, or PLY files), the default | ||||
| unit of measurement is millimeters. Alternatively you may specify the unit | ||||
| by using an attribute. Likewise, you can also specify a coordinate system. E.g., | ||||
|  | ||||
| ```kcl | ||||
| @(lengthUnit = ft, coords = opengl) | ||||
| import "tests/inputs/cube.obj" | ||||
| ``` | ||||
|  | ||||
| When importing a GLTF file, the bin file will be imported as well. | ||||
|  | ||||
| Import paths are relative to the current project directory. Imports currently only work when | ||||
| using the native Design Studio, not in the browser. | ||||
|  | ||||
| ### Supported values | ||||
|  | ||||
| File formats: `fbx`, `gltf`/`glb`, `obj`+, `ply`+, `sldprt`, `step`/`stp`, `stl`+. (Those marked with a | ||||
| '+' support customising the length unit and coordinate system). | ||||
|  | ||||
| Length units: `mm` (the default), `cm`, `m`, `inch`, `ft`, `yd`. | ||||
|  | ||||
| Coordinate systems: | ||||
|  | ||||
| - `zoo` (the default), forward: -Y, up: +Z, handedness: right | ||||
| - `opengl`, forward: +Z, up: +Y, handedness: right | ||||
| - `vulkan`, forward: +Z, up: -Y, handedness: left | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Performance deep‑dive for foreign‑file imports | ||||
|  | ||||
| Parallelized foreign‑file imports now let you overlap file reads, initialization, | ||||
| and rendering. To maximize throughput, you need to understand the three distinct | ||||
| stages—reading, initializing (background render start), and invocation (blocking) | ||||
| —and structure your code to defer blocking operations until the end. | ||||
|  | ||||
| ### Foreign import execution stages | ||||
|  | ||||
| 1. **Import (Read / Initialization) Stage** | ||||
|    ```kcl | ||||
|    import "tests/inputs/cube.step" as cube | ||||
|    ``` | ||||
|    - Reads the file from disk and makes its API available. | ||||
|    - Starts engine rendering but **does not block** your script. | ||||
|    - This kick‑starts the render pipeline while you keep executing other code. | ||||
|  | ||||
| 2. **Invocation (Blocking) Stage** | ||||
|    ```kcl | ||||
|    import "tests/inputs/cube.step" as cube | ||||
|  | ||||
|    cube | ||||
|      |> translate(z=10) // ← blocks here only | ||||
|    ``` | ||||
|    - Any method call (e.g., `translate`, `scale`, `rotate`) waits for the background render to finish before applying transformations. | ||||
|  | ||||
| ### Best practices | ||||
|  | ||||
| #### 1. Defer blocking calls | ||||
|  | ||||
| ```kcl | ||||
| import "tests/inputs/cube.step" as cube     // 1) Read / Background render starts | ||||
|  | ||||
|  | ||||
| // --- perform other operations and calculations here --- | ||||
|  | ||||
|  | ||||
| cube | ||||
|   |> translate(z=10)                        // 2) Blocks only here | ||||
| ``` | ||||
|  | ||||
| #### 2. Split heavy work into separate modules | ||||
|  | ||||
| Place computationally expensive or IO‑heavy work into its own module so it can render in parallel while `main.kcl` continues. | ||||
|  | ||||
| #### Future improvements | ||||
|  | ||||
| Upcoming releases will auto‑analyse dependencies and only block when truly necessary. Until then, explicit deferral will give you the best performance. | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										52
									
								
								docs/kcl-lang/numeric.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								docs/kcl-lang/numeric.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| --- | ||||
| title: "Numeric types and units" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Numbers and numeric types in KCL include information about the units of the numbers. So rather than just having a number like `42`, we always have information about the units so we don't confuse 42 mm with 42 inches. | ||||
|  | ||||
|  | ||||
| ## Numeric literals | ||||
|  | ||||
| When writing a number literal, you can use a unit suffix to explicitly state the unit, e.g., `42mm`. The following units are available: | ||||
|  | ||||
| - Length units: | ||||
|   - metric: `mm`, `cm`, `m` | ||||
|   - imperial: `in`, `ft`, `yd` | ||||
| - Angle units: `deg`, `rad` | ||||
| - `_` to indicate a unitless number such as a count or ratio. | ||||
|  | ||||
| If you write a numeric literal without a suffix, then the defaults for the current file are used. These defaults are specified using the `@settings` attribute, see [settings](/docs/kcl-lang/settings) for details. Note that if using the defaults, the KCL interpreter won't know whether you intend the number to be a length, angle, or count and will treat it as being possibly any of them. | ||||
|  | ||||
|  | ||||
| ## Numeric types | ||||
|  | ||||
| Just like numbers carry units information, the `number` type also includes units information. Units are written in parentheses after the type, e.g., `number(mm)`. | ||||
|  | ||||
| Any of the suffixes described above can be used meaning that values with that type have the supplied units. E.g., `number(mm)` is the type of number values with mm units and `number(_)` is the type of number values with no units. | ||||
|  | ||||
| You can also use `number(Length)`, `number(Angle)`, or `number(Count)`. These types mean a number with any length, angle, or unitless (count) units, respectively (note that `number(_)` and `number(Count)` are equivalent since there is only one kind of unitless-ness). | ||||
|  | ||||
| Using just `number` means accepting any kind of number, even where the units are unknown by KCL. | ||||
|  | ||||
|  | ||||
| ## Function calls | ||||
|  | ||||
| When calling a function with an argument with numeric type, the declared numeric type in the function signature and the units of the argument value used in the function call must be compatible. Units are adjusted automatically. For example, if a function requires an argument with type `number(mm)`, then you can call it with `2in` and the units will be automatically adjusted, but calling it with `90deg` will cause an error. | ||||
|  | ||||
|  | ||||
| ## Mixing units with arithmetic | ||||
|  | ||||
| When doing arithmetic or comparisons, units will be adjusted as necessary if possible. However, often arithmetic expressions exceed the ability of KCL to accurately choose units which can result in warnings in your code or sometimes errors. In these cases, you will need to give KCL more information. Sometimes this can be done by making units explicit using suffixes. If not, then you will need to use *type ascription*, which asserts that an expression has the supplied type. For example, `(x * y): number(mm)` tells KCL that the units of `x * y` is mm. Note that type ascription does not do any adjustment of the numbers, e.g., `2mm: number(in)` has the value `2in` (note that this would be a very non-idiomatic way to use numeric type ascription, you could simply write `2in`. Usually type ascription is only necessary for supplying type information about the result of computation). | ||||
|  | ||||
| KCL has no support for area, volume, or other higher dimension units. When internal unit tracking requires multiple dimensions, KCL essentially gives up. This is usually where the extra type information described above is needed. If doing computation with higher dimensioned units, you must ensure that all adjustments occur before any computation. E.g., if you want to compute an area with unknown units, you must convert all numbers to the same unit before starting. | ||||
|  | ||||
|  | ||||
| ## Explicit conversions | ||||
|  | ||||
| You might sometimes need to convert from one unit to another for some calculation. You can do this implicitly when calling a function (see above), but if you can't or don't want to, then you can use the explicit conversion functions in the [`std::units`](/docs/kcl-std/modules/std-units) module. | ||||
|  | ||||
| KCL cannot know about changes to units caused by arithmetic. For example, you may intend for `10in * 25.4` to be the value `254mm` (i.e., `10in` in mm), however, the result of that computation in KCL is `254in`. It is always better to rely on automatic conversion or to use the explicit conversion functions, where possible. | ||||
|  | ||||
| Converting between degrees and radians using π ([`PI`](/docs/kcl-std/consts/std-math-PI) in KCL) is especially prone to this error and so the `PI` constant always requires specifying units of any computation it is used with. E.g., `radius = (circumference / (2 * PI)): number(mm)`. | ||||
							
								
								
									
										66
									
								
								docs/kcl-lang/pipelines.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								docs/kcl-lang/pipelines.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | ||||
| --- | ||||
| title: "Pipelines" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| It can be hard to read repeated function calls, because of all the nested brackets. | ||||
|  | ||||
| ```norun | ||||
| i = 1 | ||||
| x = h(g(f(i))) | ||||
| ``` | ||||
|  | ||||
| You can make this easier to read by breaking it into many declarations, but that is a bit annoying. | ||||
|  | ||||
| ```norun | ||||
| i  = 1 | ||||
| x0 = f(i) | ||||
| x1 = g(x0) | ||||
| x  = h(x1) | ||||
| ``` | ||||
|  | ||||
| Instead, you can use the pipeline operator (`|>`) to simplify this. | ||||
|  | ||||
| Basically, `x |> f(%)` is a shorthand for `f(x)`. The left-hand side of the `|>` gets put into | ||||
| the `%` in the right-hand side. | ||||
|  | ||||
| So, this means `x |> f(%) |> g(%)` is shorthand for `g(f(x))`. The code example above, with its | ||||
| somewhat-clunky `x0` and `x1` constants could be rewritten as | ||||
|  | ||||
| ```norun | ||||
| i = 1 | ||||
| x = i | ||||
|   |> f(%) | ||||
|   |> g(%) | ||||
|   |> h(%) | ||||
| ``` | ||||
|  | ||||
| This helps keep your code neat and avoid unnecessary declarations. | ||||
|  | ||||
| ## Pipelines and keyword arguments | ||||
|  | ||||
| Say you have a long pipeline of sketch functions, like this: | ||||
|  | ||||
| ```norun | ||||
| startSketchOn(XZ) | ||||
|   |> line(%, end = [3, 4]) | ||||
|   |> line(%, end = [10, 10]) | ||||
|   |> line(%, end = [-13, -14]) | ||||
|   |> close(%) | ||||
| ``` | ||||
|  | ||||
| In this example, each function call outputs a sketch, and it gets put into the next function call via | ||||
| the `%`, into the first (unlabeled) argument. | ||||
|  | ||||
| If a function call uses an unlabeled first parameter, it will default to `%` if it's not given. This | ||||
| means that `|> line(%, end = [3, 4])` and `|> line(end = [3, 4])` are equivalent! So the above | ||||
| could be rewritten as  | ||||
|  | ||||
| ```norun | ||||
| startSketchOn(XZ) | ||||
|  |> line(end = [3, 4]) | ||||
|  |> line(end = [10, 10]) | ||||
|  |> line(end = [-13, -14]) | ||||
|  |> close() | ||||
| ``` | ||||
| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| title: "Settings" | ||||
| excerpt: "Documentation of settings for the KCL language and Zoo Design Studio." | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| @ -4,8 +4,6 @@ excerpt: "Project specific settings for the app. These live in `project.toml` in | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| # Project Settings | ||||
|  | ||||
| Project specific settings for the app. These live in `project.toml` in the base of the project directory. Updating the settings for the project in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | ||||
|  | ||||
| ## Project Configuration Structure | ||||
| @ -184,4 +182,4 @@ color = 240.0 | ||||
| # Use inches as the default measurement unit | ||||
| base_unit = "in" | ||||
|  | ||||
| ``` | ||||
| ``` | ||||
|  | ||||
| @ -4,8 +4,6 @@ excerpt: "User specific settings for the app. These live in `user.toml` in the a | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| # User Settings | ||||
|  | ||||
| User specific settings for the app. These live in `user.toml` in the app's configuration directory. Updating the settings in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | ||||
|  | ||||
| ## User Configuration Structure | ||||
| @ -85,6 +83,13 @@ Allow orbiting in sketch mode. | ||||
| Whether to show the debug panel, which lets you see various states of the app to aid in development. | ||||
|  | ||||
|  | ||||
| **Default:** None | ||||
|  | ||||
| ##### fixed_size_grid | ||||
|  | ||||
| If true, the grid cells will be fixed-size, where the width is your default length unit. If false, the grid will get larger as you zoom out, and smaller as you zoom in. | ||||
|  | ||||
|  | ||||
| **Default:** None | ||||
|  | ||||
|  | ||||
| @ -234,4 +239,4 @@ base_unit = "mm" | ||||
| # Disable text wrapping in the editor | ||||
| text_wrapping = false | ||||
|  | ||||
| ``` | ||||
| ``` | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| title: "Types" | ||||
| excerpt: "Documentation of types for the KCL standard library for the Zoo Design Studio." | ||||
| title: "Values and types" | ||||
| excerpt: "Documentation of the KCL language for the Zoo Design Studio." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| @ -19,18 +19,6 @@ myBool = false | ||||
|  | ||||
| Currently you cannot redeclare a constant. | ||||
|  | ||||
| ## Arrays | ||||
|  | ||||
| An array is defined with `[]` braces. What is inside the brackets can | ||||
| be of any type. For example, the following is completely valid: | ||||
|  | ||||
| ``` | ||||
| myArray = ["thing", 2, false] | ||||
| ``` | ||||
|  | ||||
| If you want to get a value from an array you can use the index like so: | ||||
| `myArray[0]`. | ||||
|  | ||||
|  | ||||
| ## Objects | ||||
|  | ||||
| @ -40,8 +28,8 @@ An object is defined with `{}` braces. Here is an example object: | ||||
| myObj = { a = 0, b = "thing" } | ||||
| ``` | ||||
|  | ||||
| We support two different ways of getting properties from objects, you can call | ||||
| `myObj.a` or `myObj["a"]` both work. | ||||
| To get the property of an object, you can call `myObj.a`, which in the above | ||||
| example returns 0. | ||||
|  | ||||
| ## `ImportedGeometry` | ||||
|  | ||||
| @ -52,136 +40,11 @@ their internal components. See the [modules and imports docs](modules) for more | ||||
| detail on importing geometry. | ||||
|  | ||||
|  | ||||
| ## Binary expressions | ||||
|  | ||||
| You can also do math! Let's show an example below: | ||||
|  | ||||
| ``` | ||||
| myMathExpression = 3 + 1 * 2 / 3 - 7 | ||||
| ``` | ||||
|  | ||||
| You can nest expressions in parenthesis as well: | ||||
|  | ||||
| ``` | ||||
| myMathExpression = 3 + (1 * 2 / (3 - 7)) | ||||
| ``` | ||||
|  | ||||
| ## Functions | ||||
|  | ||||
| We also have support for defining your own functions. Functions can take in any | ||||
| type of argument. Below is an example of the syntax: | ||||
|  | ||||
| ``` | ||||
| fn myFn(x) { | ||||
|   return x | ||||
| } | ||||
| ``` | ||||
|  | ||||
| As you can see above `myFn` just returns whatever it is given. | ||||
|  | ||||
| KCL's early drafts used positional arguments, but we now use keyword arguments: | ||||
|  | ||||
| ``` | ||||
| // If you declare a function like this | ||||
| fn add(left, right) { | ||||
|   return left + right | ||||
| } | ||||
|  | ||||
| // You can call it like this: | ||||
| total = add(left = 1, right = 2) | ||||
| ``` | ||||
|  | ||||
| Functions can also declare one *unlabeled* arg. If you do want to declare an unlabeled arg, it must | ||||
| be the first arg declared. | ||||
|  | ||||
| ``` | ||||
| // The @ indicates an argument can be used without a label. | ||||
| // Note that only the first argument can use @. | ||||
| fn increment(@x) { | ||||
|   return x + 1 | ||||
| } | ||||
|  | ||||
| fn add(@x, delta) { | ||||
|   return x + delta | ||||
| } | ||||
|  | ||||
| two = increment(1) | ||||
| three = add(1, delta = 2) | ||||
| ``` | ||||
|  | ||||
| ## Pipelines | ||||
|  | ||||
| It can be hard to read repeated function calls, because of all the nested brackets. | ||||
|  | ||||
| ```norun | ||||
| i = 1 | ||||
| x = h(g(f(i))) | ||||
| ``` | ||||
|  | ||||
| You can make this easier to read by breaking it into many declarations, but that is a bit annoying. | ||||
|  | ||||
| ```norun | ||||
| i  = 1 | ||||
| x0 = f(i) | ||||
| x1 = g(x0) | ||||
| x  = h(x1) | ||||
| ``` | ||||
|  | ||||
| Instead, you can use the pipeline operator (`|>`) to simplify this. | ||||
|  | ||||
| Basically, `x |> f(%)` is a shorthand for `f(x)`. The left-hand side of the `|>` gets put into | ||||
| the `%` in the right-hand side. | ||||
|  | ||||
| So, this means `x |> f(%) |> g(%)` is shorthand for `g(f(x))`. The code example above, with its | ||||
| somewhat-clunky `x0` and `x1` constants could be rewritten as | ||||
|  | ||||
| ```norun | ||||
| i = 1 | ||||
| x = i | ||||
|   |> f(%) | ||||
|   |> g(%) | ||||
|   |> h(%) | ||||
| ``` | ||||
|  | ||||
| This helps keep your code neat and avoid unnecessary declarations. | ||||
|  | ||||
| ## Pipelines and keyword arguments | ||||
|  | ||||
| Say you have a long pipeline of sketch functions, like this: | ||||
|  | ||||
| ```norun | ||||
| startSketchOn(XZ) | ||||
|   |> line(%, end = [3, 4]) | ||||
|   |> line(%, end = [10, 10]) | ||||
|   |> line(%, end = [-13, -14]) | ||||
|   |> close(%) | ||||
| ``` | ||||
|  | ||||
| In this example, each function call outputs a sketch, and it gets put into the next function call via | ||||
| the `%`, into the first (unlabeled) argument. | ||||
|  | ||||
| If a function call uses an unlabeled first parameter, it will default to `%` if it's not given. This | ||||
| means that `|> line(%, end = [3, 4])` and `|> line(end = [3, 4])` are equivalent! So the above | ||||
| could be rewritten as  | ||||
|  | ||||
| ```norun | ||||
| startSketchOn(XZ) | ||||
|  |> line(end = [3, 4]) | ||||
|  |> line(end = [10, 10]) | ||||
|  |> line(end = [-13, -14]) | ||||
|  |> close() | ||||
| ``` | ||||
|  | ||||
| Note that we are still in the process of migrating KCL's standard library to use keyword arguments. So some | ||||
| functions are still unfortunately using positional arguments. We're moving them over, so keep checking back. | ||||
| Some functions are still using the old positional argument syntax. | ||||
| Check the docs page for each function and look at its examples to see. | ||||
|  | ||||
| ## Tags | ||||
|  | ||||
| Tags are used to give a name (tag) to a specific path. | ||||
|  | ||||
| ### `TagDeclarator` | ||||
| ### Tag declarations - `TagDecl` | ||||
|  | ||||
| The syntax for declaring a tag is `$myTag` you would use it in the following | ||||
| way: | ||||
| @ -204,24 +67,28 @@ startSketchOn(XZ) | ||||
|   |> close() | ||||
| ``` | ||||
|  | ||||
| ### `TagIdentifier` | ||||
| When a function requires declaring a new tag (using the `$` syntax), the argument has type [`TagDecl`](/docs/kcl-std/types/std-types-TagDecl). | ||||
|  | ||||
| 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`. | ||||
| ### Tag identifiers | ||||
|  | ||||
| In the example above we use the tag identifier to get the angle of the segment | ||||
| `segAng(rectangleSegmentA001)`. | ||||
| A tag created using a tag declarator can be used by writing its name without the `$`, e.g., `myTag`. | ||||
| Where necessary to disambiguate from tag declarations, we call these tag identifiers. | ||||
|  | ||||
| ### `Start` | ||||
| In the example above we use the tag identifier `rectangleSegmentA001` to get the angle of the segment | ||||
| using `segAng(rectangleSegmentA001)`. | ||||
|  | ||||
| There is a special tag, `START` (with type `Start`, although under the cover, it's a string) | ||||
| for identifying the face of a solid which was the start of an extrusion (i.e., the surface which | ||||
| is extruded). | ||||
| Tags can identify either an edge or face of a solid, or a line or other edge of a sketch. Functions | ||||
| which take a tag identifier as an argument will use either [`TaggedEdge`](/docs/kcl-std/types/std-types-TaggedEdge) (for the edge of a | ||||
| solid or sketch) or [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace). | ||||
|  | ||||
| ### `End` | ||||
| If a line in a sketch is tagged and then the sketch is extruded, the tag is a `TaggedEdge` before | ||||
| extrusion and a `TaggedFace` after extrusion. | ||||
|  | ||||
| #### `START` and `END` | ||||
|  | ||||
| [`START`](/docs/kcl-std/consts/std-START) and [`END`](/docs/kcl-std/consts/std-END) are special tags | ||||
| for identifying the starting and ending faces of an extruded solid. | ||||
|  | ||||
| There is a special tag, `END` (with type `End`, although under the cover, it's a string) | ||||
| for identifying the face of a solid which was finishes an extrusion. | ||||
|  | ||||
| ### Tag Scope | ||||
|  | ||||
| @ -291,7 +158,6 @@ 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, | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,33 +0,0 @@ | ||||
| --- | ||||
| title: "KCL Constants" | ||||
| excerpt: "Documentation for the KCL constants." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| ## Table of Contents | ||||
|  | ||||
|  | ||||
| ### `std` | ||||
|  | ||||
| - [`END`](/docs/kcl/consts/std-END) | ||||
| - [`START`](/docs/kcl/consts/std-START) | ||||
| - [`X`](/docs/kcl/consts/std-X) | ||||
| - [`XY`](/docs/kcl/consts/std-XY) | ||||
| - [`XZ`](/docs/kcl/consts/std-XZ) | ||||
| - [`Y`](/docs/kcl/consts/std-Y) | ||||
| - [`YZ`](/docs/kcl/consts/std-YZ) | ||||
| - [`Z`](/docs/kcl/consts/std-Z) | ||||
|  | ||||
| ### `std::math` | ||||
|  | ||||
| - [`E`](/docs/kcl/consts/std-math-E) | ||||
| - [`PI`](/docs/kcl/consts/std-math-PI) | ||||
| - [`TAU`](/docs/kcl/consts/std-math-TAU) | ||||
|  | ||||
| ### `std::turns` | ||||
|  | ||||
| - [`HALF_TURN`](/docs/kcl/consts/std-turns-HALF_TURN) | ||||
| - [`QUARTER_TURN`](/docs/kcl/consts/std-turns-QUARTER_TURN) | ||||
| - [`THREE_QUARTER_TURN`](/docs/kcl/consts/std-turns-THREE_QUARTER_TURN) | ||||
| - [`ZERO`](/docs/kcl/consts/std-turns-ZERO) | ||||
|  | ||||
| @ -8,9 +8,13 @@ layout: manual | ||||
| Identifies the ending face of an extrusion. I.e., the new face created by an extrusion. | ||||
|  | ||||
| ```kcl | ||||
| END: string = 'end' | ||||
| END: TaggedFace | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace) - A tag which references a face of a solid, including the distinguished tags `START` and `END`. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -8,9 +8,13 @@ layout: manual | ||||
| Identifies the starting face of an extrusion. I.e., the face which is extruded. | ||||
|  | ||||
| ```kcl | ||||
| START: string = 'start' | ||||
| START: TaggedFace | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace) - A tag which references a face of a solid, including the distinguished tags `START` and `END`. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "X" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "The X-axis (can be used in both 2d and 3d contexts)." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| The X-axis (can be used in both 2d and 3d contexts). | ||||
|  | ||||
| ```kcl | ||||
| X | ||||
| X: Axis3d | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "XY" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "An abstract 3d plane aligned with the X and Y axes. Its normal is the positive Z axis." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| An abstract 3d plane aligned with the X and Y axes. Its normal is the positive Z axis. | ||||
|  | ||||
| ```kcl | ||||
| XY | ||||
| XY: Plane | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "XZ" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "An abstract 3d plane aligned with the X and Z axes. Its normal is the negative Y axis." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| An abstract 3d plane aligned with the X and Z axes. Its normal is the negative Y axis. | ||||
|  | ||||
| ```kcl | ||||
| XZ | ||||
| XZ: Plane | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "Y" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "The Y-axis (can be used in both 2d and 3d contexts)." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| The Y-axis (can be used in both 2d and 3d contexts). | ||||
|  | ||||
| ```kcl | ||||
| Y | ||||
| Y: Axis3d | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "YZ" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "An abstract 3d plane aligned with the Y and Z axes. Its normal is the positive X axis." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| An abstract 3d plane aligned with the Y and Z axes. Its normal is the positive X axis. | ||||
|  | ||||
| ```kcl | ||||
| YZ | ||||
| YZ: Plane | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "Z" | ||||
| subtitle: "Constant in std" | ||||
| excerpt: "" | ||||
| excerpt: "The 3D Z-axis." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| The 3D Z-axis. | ||||
|  | ||||
| ```kcl | ||||
| Z | ||||
| Z: Axis3d | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												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
											
										
									
								
							
							
								
								
									
										20
									
								
								docs/kcl-std/consts/std-sweep-SKETCH_PLANE.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								docs/kcl-std/consts/std-sweep-SKETCH_PLANE.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| --- | ||||
| title: "sweep::SKETCH_PLANE" | ||||
| subtitle: "Constant in std::sweep" | ||||
| excerpt: "Local/relative to a position centered within the plane being sketched on" | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Local/relative to a position centered within the plane being sketched on | ||||
|  | ||||
| ```kcl | ||||
| sweep::SKETCH_PLANE: string = 'sketchPlane' | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`string`](/docs/kcl-std/types/std-types-string) - A sequence of characters | ||||
|  | ||||
|  | ||||
							
								
								
									
										20
									
								
								docs/kcl-std/consts/std-sweep-TRAJECTORY.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								docs/kcl-std/consts/std-sweep-TRAJECTORY.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| --- | ||||
| title: "sweep::TRAJECTORY" | ||||
| subtitle: "Constant in std::sweep" | ||||
| excerpt: "Local/relative to the trajectory curve" | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Local/relative to the trajectory curve | ||||
|  | ||||
| ```kcl | ||||
| sweep::TRAJECTORY: string = 'trajectoryCurve' | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`string`](/docs/kcl-std/types/std-types-string) - A sequence of characters | ||||
|  | ||||
|  | ||||
| @ -1,11 +1,11 @@ | ||||
| --- | ||||
| title: "turns::HALF_TURN" | ||||
| subtitle: "Constant in std::turns" | ||||
| excerpt: "" | ||||
| excerpt: "A half turn, 180 degrees or π radians." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| A half turn, 180 degrees or π radians. | ||||
|  | ||||
| ```kcl | ||||
| turns::HALF_TURN: number(deg) = 180deg | ||||
| @ -13,4 +13,8 @@ turns::HALF_TURN: number(deg) = 180deg | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,11 +1,11 @@ | ||||
| --- | ||||
| title: "turns::QUARTER_TURN" | ||||
| subtitle: "Constant in std::turns" | ||||
| excerpt: "" | ||||
| excerpt: "A quarter turn, 90 degrees or π/2 radians." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| A quarter turn, 90 degrees or π/2 radians. | ||||
|  | ||||
| ```kcl | ||||
| turns::QUARTER_TURN: number(deg) = 90deg | ||||
| @ -13,4 +13,8 @@ turns::QUARTER_TURN: number(deg) = 90deg | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,11 +1,11 @@ | ||||
| --- | ||||
| title: "turns::THREE_QUARTER_TURN" | ||||
| subtitle: "Constant in std::turns" | ||||
| excerpt: "" | ||||
| excerpt: "Three quarters of a turn, 270 degrees or 1.5*π radians." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| Three quarters of a turn, 270 degrees or 1.5*π radians. | ||||
|  | ||||
| ```kcl | ||||
| turns::THREE_QUARTER_TURN: number(deg) = 270deg | ||||
| @ -13,4 +13,8 @@ turns::THREE_QUARTER_TURN: number(deg) = 270deg | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,16 +1,20 @@ | ||||
| --- | ||||
| title: "turns::ZERO" | ||||
| subtitle: "Constant in std::turns" | ||||
| excerpt: "" | ||||
| excerpt: "No turn, zero degrees/radians." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
|  | ||||
| No turn, zero degrees/radians. | ||||
|  | ||||
| ```kcl | ||||
| turns::ZERO: number = 0 | ||||
| turns::ZERO: number(Angle) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Type | ||||
|  | ||||
| [`number(Angle)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										130
									
								
								docs/kcl-std/functions/std-appearance-hexString.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								docs/kcl-std/functions/std-appearance-hexString.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										64
									
								
								docs/kcl-std/functions/std-appearance-rgb.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								docs/kcl-std/functions/std-appearance-rgb.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
											
										
									
								
							
							
								
								
									
										60
									
								
								docs/kcl-std/functions/std-assert.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								docs/kcl-std/functions/std-assert.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| --- | ||||
| title: "assert" | ||||
| subtitle: "Function in std" | ||||
| excerpt: "Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. If you provide multiple conditions, they will all be checked and all must be met." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Check a value meets some expected conditions at runtime. Program terminates with an error if conditions aren't met. If you provide multiple conditions, they will all be checked and all must be met. | ||||
|  | ||||
| ```kcl | ||||
| assert( | ||||
|   @actual: number, | ||||
|   isGreaterThan?: number, | ||||
|   isLessThan?: number, | ||||
|   isGreaterThanOrEqual?: number, | ||||
|   isLessThanOrEqual?: number, | ||||
|   isEqualTo?: number, | ||||
|   tolerance?: number, | ||||
|   error?: string, | ||||
| ) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Arguments | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `actual` | [`number`](/docs/kcl-std/types/std-types-number) | Value to check. If this is the boolean value true, assert passes. Otherwise it fails.. | Yes | | ||||
| | `isGreaterThan` | [`number`](/docs/kcl-std/types/std-types-number) | Comparison argument. If given, checks the `actual` value is greater than this. | No | | ||||
| | `isLessThan` | [`number`](/docs/kcl-std/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than this. | No | | ||||
| | `isGreaterThanOrEqual` | [`number`](/docs/kcl-std/types/std-types-number) | Comparison argument. If given, checks the `actual` value is greater than or equal to this. | No | | ||||
| | `isLessThanOrEqual` | [`number`](/docs/kcl-std/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | | ||||
| | `isEqualTo` | [`number`](/docs/kcl-std/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | | ||||
| | `tolerance` | [`number`](/docs/kcl-std/types/std-types-number) | If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places. | No | | ||||
| | `error` | [`string`](/docs/kcl-std/types/std-types-string) | If the value was false, the program will terminate with this error message | No | | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ```kcl | ||||
| n = 10 | ||||
| assert(n, isEqualTo = 10) | ||||
| assert( | ||||
|   n, | ||||
|   isGreaterThanOrEqual = 0, | ||||
|   isLessThan = 100, | ||||
|   error = "number should be between 0 and 100", | ||||
| ) | ||||
| assert( | ||||
|   1.0000000000012, | ||||
|   isEqualTo = 1, | ||||
|   tolerance = 0.0001, | ||||
|   error = "number should be almost exactly 1", | ||||
| ) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										36
									
								
								docs/kcl-std/functions/std-assertIs.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								docs/kcl-std/functions/std-assertIs.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | ||||
| --- | ||||
| title: "assertIs" | ||||
| subtitle: "Function in std" | ||||
| excerpt: "Asserts that a value is the boolean value true." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Asserts that a value is the boolean value true. | ||||
|  | ||||
| ```kcl | ||||
| assertIs( | ||||
|   @actual: bool, | ||||
|   error?: string, | ||||
| ) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Arguments | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `actual` | [`bool`](/docs/kcl-std/types/std-types-bool) | Value to check. If this is the boolean value true, assert passes. Otherwise it fails.. | Yes | | ||||
| | `error` | [`string`](/docs/kcl-std/types/std-types-string) | If the value was false, the program will terminate with this error message | No | | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ```kcl | ||||
| kclIsFun = true | ||||
| assertIs(kclIsFun) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												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
											
										
									
								
							| @ -17,11 +17,11 @@ Consider using `atan2()` instead for the true inverse of tangent. | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `num` | [`number(_)`](/docs/kcl-std/types/std-types-number) | A number | Yes | | ||||
| | `num` | [`number(_)`](/docs/kcl-std/types/std-types-number) | A number. | Yes | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| [`number(rad)`](/docs/kcl-std/types/std-types-number) - A number | ||||
| [`number(rad)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
| @ -29,14 +29,12 @@ Consider using `atan2()` instead for the true inverse of tangent. | ||||
| ```kcl | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfile(at = [0, 0]) | ||||
|   |> angledLine( | ||||
|     angle = atan(1.25), | ||||
|     length = 20, | ||||
|   ) | ||||
|   |> angledLine(angle = atan(1.25), length = 20) | ||||
|   |> yLine(endAbsolute = 0) | ||||
|   |> close() | ||||
|  | ||||
| extrude001 = extrude(sketch001, length = 5) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												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
											
										
									
								
							
							
								
								
									
										39
									
								
								docs/kcl-std/functions/std-math-legAngX.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								docs/kcl-std/functions/std-math-legAngX.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | ||||
| --- | ||||
| title: "legAngX" | ||||
| subtitle: "Function in std::math" | ||||
| excerpt: "Compute the angle of the given leg for x." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Compute the angle of the given leg for x. | ||||
|  | ||||
| ```kcl | ||||
| legAngX( | ||||
|   hypotenuse: number(Length), | ||||
|   leg: number(Length), | ||||
| ): number(deg) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Arguments | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `hypotenuse` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse. | Yes | | ||||
| | `leg` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side). | Yes | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ```kcl | ||||
| legAngX(hypotenuse = 5, leg = 3) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										39
									
								
								docs/kcl-std/functions/std-math-legAngY.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								docs/kcl-std/functions/std-math-legAngY.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | ||||
| --- | ||||
| title: "legAngY" | ||||
| subtitle: "Function in std::math" | ||||
| excerpt: "Compute the angle of the given leg for y." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Compute the angle of the given leg for y. | ||||
|  | ||||
| ```kcl | ||||
| legAngY( | ||||
|   hypotenuse: number(Length), | ||||
|   leg: number(Length), | ||||
| ): number(deg) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Arguments | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `hypotenuse` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse. | Yes | | ||||
| | `leg` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side). | Yes | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ```kcl | ||||
| legAngY(hypotenuse = 5, leg = 3) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										39
									
								
								docs/kcl-std/functions/std-math-legLen.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								docs/kcl-std/functions/std-math-legLen.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | ||||
| --- | ||||
| title: "legLen" | ||||
| subtitle: "Function in std::math" | ||||
| excerpt: "Compute the length of the given leg." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Compute the length of the given leg. | ||||
|  | ||||
| ```kcl | ||||
| legLen( | ||||
|   hypotenuse: number(Length), | ||||
|   leg: number(Length), | ||||
| ): number(Length) | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Arguments | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `hypotenuse` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse. | Yes | | ||||
| | `leg` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side). | Yes | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ```kcl | ||||
| legLen(hypotenuse = 5, leg = 3) | ||||
|  | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
										
											
												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
											
										
									
								
							
										
											
												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
	![github-actions[bot]](/assets/img/avatar_default.png)