Compare commits
	
		
			302 Commits
		
	
	
		
			pierremtb/
			...
			kcl-80
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 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 | 
							
								
								
									
										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 |     # If no last run artifact, than run Playwright normally | ||||||
|     echo "run playwright normally" |     echo "run playwright normally" | ||||||
|     if [[ "$3" == *ubuntu* ]]; then |     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 |     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 |     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 |     else | ||||||
|         echo "Do not run Playwright. Unable to detect os runtime." |         echo "Do not run Playwright. Unable to detect os runtime." | ||||||
|         exit 1 |         exit 1 | ||||||
| @ -31,11 +31,11 @@ while [[ $retry -le $max_retries ]]; do | |||||||
|             echo "retried=true" >>$GITHUB_OUTPUT |             echo "retried=true" >>$GITHUB_OUTPUT | ||||||
|             echo "run playwright with last failed tests and retry $retry" |             echo "run playwright with last failed tests and retry $retry" | ||||||
|             if [[ "$3" == *ubuntu* ]]; then |             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 |             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 |             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 |             else | ||||||
|                 echo "Do not run playwright. Unable to detect os runtime." |                 echo "Do not run playwright. Unable to detect os runtime." | ||||||
|                 exit 1 |                 exit 1 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/ci-cd-scripts/upload-results.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ci-cd-scripts/upload-results.sh
									
									
									
									
										vendored
									
									
								
							| @ -6,6 +6,7 @@ if [ -z "${TAB_API_URL:-}" ] || [ -z "${TAB_API_KEY:-}" ]; then | |||||||
| fi | fi | ||||||
|  |  | ||||||
| project="https://github.com/KittyCAD/modeling-app" | project="https://github.com/KittyCAD/modeling-app" | ||||||
|  | suite="${CI_SUITE:-unit}" | ||||||
| branch="${GITHUB_HEAD_REF:-${GITHUB_REF_NAME:-}}" | branch="${GITHUB_HEAD_REF:-${GITHUB_REF_NAME:-}}" | ||||||
| commit="${CI_COMMIT_SHA:-${GITHUB_SHA:-}}" | commit="${CI_COMMIT_SHA:-${GITHUB_SHA:-}}" | ||||||
|  |  | ||||||
| @ -13,6 +14,7 @@ echo "Uploading batch results" | |||||||
| curl --silent --request POST \ | curl --silent --request POST \ | ||||||
|   --header "X-API-Key: ${TAB_API_KEY}" \ |   --header "X-API-Key: ${TAB_API_KEY}" \ | ||||||
|   --form "project=${project}" \ |   --form "project=${project}" \ | ||||||
|  |   --form "suite=${suite}" \ | ||||||
|   --form "branch=${branch}" \ |   --form "branch=${branch}" \ | ||||||
|   --form "commit=${commit}" \ |   --form "commit=${commit}" \ | ||||||
|   --form "tests=@test-results/junit.xml" \ |   --form "tests=@test-results/junit.xml" \ | ||||||
|  | |||||||
							
								
								
									
										853
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										853
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										78
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										78
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							| @ -7,14 +7,13 @@ on: | |||||||
|       - main |       - main | ||||||
|     tags: |     tags: | ||||||
|       - 'v[0-9]+.[0-9]+.[0-9]+' |       - 'v[0-9]+.[0-9]+.[0-9]+' | ||||||
|       - 'nightly-v[0-9]+.[0-9]+.[0-9]+' |  | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   IS_RELEASE: ${{ github.ref_type == 'tag' && startsWith(github.ref_name, 'v') }} |   IS_RELEASE: ${{ github.ref_type == 'tag' && startsWith(github.ref_name, 'v') }} | ||||||
|   IS_NIGHTLY: ${{ github.ref_type == 'tag' && startsWith(github.ref_name, 'nightly-v') }} |   IS_NIGHTLY: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||||
|  |  | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.ref }} | ||||||
|   cancel-in-progress: true |   cancel-in-progress: true | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
| @ -95,7 +94,9 @@ jobs: | |||||||
|       - name: Set nightly version, product name, release notes, and icons |       - name: Set nightly version, product name, release notes, and icons | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|         run: | |         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:set-version | ||||||
|           npm run files:flip-to-nightly |           npm run files:flip-to-nightly | ||||||
|  |  | ||||||
| @ -122,18 +123,6 @@ jobs: | |||||||
|       - id: export_notes |       - id: export_notes | ||||||
|         run: echo "notes=`cat release-notes.md`" >> "$GITHUB_OUTPUT" |         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: |   build-apps: | ||||||
|     needs: [prepare-files] |     needs: [prepare-files] | ||||||
| @ -258,55 +247,13 @@ jobs: | |||||||
|  |  | ||||||
|       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back |       # 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 |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   upload-apps-release: |   upload-apps-release: | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     if: ${{ github.ref_type == 'tag' }} |     # Equivalent to IS_RELEASE || IS_NIGHTLY (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: |     env: | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|       VERSION: ${{ format('v{0}', needs.prepare-files.outputs.version) }} |       VERSION: ${{ format('v{0}', needs.prepare-files.outputs.version) }} | ||||||
| @ -412,17 +359,6 @@ jobs: | |||||||
|       - name: List artifacts |       - name: List artifacts | ||||||
|         run: "ls -R out" |         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 |       - name: Authenticate to Google Cloud | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|         uses: 'google-github-actions/auth@v2.1.8' |         uses: 'google-github-actions/auth@v2.1.8' | ||||||
|  | |||||||
							
								
								
									
										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/* | ||||||
							
								
								
									
										63
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										63
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,16 +1,22 @@ | |||||||
|  | name: cargo test | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|   pull_request: |   pull_request: | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |   schedule: | ||||||
|  |     - cron: 0 * * * *  # hourly | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|   pull-requests: write |   pull-requests: write | ||||||
|  |  | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|   cancel-in-progress: true |   cancel-in-progress: true | ||||||
| name: cargo test |  | ||||||
| jobs: | jobs: | ||||||
|   build-test-artifacts: |   build-test-artifacts: | ||||||
|     name: Build test artifacts |     name: Build test artifacts | ||||||
| @ -88,6 +94,7 @@ jobs: | |||||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} |           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} | ||||||
|           ZOO_HOST: https://api.dev.zoo.dev |           ZOO_HOST: https://api.dev.zoo.dev | ||||||
|           RUST_BACKTRACE: full |           RUST_BACKTRACE: full | ||||||
|  |           RUST_MIN_STACK: 10485760000 | ||||||
|       - name: Commit differences |       - name: Commit differences | ||||||
|         if: steps.path-changes.outputs.outside-kcl-samples == 'false' && steps.cargo-test-kcl-samples.outcome == 'failure' |         if: steps.path-changes.outputs.outside-kcl-samples == 'false' && steps.cargo-test-kcl-samples.outcome == 'failure' | ||||||
|         shell: bash |         shell: bash | ||||||
| @ -119,6 +126,7 @@ jobs: | |||||||
|           # Configure nextest when it's run by insta (via just). |           # Configure nextest when it's run by insta (via just). | ||||||
|           NEXTEST_PROFILE: ci |           NEXTEST_PROFILE: ci | ||||||
|           RUST_BACKTRACE: full |           RUST_BACKTRACE: full | ||||||
|  |           RUST_MIN_STACK: 10485760000 | ||||||
|       - name: Build and archive tests |       - name: Build and archive tests | ||||||
|         run: | |         run: | | ||||||
|           cd rust |           cd rust | ||||||
| @ -155,7 +163,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ |           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||||
|       - name: Install rust |       - name: Install Rust | ||||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 |         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           cache: false # Configured below. |           cache: false # Configured below. | ||||||
| @ -182,6 +190,7 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} |           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN_DEV}} | ||||||
|           ZOO_HOST: https://api.dev.zoo.dev |           ZOO_HOST: https://api.dev.zoo.dev | ||||||
|  |           RUST_MIN_STACK: 10485760000 | ||||||
|       - name: Upload results |       - name: Upload results | ||||||
|         if: always() |         if: always() | ||||||
|         run: .github/ci-cd-scripts/upload-results.sh |         run: .github/ci-cd-scripts/upload-results.sh | ||||||
| @ -190,6 +199,56 @@ jobs: | |||||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} |           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} |           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} |           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@v1 | ||||||
|  |       - 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 }} | ||||||
|  |       - 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: |   run-wasm-tests: | ||||||
|     name: Run wasm tests |     name: Run wasm tests | ||||||
|     strategy: |     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, |  | ||||||
|               }); |  | ||||||
|             } |  | ||||||
							
								
								
									
										283
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										283
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,4 +1,5 @@ | |||||||
| name: E2E Tests | name: E2E Tests | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
| @ -18,73 +19,15 @@ permissions: | |||||||
|  |  | ||||||
| jobs: | 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: |   prepare-wasm: | ||||||
|  |  | ||||||
|     # separate job on Ubuntu to build or fetch the wasm blob once on the fastest runner |     # 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 |     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||||
|     needs: conditions |  | ||||||
|     steps: |     steps: | ||||||
|  |  | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|  |  | ||||||
|       - id: filter |       - id: filter | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         name: Check for Rust changes |         name: Check for Rust changes | ||||||
|         uses: dorny/paths-filter@v3 |         uses: dorny/paths-filter@v3 | ||||||
|         with: |         with: | ||||||
| @ -93,18 +36,16 @@ jobs: | |||||||
|               - 'rust/**' |               - 'rust/**' | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |       - uses: actions/setup-node@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.nvmrc' |           node-version-file: '.nvmrc' | ||||||
|           cache: 'npm' |           cache: 'npm' | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: npm install |         run: npm install | ||||||
|  |  | ||||||
|       - name: Download Wasm Cache |       - name: Download Wasm cache | ||||||
|         id: download-wasm |         id: download-wasm | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && github.event_name != 'schedule' && steps.filter.outputs.rust == 'false' }} |         if: ${{ github.event_name != 'schedule' && steps.filter.outputs.rust == 'false' }} | ||||||
|         uses: dawidd6/action-download-artifact@v7 |         uses: dawidd6/action-download-artifact@v7 | ||||||
|         continue-on-error: true |         continue-on-error: true | ||||||
|         with: |         with: | ||||||
| @ -114,9 +55,8 @@ jobs: | |||||||
|           branch: main |           branch: main | ||||||
|           path: rust/kcl-wasm-lib/pkg |           path: rust/kcl-wasm-lib/pkg | ||||||
|  |  | ||||||
|       - name: Build WASM condition |       - name: Build Wasm condition | ||||||
|         id: wasm |         id: wasm | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: | |         run: | | ||||||
|           set -euox pipefail |           set -euox pipefail | ||||||
|           # Build wasm if this is a scheduled run, there are Rust changes, or |           # Build wasm if this is a scheduled run, there are Rust changes, or | ||||||
| @ -128,47 +68,48 @@ jobs: | |||||||
|           fi |           fi | ||||||
|  |  | ||||||
|       - name: Use correct Rust toolchain |       - 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 |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ |           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ | ||||||
|  |  | ||||||
|       - name: Install rust |       - name: Install Rust | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} |         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 |         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           cache: false # Configured below. |           cache: false # Configured below. | ||||||
|  |  | ||||||
|       - uses: taiki-e/install-action@d4635f2de61c8b8104d59cd4aede2060638378cc |       - 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: |         with: | ||||||
|           tool: wasm-pack |           tool: wasm-pack | ||||||
|  |  | ||||||
|       - name: Rust Cache |       - name: Use Rust cache | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} |         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||||
|         uses: Swatinem/rust-cache@v2 |         uses: Swatinem/rust-cache@v2 | ||||||
|         with: |         with: | ||||||
|           workspaces: './rust' |           workspaces: './rust' | ||||||
|  |  | ||||||
|       - name: Build Wasm |       - 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 |         shell: bash | ||||||
|         run: npm run build:wasm |         run: npm run build:wasm | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         with: |         with: | ||||||
|           name: prepared-wasm |           name: prepared-wasm | ||||||
|           path: | |           path: | | ||||||
|             rust/kcl-wasm-lib/pkg/kcl_wasm_lib* |             rust/kcl-wasm-lib/pkg/kcl_wasm_lib* | ||||||
|  |  | ||||||
|   snapshots: |   snapshots: | ||||||
|     name: playwright:snapshots:ubuntu |     needs: [prepare-wasm] | ||||||
|  |  | ||||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 |     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||||
|     needs: [conditions, prepare-wasm] |     name: e2e:snapshots | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|  |  | ||||||
|       - uses: actions/create-github-app-token@v1 |       - uses: actions/create-github-app-token@v1 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         id: app-token |         id: app-token | ||||||
|         with: |         with: | ||||||
|           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} |           app-id: ${{ secrets.MODELING_APP_GH_APP_ID }} | ||||||
| @ -176,16 +117,13 @@ jobs: | |||||||
|           owner: ${{ github.repository_owner }} |           owner: ${{ github.repository_owner }} | ||||||
|  |  | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         with: |         with: | ||||||
|           token: ${{ steps.app-token.outputs.token }} |           token: ${{ steps.app-token.outputs.token }} | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         name: prepared-wasm |         name: prepared-wasm | ||||||
|  |  | ||||||
|       - name: Copy prepared wasm |       - name: Copy prepared Wasm | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-wasm |           ls -R prepared-wasm | ||||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public |           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||||
| @ -193,34 +131,24 @@ jobs: | |||||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg |           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |       - uses: actions/setup-node@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.nvmrc' |           node-version-file: '.nvmrc' | ||||||
|           cache: 'npm' |           cache: 'npm' | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         id: deps-install |  | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: npm install |         run: npm install | ||||||
|  |  | ||||||
|       - name: Cache Playwright Browsers |       - name: Download browser cache | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         uses: actions/cache@v4 |         uses: actions/cache@v4 | ||||||
|         with: |         with: | ||||||
|           path: | |           path: | | ||||||
|             ~/.cache/ms-playwright/ |             ~/.cache/ms-playwright/ | ||||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} |           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} | ||||||
|  |  | ||||||
|       - name: Install Playwright Browsers |       - name: Install browsers | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: npm run playwright install --with-deps |         run: npm run playwright install --with-deps | ||||||
|  |  | ||||||
|       - name: build web |       - name: npm run test:snapshots | ||||||
|         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' |  | ||||||
|         uses: nick-fields/retry@v3.0.2 |         uses: nick-fields/retry@v3.0.2 | ||||||
|         with: |         with: | ||||||
|           shell: bash |           shell: bash | ||||||
| @ -233,10 +161,23 @@ jobs: | |||||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} |           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} |           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} |           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||||
|  |           CI_SUITE: e2e:snapshots | ||||||
|  |           TARGET: web | ||||||
|  |  | ||||||
|  |       - 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 |           TARGET: web | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} |         if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|         with: |         with: | ||||||
|           name: playwright-report-ubuntu-snapshot-${{ github.sha }} |           name: playwright-report-ubuntu-snapshot-${{ github.sha }} | ||||||
|           path: playwright-report/ |           path: playwright-report/ | ||||||
| @ -244,20 +185,19 @@ jobs: | |||||||
|           retention-days: 30 |           retention-days: 30 | ||||||
|           overwrite: true |           overwrite: true | ||||||
|  |  | ||||||
|       - name: Check for changes |       - name: Check diff | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && github.ref != 'refs/heads/main' }} |         if: ${{ github.ref != 'refs/heads/main' }} | ||||||
|         shell: bash |         shell: bash | ||||||
|         id: git-check |         id: git-check | ||||||
|         run: | |         run: | | ||||||
|             git add e2e/playwright/snapshot-tests.spec.ts-snapshots e2e/playwright/snapshots |             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 |             then echo "modified=true" >> $GITHUB_OUTPUT | ||||||
|             else echo "modified=false" >> $GITHUB_OUTPUT |             else echo "modified=false" >> $GITHUB_OUTPUT | ||||||
|             fi |             fi | ||||||
|  |  | ||||||
|       - name: Commit changes, if any |       - name: Commit changes | ||||||
|         # TODO: find a more reliable way to detect visual changes |         if: ${{ steps.git-check.outputs.modified == 'true' }} | ||||||
|         if: ${{ false && needs.conditions.outputs.should-run == 'true' && steps.git-check.outputs.modified == 'true' }} |  | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           git add e2e/playwright/snapshot-tests.spec.ts-snapshots e2e/playwright/snapshots |           git add e2e/playwright/snapshot-tests.spec.ts-snapshots e2e/playwright/snapshots | ||||||
| @ -267,16 +207,100 @@ jobs: | |||||||
|           git fetch origin |           git fetch origin | ||||||
|           echo ${{ github.head_ref }} |           echo ${{ github.head_ref }} | ||||||
|           git checkout ${{ 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 | ||||||
|           git push origin ${{ github.head_ref }} |           git push origin ${{ github.head_ref }} | ||||||
|  |  | ||||||
|   electron: |   web: | ||||||
|     needs: [conditions, prepare-wasm] |     needs: [prepare-wasm] | ||||||
|     timeout-minutes: 60 |  | ||||||
|  |     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: windows-latest-8-cores | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     name: e2e:web (${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}) | ||||||
|     env: |     env: | ||||||
|       OS_NAME: ${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} |       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 }}) |  | ||||||
|  |     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/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 | ||||||
|  |  | ||||||
|  |       - uses: actions/upload-artifact@v4 | ||||||
|  |         if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |         with: | ||||||
|  |           path: playwright-report/ | ||||||
|  |           include-hidden-files: true | ||||||
|  |           retention-days: 30 | ||||||
|  |           overwrite: true | ||||||
|  |  | ||||||
|  |   desktop: | ||||||
|  |     needs: [prepare-wasm] | ||||||
|  |  | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
| @ -308,21 +332,28 @@ jobs: | |||||||
|             shardTotal: 8 |             shardTotal: 8 | ||||||
|           - os: namespace-profile-macos-8-cores |           - os: namespace-profile-macos-8-cores | ||||||
|             shardIndex: 1 |             shardIndex: 1 | ||||||
|             shardTotal: 1 |             shardTotal: 2 | ||||||
|  |           - os: namespace-profile-macos-8-cores | ||||||
|  |             shardIndex: 2 | ||||||
|  |             shardTotal: 2 | ||||||
|           - os: windows-latest-8-cores |           - os: windows-latest-8-cores | ||||||
|             shardIndex: 1 |             shardIndex: 1 | ||||||
|             shardTotal: 1 |             shardTotal: 2 | ||||||
|  |           - os: windows-latest-8-cores | ||||||
|  |             shardIndex: 2 | ||||||
|  |             shardTotal: 2 | ||||||
|     runs-on: ${{ matrix.os }} |     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: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         name: prepared-wasm |         name: prepared-wasm | ||||||
|  |  | ||||||
|       - name: Copy prepared wasm |       - name: Copy prepared Wasm | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-wasm |           ls -R prepared-wasm | ||||||
|           cp prepared-wasm/kcl_wasm_lib_bg.wasm public |           cp prepared-wasm/kcl_wasm_lib_bg.wasm public | ||||||
| @ -330,49 +361,44 @@ jobs: | |||||||
|           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg |           cp prepared-wasm/kcl_wasm_lib* rust/kcl-wasm-lib/pkg | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |       - uses: actions/setup-node@v4 | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.nvmrc' |           node-version-file: '.nvmrc' | ||||||
|           cache: 'npm' |           cache: 'npm' | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         id: deps-install |         id: deps-install | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: npm install |         run: npm install | ||||||
|  |  | ||||||
|       - name: Cache Playwright Browsers |       - name: Download browser cache | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         uses: actions/cache@v4 |         uses: actions/cache@v4 | ||||||
|         with: |         with: | ||||||
|           path: | |           path: | | ||||||
|             ~/.cache/ms-playwright/ |             ~/.cache/ms-playwright/ | ||||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} |           key: ${{ runner.os }}-playwright-${{ hashFiles('package-lock.json') }} | ||||||
|  |  | ||||||
|       - name: Install Playwright Browsers |       - name: Install browsers | ||||||
|         if: needs.conditions.outputs.should-run == 'true' |  | ||||||
|         run: npm run playwright install --with-deps |         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 |       - 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 |         run: .github/ci-cd-scripts/start-vector-${{ env.OS_NAME }}.sh | ||||||
|         env: |         env: | ||||||
|           GH_ACTIONS_AXIOM_TOKEN: ${{ secrets.GH_ACTIONS_AXIOM_TOKEN }} |           GH_ACTIONS_AXIOM_TOKEN: ${{ secrets.GH_ACTIONS_AXIOM_TOKEN }} | ||||||
|           OS_NAME: ${{ env.OS_NAME }} |           OS_NAME: ${{ env.OS_NAME }} | ||||||
|  |  | ||||||
|  |       - name: Build app | ||||||
|  |         run: npm run tronb:vite:dev | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} |         if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|         continue-on-error: true |         continue-on-error: true | ||||||
|         with: |         with: | ||||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} |           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: test-results/ |           path: test-results/ | ||||||
|  |  | ||||||
|       - name: Run playwright/electron flow (with retries) |       - name: npm run test:e2e:desktop | ||||||
|         id: retry |         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 |         uses: nick-fields/retry@v3.0.2 | ||||||
|         with: |         with: | ||||||
|           shell: bash |           shell: bash | ||||||
| @ -386,10 +412,11 @@ jobs: | |||||||
|           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} |           TAB_API_KEY: ${{ secrets.TAB_API_KEY }} | ||||||
|           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} |           CI_COMMIT_SHA: ${{ github.event.pull_request.head.sha }} | ||||||
|           CI_PR_NUMBER: ${{ github.event.pull_request.number }} |           CI_PR_NUMBER: ${{ github.event.pull_request.number }} | ||||||
|  |           CI_SUITE: e2e:desktop | ||||||
|           TARGET: desktop |           TARGET: desktop | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} |         if: always() | ||||||
|         with: |         with: | ||||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} |           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: test-results/ |           path: test-results/ | ||||||
| @ -398,7 +425,7 @@ jobs: | |||||||
|           overwrite: true |           overwrite: true | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} |         if: always() | ||||||
|         with: |         with: | ||||||
|           name: playwright-report-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} |           name: playwright-report-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: playwright-report/ |           path: playwright-report/ | ||||||
|  | |||||||
							
								
								
									
										61
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										61
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							| @ -21,14 +21,11 @@ on: | |||||||
|       - '**.rs' |       - '**.rs' | ||||||
|       - .github/workflows/kcl-language-server.yml |       - .github/workflows/kcl-language-server.yml | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|   cancel-in-progress: true |   cancel-in-progress: true | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   CARGO_INCREMENTAL: 0 |   CARGO_INCREMENTAL: 0 | ||||||
|   CARGO_NET_RETRY: 10 |   CARGO_NET_RETRY: 10 | ||||||
| @ -38,10 +35,9 @@ env: | |||||||
|   MACOSX_DEPLOYMENT_TARGET: 10.15 |   MACOSX_DEPLOYMENT_TARGET: 10.15 | ||||||
|   CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER: aarch64-linux-gnu-gcc |   CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER: aarch64-linux-gnu-gcc | ||||||
|   CARGO_TARGET_ARM_UNKNOWN_LINUX_GNUEABIHF_LINKER: arm-linux-gnueabihf-gcc |   CARGO_TARGET_ARM_UNKNOWN_LINUX_GNUEABIHF_LINKER: arm-linux-gnueabihf-gcc | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   test: |   test: | ||||||
|     name: vscode tests |     name: kcl-language-server (vscode tests) | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
| @ -77,8 +73,7 @@ jobs: | |||||||
|         include: |         include: | ||||||
|           - os: windows-latest |           - os: windows-latest | ||||||
|             target: x86_64-pc-windows-msvc |             target: x86_64-pc-windows-msvc | ||||||
|             code-target: |             code-target: win32-x64 | ||||||
|               win32-x64 |  | ||||||
|             #- os: windows-latest |             #- os: windows-latest | ||||||
|             #target: i686-pc-windows-msvc |             #target: i686-pc-windows-msvc | ||||||
|             #code-target: |             #code-target: | ||||||
| @ -88,8 +83,7 @@ jobs: | |||||||
|             #code-target: win32-arm64 |             #code-target: win32-arm64 | ||||||
|           - os: ubuntu-latest |           - os: ubuntu-latest | ||||||
|             target: x86_64-unknown-linux-gnu |             target: x86_64-unknown-linux-gnu | ||||||
|             code-target: |             code-target: linux-x64 | ||||||
|               linux-x64 |  | ||||||
|             #- os: ubuntu-latest |             #- os: ubuntu-latest | ||||||
|             #target: aarch64-unknown-linux-musl |             #target: aarch64-unknown-linux-musl | ||||||
|             #code-target: linux-arm64 |             #code-target: linux-arm64 | ||||||
| @ -105,41 +99,33 @@ jobs: | |||||||
|           - os: macos-latest |           - os: macos-latest | ||||||
|             target: aarch64-apple-darwin |             target: aarch64-apple-darwin | ||||||
|             code-target: darwin-arm64 |             code-target: darwin-arm64 | ||||||
|  |     name: kcl-language-server build-release (${{ matrix.target }}) | ||||||
|     name: build-release (${{ matrix.target }}) |  | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     container: ${{ matrix.container }} |     container: ${{ matrix.container }} | ||||||
|  |  | ||||||
|     env: |     env: | ||||||
|       RA_TARGET: ${{ matrix.target }} |       RA_TARGET: ${{ matrix.target }} | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} |           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||||
|  |  | ||||||
|       - name: Use correct Rust toolchain |       - name: Use correct Rust toolchain | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           rm rust/rust-toolchain.toml |           rm rust/rust-toolchain.toml | ||||||
|  |  | ||||||
|       - name: Install rust |       - name: Install rust | ||||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 |         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           cache: rust |           cache: rust | ||||||
|           components: rust-src |           components: rust-src | ||||||
|           target: ${{ matrix.target }} |           target: ${{ matrix.target }} | ||||||
|  |  | ||||||
|       - name: Install Node.js |       - name: Install Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           node-version-file: ".nvmrc" |           node-version-file: ".nvmrc" | ||||||
|  |  | ||||||
|       - name: Update apt repositories |       - name: Update apt repositories | ||||||
|         if: matrix.target == 'aarch64-unknown-linux-gnu' || matrix.target == 'arm-unknown-linux-gnueabihf' || matrix.os == 'ubuntu-latest' |         if: matrix.target == 'aarch64-unknown-linux-gnu' || matrix.target == 'arm-unknown-linux-gnueabihf' || matrix.os == 'ubuntu-latest' | ||||||
|         run: sudo apt-get update |         run: sudo apt-get update | ||||||
|  |  | ||||||
|       - if: ${{ matrix.os == 'ubuntu-latest' }} |       - if: ${{ matrix.os == 'ubuntu-latest' }} | ||||||
|         name: Install deps |         name: Install deps | ||||||
|         shell: bash |         shell: bash | ||||||
| @ -164,64 +150,53 @@ jobs: | |||||||
|             zlib1g-dev |             zlib1g-dev | ||||||
|  |  | ||||||
|           cargo install cross |           cargo install cross | ||||||
|  |  | ||||||
|       - name: Install AArch64 target toolchain |       - name: Install AArch64 target toolchain | ||||||
|         if: matrix.target == 'aarch64-unknown-linux-gnu' |         if: matrix.target == 'aarch64-unknown-linux-gnu' | ||||||
|         run: sudo apt-get install gcc-aarch64-linux-gnu |         run: sudo apt-get install gcc-aarch64-linux-gnu | ||||||
|  |  | ||||||
|       - name: Install ARM target toolchain |       - name: Install ARM target toolchain | ||||||
|         if: matrix.target == 'arm-unknown-linux-gnueabihf' |         if: matrix.target == 'arm-unknown-linux-gnueabihf' | ||||||
|         run: sudo apt-get install gcc-arm-linux-gnueabihf |         run: sudo apt-get install gcc-arm-linux-gnueabihf | ||||||
|  |  | ||||||
|       - name: build |       - name: build | ||||||
|         run: | |         run: | | ||||||
|           cd rust |           cd rust | ||||||
|           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} |           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           # npm will symlink which will cause issues w tarballing later |           # npm will symlink which will cause issues w tarballing later | ||||||
|           yarn install |           yarn install | ||||||
|  |  | ||||||
|       - name: Package Extension (release) |       - name: Package Extension (release) | ||||||
|         if: startsWith(github.event.ref, 'refs/tags/') |         if: startsWith(github.event.ref, 'refs/tags/') | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} |           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} | ||||||
|  |  | ||||||
|       - name: Package Extension (nightly) |       - name: Package Extension (nightly) | ||||||
|         if: startsWith(github.event.ref, 'refs/tags/') == false |         if: startsWith(github.event.ref, 'refs/tags/') == false | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} --pre-release |           npx vsce package --yarn -o "../build/kcl-language-server-${{ matrix.code-target }}.vsix" --target ${{ matrix.code-target }} --pre-release | ||||||
|  |  | ||||||
|       - name: remove server |       - name: remove server | ||||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' |         if: matrix.target == 'x86_64-unknown-linux-gnu' | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           rm -rf server |           rm -rf server | ||||||
|  |  | ||||||
|       - name: Package Extension (no server, release) |       - name: Package Extension (no server, release) | ||||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') |         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix |           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix | ||||||
|  |  | ||||||
|       - name: Package Extension (no server, nightly) |       - name: Package Extension (no server, nightly) | ||||||
|         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') == false |         if: matrix.target == 'x86_64-unknown-linux-gnu' && startsWith(github.event.ref, 'refs/tags/') == false | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix --pre-release |           npx vsce package --yarn -o ../build/kcl-language-server-no-server.vsix --pre-release | ||||||
|  |  | ||||||
|       - name: Upload artifacts |       - name: Upload artifacts | ||||||
|         uses: actions/upload-artifact@v4 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: release-${{ matrix.target }} |           name: release-${{ matrix.target }} | ||||||
|           path: ./rust/build |           path: ./rust/build | ||||||
|  |  | ||||||
|   build-release-x86_64-unknown-linux-musl: |   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 |     runs-on: ubuntu-latest | ||||||
|     env: |     env: | ||||||
|       RA_TARGET: x86_64-unknown-linux-musl |       RA_TARGET: x86_64-unknown-linux-musl | ||||||
| @ -231,7 +206,6 @@ jobs: | |||||||
|       image: alpine:latest |       image: alpine:latest | ||||||
|       volumes: |       volumes: | ||||||
|         - /usr/local/cargo/registry:/usr/local/cargo/registry |         - /usr/local/cargo/registry:/usr/local/cargo/registry | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: | |         run: | | ||||||
| @ -245,55 +219,46 @@ jobs: | |||||||
|             nodejs \ |             nodejs \ | ||||||
|             npm \ |             npm \ | ||||||
|             yarn |             yarn | ||||||
|  |  | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} |           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||||
|  |  | ||||||
|       - name: Use correct Rust toolchain |       - name: Use correct Rust toolchain | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           rm rust/rust-toolchain.toml |           rm rust/rust-toolchain.toml | ||||||
|  |  | ||||||
|       - name: Install rust |       - name: Install rust | ||||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 |         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           cache: rust |           cache: rust | ||||||
|           components: rust-src |           components: rust-src | ||||||
|           target: ${{ matrix.target }} |           target: ${{ matrix.target }} | ||||||
|  |  | ||||||
|       - name: build |       - name: build | ||||||
|         run: | |         run: | | ||||||
|           cd rust |           cd rust | ||||||
|           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} |           cargo kcl-language-server-release build --client-patch-version ${{ github.run_number }} | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           # npm will symlink which will cause issues w tarballing later |           # npm will symlink which will cause issues w tarballing later | ||||||
|           yarn install |           yarn install | ||||||
|  |  | ||||||
|       - name: Package Extension (release) |       - name: Package Extension (release) | ||||||
|         if: startsWith(github.event.ref, 'refs/tags/') |         if: startsWith(github.event.ref, 'refs/tags/') | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 |           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 | ||||||
|  |  | ||||||
|       - name: Package Extension (release) |       - name: Package Extension (release) | ||||||
|         if: startsWith(github.event.ref, 'refs/tags/') == false |         if: startsWith(github.event.ref, 'refs/tags/') == false | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 --pre-release |           npx vsce package --yarn -o "../build/kcl-language-server-alpine-x64.vsix" --target alpine-x64 --pre-release | ||||||
|  |  | ||||||
|       - name: Upload artifacts |       - name: Upload artifacts | ||||||
|         uses: actions/upload-artifact@v4 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: release-x86_64-unknown-linux-musl |           name: release-x86_64-unknown-linux-musl | ||||||
|           path: ./rust/build |           path: ./rust/build | ||||||
|  |  | ||||||
|   publish: |   publish: | ||||||
|     name: publish |     name: kcl-language-server (publish) | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     needs: ["build-release", "build-release-x86_64-unknown-linux-musl"] |     needs: ["build-release", "build-release-x86_64-unknown-linux-musl"] | ||||||
|     if: startsWith(github.event.ref, 'refs/tags') |     if: startsWith(github.event.ref, 'refs/tags') | ||||||
| @ -301,22 +266,17 @@ jobs: | |||||||
|       contents: write |       contents: write | ||||||
|     steps: |     steps: | ||||||
|       - run: echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV |       - run: echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV | ||||||
|  |  | ||||||
|       - run: 'echo "TAG: $TAG"' |       - run: 'echo "TAG: $TAG"' | ||||||
|  |  | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: ${{ env.FETCH_DEPTH }} |           fetch-depth: ${{ env.FETCH_DEPTH }} | ||||||
|  |  | ||||||
|       - name: Install Nodejs |       - name: Install Nodejs | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           node-version-file: ".nvmrc" |           node-version-file: ".nvmrc" | ||||||
|  |  | ||||||
|       - run: echo "HEAD_SHA=$(git rev-parse HEAD)" >> $GITHUB_ENV |       - run: echo "HEAD_SHA=$(git rev-parse HEAD)" >> $GITHUB_ENV | ||||||
|       - run: 'echo "HEAD_SHA: $HEAD_SHA"' |       - run: 'echo "HEAD_SHA: $HEAD_SHA"' | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: release-aarch64-apple-darwin |           name: release-aarch64-apple-darwin | ||||||
| @ -344,8 +304,7 @@ jobs: | |||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: release-x86_64-pc-windows-msvc |           name: release-x86_64-pc-windows-msvc | ||||||
|           path: |           path: rust/build | ||||||
|             rust/build |  | ||||||
|           #- uses: actions/download-artifact@v4 |           #- uses: actions/download-artifact@v4 | ||||||
|           #with: |           #with: | ||||||
|           #name: release-i686-pc-windows-msvc |           #name: release-i686-pc-windows-msvc | ||||||
| @ -356,21 +315,18 @@ jobs: | |||||||
|           #name: release-aarch64-pc-windows-msvc |           #name: release-aarch64-pc-windows-msvc | ||||||
|           #path: rust/build |           #path: rust/build | ||||||
|       - run: ls -al ./rust/build |       - run: ls -al ./rust/build | ||||||
|  |  | ||||||
|       - name: Publish Release |       - name: Publish Release | ||||||
|         uses: ./.github/actions/github-release |         uses: ./.github/actions/github-release | ||||||
|         with: |         with: | ||||||
|           files: "rust/build/*" |           files: "rust/build/*" | ||||||
|           name: ${{ env.TAG }} |           name: ${{ env.TAG }} | ||||||
|           token: ${{ secrets.GITHUB_TOKEN }} |           token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|       - name: move files to dir for upload |       - name: move files to dir for upload | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           cd rust |           cd rust | ||||||
|           mkdir -p releases/language-server/${{ env.TAG }} |           mkdir -p releases/language-server/${{ env.TAG }} | ||||||
|           cp -r build/* releases/language-server/${{ env.TAG }} |           cp -r build/* releases/language-server/${{ env.TAG }} | ||||||
|  |  | ||||||
|       - name: "Authenticate to Google Cloud" |       - name: "Authenticate to Google Cloud" | ||||||
|         uses: "google-github-actions/auth@v2.1.8" |         uses: "google-github-actions/auth@v2.1.8" | ||||||
|         with: |         with: | ||||||
| @ -385,15 +341,12 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           path: rust/releases |           path: rust/releases | ||||||
|           destination: dl.kittycad.io |           destination: dl.kittycad.io | ||||||
|  |  | ||||||
|       - run: rm rust/build/kcl-language-server-no-server.vsix |       - run: rm rust/build/kcl-language-server-no-server.vsix | ||||||
|  |  | ||||||
|       - name: Publish Extension (Code Marketplace, release) |       - name: Publish Extension (Code Marketplace, release) | ||||||
|         # token from https://dev.azure.com/kcl-language-server/ |         # token from https://dev.azure.com/kcl-language-server/ | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|           npx vsce publish --pat ${{ secrets.VSCE_PAT }} --packagePath ../build/kcl-language-server-*.vsix |           npx vsce publish --pat ${{ secrets.VSCE_PAT }} --packagePath ../build/kcl-language-server-*.vsix | ||||||
|  |  | ||||||
|       - name: Publish Extension (OpenVSX, release) |       - name: Publish Extension (OpenVSX, release) | ||||||
|         run: | |         run: | | ||||||
|           cd rust/kcl-language-server |           cd rust/kcl-language-server | ||||||
|  | |||||||
							
								
								
									
										14
									
								
								.github/workflows/kcl-python-bindings.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/kcl-python-bindings.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,6 @@ | |||||||
| #    maturin generate-ci github | #    maturin generate-ci github | ||||||
| # | # | ||||||
| name: kcl-python-bindings | name: kcl-python-bindings | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
| @ -27,16 +26,14 @@ on: | |||||||
|       - '**.rs' |       - '**.rs' | ||||||
|       - .github/workflows/kcl-python-bindings.yml |       - .github/workflows/kcl-python-bindings.yml | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|   cancel-in-progress: true |   cancel-in-progress: true | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   linux-x86_64: |   linux-x86_64: | ||||||
|  |     name: kcl-python-bindings (linux-x86_64) | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @ -58,8 +55,8 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           name: wheels-linux-x86_64 |           name: wheels-linux-x86_64 | ||||||
|           path: rust/kcl-python-bindings/dist |           path: rust/kcl-python-bindings/dist | ||||||
|  |  | ||||||
|   windows: |   windows: | ||||||
|  |     name: kcl-python-bindings (windows) | ||||||
|     runs-on: windows-16-cores |     runs-on: windows-16-cores | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
| @ -84,8 +81,8 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           name: wheels-windows-${{ matrix.target }} |           name: wheels-windows-${{ matrix.target }} | ||||||
|           path: rust/kcl-python-bindings/dist |           path: rust/kcl-python-bindings/dist | ||||||
|  |  | ||||||
|   macos: |   macos: | ||||||
|  |     name: kcl-python-bindings (macos) | ||||||
|     runs-on: macos-latest |     runs-on: macos-latest | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
| @ -110,8 +107,8 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           name: wheels-macos-${{ matrix.target }} |           name: wheels-macos-${{ matrix.target }} | ||||||
|           path: rust/kcl-python-bindings/dist |           path: rust/kcl-python-bindings/dist | ||||||
|  |  | ||||||
|   test: |   test: | ||||||
|  |     name: kcl-python-bindings (test) | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @ -127,8 +124,8 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           KITTYCAD_API_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |           KITTYCAD_API_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|           ZOO_HOST: https://api.dev.zoo.dev |           ZOO_HOST: https://api.dev.zoo.dev | ||||||
|  |  | ||||||
|   sdist: |   sdist: | ||||||
|  |     name: kcl-python-bindings (sdist) | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @ -151,7 +148,6 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           name: wheels-sdist |           name: wheels-sdist | ||||||
|           path: rust/kcl-python-bindings/dist |           path: rust/kcl-python-bindings/dist | ||||||
|  |  | ||||||
|   release: |   release: | ||||||
|     name: Release |     name: Release | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  | |||||||
							
								
								
									
										161
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										161
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -28,53 +28,7 @@ jobs: | |||||||
|       - run: npm run fmt:check |       - run: npm run fmt:check | ||||||
|  |  | ||||||
|   npm-build-wasm: |   npm-build-wasm: | ||||||
|     # Build the wasm blob once on the fastest runner. |     uses: ./.github/workflows/build-wasm.yml | ||||||
|     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/* |  | ||||||
|  |  | ||||||
|   npm-tsc: |   npm-tsc: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
| @ -173,116 +127,3 @@ jobs: | |||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|       - name: Run codespell |       - name: Run codespell | ||||||
|         uses: crate-ci/typos@v1.32.0 |         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 | ||||||
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -58,6 +58,8 @@ trace.zip | |||||||
| /public/kcl-samples/.github | /public/kcl-samples/.github | ||||||
| /public/kcl-samples/screenshots/main.kcl | /public/kcl-samples/screenshots/main.kcl | ||||||
| /public/kcl-samples/step/main.kcl | /public/kcl-samples/step/main.kcl | ||||||
|  | /public/kcl-samples/internal | ||||||
|  | /rust/kcl-lib/tests/kcl_samples/internal | ||||||
| /test-results/ | /test-results/ | ||||||
| /playwright-report/ | /playwright-report/ | ||||||
| /blob-report/ | /blob-report/ | ||||||
|  | |||||||
							
								
								
									
										224
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										224
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| # Contributor Guide | # 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). | 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 | npm run install:wasm-pack:cargo | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Then to build the WASM layer, run: | ## Building the app | ||||||
|  |  | ||||||
|  | To build the WASM layer, run: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| # macOS/Linux | # 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 | the eye with a slash through it in the URL bar, and clicking on "Enable | ||||||
| Third-Party Cookies". | 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: | 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). | 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 | ## Running tests | ||||||
|  |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| ### Playwright tests | ### Playwright tests | ||||||
|  |  | ||||||
| @ -204,7 +100,7 @@ Prepare these system dependencies: | |||||||
|  |  | ||||||
| #### Snapshot tests (Google Chrome on Ubuntu only) | #### 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. | If you don't run Ubuntu locally or in a VM, you may use a GitHub Codespace. | ||||||
| ``` | ``` | ||||||
| npm run playwright -- install chrome | npm run playwright -- install chrome | ||||||
| @ -212,14 +108,21 @@ npm run test:snapshots | |||||||
| ``` | ``` | ||||||
| You may use `-- --update-snapshots` as needed. | 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 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. | 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 | #### 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. | 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,103 @@ then run tests that target the KCL language: | |||||||
| npm run test:rust | 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 | ### 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 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`. | To enable memory metrics, build with `--features dhat-heap`. | ||||||
|  |  | ||||||
|  | ## 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 | ||||||
|  |  | ||||||
|  | It will be used to document 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 | ||||||
|  |  | ||||||
|  | ##### 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 step 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. | ||||||
|  |  | ||||||
|  | A prompt should show up asking for a downgrade to the last release version. Running through that at the end of testing | ||||||
|  | and making sure the current release candidate has the ability to be updated to what electron-updater points to is critical, | ||||||
|  | but what is actually being downloaded and installed isn't. | ||||||
|  | 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. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | # 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. 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. | ||||||
|  |  | ||||||
|  | #### 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. | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | |||||||
|  |  | ||||||
| ## Windows | ## 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. | 2. Once downloaded, run the installer `Zoo Design Studio-{version}-{arch}-win.exe` which should take a few seconds. | ||||||
|  |  | ||||||
| @ -12,7 +12,7 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | |||||||
|  |  | ||||||
| ## macOS | ## 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. | 2. Once downloaded, open the disk image `Zoo Design Studio-{version}-{arch}-mac.dmg` and drag the applications to your `Applications` directory. | ||||||
|  |  | ||||||
| @ -21,7 +21,7 @@ Compared to other CAD software, getting Zoo Design Studio up and running is quic | |||||||
|  |  | ||||||
| ## 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/). | 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. |     -  On Ubuntu, install the FUSE library with these commands in a terminal. | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								Makefile
									
									
									
									
									
								
							| @ -23,6 +23,7 @@ endif | |||||||
| install: node_modules/.package-lock.json $(CARGO) $(WASM_PACK) ## Install dependencies | install: node_modules/.package-lock.json $(CARGO) $(WASM_PACK) ## Install dependencies | ||||||
|  |  | ||||||
| node_modules/.package-lock.json: package.json package-lock.json | node_modules/.package-lock.json: package.json package-lock.json | ||||||
|  | 	npm prune | ||||||
| 	npm install | 	npm install | ||||||
|  |  | ||||||
| $(CARGO): | $(CARGO): | ||||||
| @ -43,15 +44,15 @@ endif | |||||||
| # BUILD | # BUILD | ||||||
|  |  | ||||||
| CARGO_SOURCES := rust/.cargo/config.toml $(wildcard rust/Cargo.*) $(wildcard rust/**/Cargo.*) | CARGO_SOURCES := rust/.cargo/config.toml $(wildcard rust/Cargo.*) $(wildcard rust/**/Cargo.*) | ||||||
|  | KCL_SOURCES := $(wildcard public/kcl-samples/**/*.kcl) | ||||||
| RUST_SOURCES := $(wildcard rust/**/*.rs) | RUST_SOURCES := $(wildcard rust/**/*.rs) | ||||||
|  |  | ||||||
| REACT_SOURCES := $(wildcard src/*.tsx) $(wildcard src/**/*.tsx) | REACT_SOURCES := $(wildcard src/*.tsx) $(wildcard src/**/*.tsx) | ||||||
| TYPESCRIPT_SOURCES := tsconfig.* $(wildcard src/*.ts) $(wildcard src/**/*.ts) | TYPESCRIPT_SOURCES := tsconfig.* $(wildcard src/*.ts) $(wildcard src/**/*.ts) | ||||||
| VITE_SOURCES := $(wildcard vite.*) $(wildcard vite/**/*.tsx) | VITE_SOURCES := $(wildcard vite.*) $(wildcard vite/**/*.tsx) | ||||||
|  |  | ||||||
|  |  | ||||||
| .PHONY: build | .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) | public/kcl_wasm_lib_bg.wasm: $(CARGO_SOURCES) $(RUST_SOURCES) | ||||||
| ifdef WINDOWS | ifdef WINDOWS | ||||||
| @ -60,6 +61,9 @@ else | |||||||
| 	npm run build:wasm:dev | 	npm run build:wasm:dev | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | public/kcl-samples/manifest.json: $(KCL_SOURCES) | ||||||
|  | 	cd rust/kcl-lib && EXPECTORATE=overwrite cargo test generate_manifest | ||||||
|  |  | ||||||
| .vite/build/main.js: $(REACT_SOURCES) $(TYPESCRIPT_SOURCES) $(VITE_SOURCES) | .vite/build/main.js: $(REACT_SOURCES) $(TYPESCRIPT_SOURCES) $(VITE_SOURCES) | ||||||
| 	npm run tronb:vite:dev | 	npm run tronb:vite:dev | ||||||
|  |  | ||||||
| @ -107,6 +111,7 @@ test: test-unit test-e2e | |||||||
| .PHONY: test-unit | .PHONY: test-unit | ||||||
| test-unit: install ## Run the unit tests | test-unit: install ## Run the unit tests | ||||||
| 	npm run test:rust | 	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 ) | 	@ curl -fs localhost:3000 >/dev/null || ( echo "Error: localhost:3000 not available, 'make run-web' first" && exit 1 ) | ||||||
| 	npm run test:unit | 	npm run test:unit | ||||||
|  |  | ||||||
| @ -115,19 +120,18 @@ test-e2e: test-e2e-$(TARGET) | |||||||
|  |  | ||||||
| .PHONY: test-e2e-web | .PHONY: test-e2e-web | ||||||
| test-e2e-web: install build ## Run the web e2e tests | 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 | 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 | else | ||||||
| 	npm run chrome:test -- --headed --workers='100%' | 	npm run test:e2e:web -- --headed --workers='100%' | ||||||
| endif | endif | ||||||
|  |  | ||||||
| .PHONY: test-e2e-desktop | .PHONY: test-e2e-desktop | ||||||
| test-e2e-desktop: install build ## Run the desktop e2e tests | test-e2e-desktop: install build ## Run the desktop e2e tests | ||||||
| ifdef E2E_GREP | 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 | else | ||||||
| 	npm run test:playwright:electron -- --workers='100%' | 	npm run test:e2e:desktop -- --workers='100%' | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ############################################################################### | ############################################################################### | ||||||
|  | |||||||
							
								
								
									
										14
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								README.md
									
									
									
									
									
								
							| @ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| # Zoo Design Studio | # 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). | 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)) |   - WebSockets (via [KittyCAD TS client](https://github.com/KittyCAD/kittycad.ts)) | ||||||
| - Code Editor | - Code Editor | ||||||
|   - [CodeMirror](https://codemirror.net/) |   - [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 | - Modeling | ||||||
|   - [KittyCAD TypeScript client](https://github.com/KittyCAD/kittycad.ts) |   - [KittyCAD TypeScript client](https://github.com/KittyCAD/kittycad.ts) | ||||||
|  |  | ||||||
| ## Get Started | ## 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. | 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. | ||||||
|  |  | ||||||
| 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. |  | ||||||
|  |  | ||||||
| ## Developing | ## 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. | 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. | ||||||
|  |  | ||||||
| ## KCL |  | ||||||
|  |  | ||||||
| To contribute to the KittyCAD Language, see the [README](https://github.com/KittyCAD/modeling-app/tree/main/rust/kcl-lib) for KCL. |  | ||||||
|  | |||||||
| @ -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 | nwo = "nwo" # don't know what this is about tbh | ||||||
| "ot" = "ot" # some abbreviation, idk what | "ot" = "ot" # some abbreviation, idk what | ||||||
| "oe" = "oe" # some abbreviation, idk what | "oe" = "oe" # some abbreviation, idk what | ||||||
|  | "colinear" = "colinear" # some engine shit, kidding | ||||||
|  |  | ||||||
| [default] | [default] | ||||||
| extend-ignore-identifiers-re = [ | extend-ignore-identifiers-re = [ | ||||||
|  | |||||||
							
								
								
									
										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.  | ||||||
| @ -4,7 +4,7 @@ excerpt: "Documentation of the KCL language for the Zoo Design Studio." | |||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
| This is a reference for KCL. If you are learning KCL, you may prefer the [guide]() which explains | 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). | things in a more tutorial fashion. See also our documentation of the [standard library](/docs/kcl-std). | ||||||
|  |  | ||||||
| ## Topics | ## Topics | ||||||
| @ -14,6 +14,7 @@ things in a more tutorial fashion. See also our documentation of the [standard l | |||||||
| * [Values and types](/docs/kcl-lang/types) | * [Values and types](/docs/kcl-lang/types) | ||||||
| * [Numeric types and units](/docs/kcl-lang/numeric) | * [Numeric types and units](/docs/kcl-lang/numeric) | ||||||
| * [Functions](/docs/kcl-lang/functions) | * [Functions](/docs/kcl-lang/functions) | ||||||
|  | * [Arrays and ranges](/docs/kcl-lang/arrays) | ||||||
| * [Projects and modules](/docs/kcl-lang/modules) | * [Projects and modules](/docs/kcl-lang/modules) | ||||||
| * [Attributes](/docs/kcl-lang/attributes) | * [Attributes](/docs/kcl-lang/attributes) | ||||||
| * [Importing geometry from other CAD systems](/docs/kcl-lang/foreign-imports) | * [Importing geometry from other CAD systems](/docs/kcl-lang/foreign-imports) | ||||||
|  | |||||||
| @ -27,9 +27,6 @@ import increment from "util.kcl" | |||||||
| answer = increment(41) | 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 | 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. | 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" | 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` | ## 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. | result of a module as a variable, like a part. | ||||||
|  |  | ||||||
| ```norun | ```norun | ||||||
| import "tests/inputs/cube.kcl" as cube | import "cube.kcl" | ||||||
| cube | cube | ||||||
|   |> translate(x=10) |   |> 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 | entire module. The module is expected to return a single object that can be used | ||||||
| as a variable by the file that imports it. | 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 | ## 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. | [`clone`](/docs/kcl/clone) function. This will render a new instance of the object in memory. | ||||||
|  |  | ||||||
| ```norun | ```norun | ||||||
| import cube from "tests/inputs/cube.kcl" | import cube from "cube.kcl" | ||||||
|  |  | ||||||
| cube   | cube   | ||||||
|   |> translate(x=10) |   |> translate(x=10) | ||||||
| @ -257,7 +270,7 @@ separate objects in memory, and can be manipulated independently. | |||||||
| Here is an example with a file from another CAD system: | Here is an example with a file from another CAD system: | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| import "tests/inputs/cube.step" as cube | import "tests/inputs/cube.step" | ||||||
|  |  | ||||||
| cube | cube | ||||||
|   |> translate(x=10) |   |> translate(x=10) | ||||||
|  | |||||||
| @ -19,18 +19,6 @@ myBool = false | |||||||
|  |  | ||||||
| Currently you cannot redeclare a constant. | 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 | ## Objects | ||||||
|  |  | ||||||
| @ -40,8 +28,8 @@ An object is defined with `{}` braces. Here is an example object: | |||||||
| myObj = { a = 0, b = "thing" } | myObj = { a = 0, b = "thing" } | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| We support two different ways of getting properties from objects, you can call | To get the property of an object, you can call `myObj.a`, which in the above | ||||||
| `myObj.a` or `myObj["a"]` both work. | example returns 0. | ||||||
|  |  | ||||||
| ## `ImportedGeometry` | ## `ImportedGeometry` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							
							
								
								
									
										16
									
								
								docs/kcl-std/consts/std-sweep-SKETCH_PLANE.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								docs/kcl-std/consts/std-sweep-SKETCH_PLANE.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | |||||||
|  | --- | ||||||
|  | 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' | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										16
									
								
								docs/kcl-std/consts/std-sweep-TRAJECTORY.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								docs/kcl-std/consts/std-sweep-TRAJECTORY.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | |||||||
|  | --- | ||||||
|  | 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' | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										126
									
								
								docs/kcl-std/functions/std-appearance-hexString.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								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
											
										
									
								
							
							
								
								
									
										49
									
								
								docs/kcl-std/functions/std-assert.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								docs/kcl-std/functions/std-assert.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,49 @@ | |||||||
|  | --- | ||||||
|  | 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") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										35
									
								
								docs/kcl-std/functions/std-assertIs.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								docs/kcl-std/functions/std-assertIs.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | |||||||
|  | --- | ||||||
|  | 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
											
										
									
								
							
							
								
								
									
										38
									
								
								docs/kcl-std/functions/std-math-legAngX.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								docs/kcl-std/functions/std-math-legAngX.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | --- | ||||||
|  | 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) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										38
									
								
								docs/kcl-std/functions/std-math-legAngY.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								docs/kcl-std/functions/std-math-legAngY.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | --- | ||||||
|  | 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) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										38
									
								
								docs/kcl-std/functions/std-math-legLen.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								docs/kcl-std/functions/std-math-legLen.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | --- | ||||||
|  | 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) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,11 +1,11 @@ | |||||||
| --- | --- | ||||||
| title: "polar" | title: "polar" | ||||||
| subtitle: "Function in std::math" | subtitle: "Function in std::math" | ||||||
| excerpt: "" | excerpt: "Convert polar/sphere (azimuth, elevation, distance) coordinates to cartesian (x/y/z grid) coordinates." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | Convert polar/sphere (azimuth, elevation, distance) coordinates to cartesian (x/y/z grid) coordinates. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| polar( | polar( | ||||||
| @ -14,8 +14,7 @@ polar( | |||||||
| ): Point2d | ): Point2d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Convert polar/sphere (azimuth, elevation, distance) coordinates to |  | ||||||
| cartesian (x/y/z grid) coordinates. |  | ||||||
|  |  | ||||||
| ### Arguments | ### Arguments | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| --- | --- | ||||||
| title: "rem" | title: "rem" | ||||||
| subtitle: "Function in std::math" | subtitle: "Function in std::math" | ||||||
| excerpt: "" | excerpt: "Compute the remainder after dividing `num` by `div`. If `num` is negative, the result will be too." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | Compute the remainder after dividing `num` by `div`. If `num` is negative, the result will be too. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| rem( | rem( | ||||||
| @ -14,8 +14,7 @@ rem( | |||||||
| ): number | ): number | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Compute the remainder after dividing `num` by `div`. |  | ||||||
| If `num` is negative, the result will be too. |  | ||||||
|  |  | ||||||
| ### Arguments | ### Arguments | ||||||
|  |  | ||||||
|  | |||||||
| @ -10,13 +10,13 @@ Draw a line segment relative to the current origin using the polar measure of so | |||||||
| ```kcl | ```kcl | ||||||
| angledLine( | angledLine( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   angle: number, |   angle: number(Angle), | ||||||
|   length?: number, |   length?: number(Length), | ||||||
|   lengthX?: number, |   lengthX?: number(Length), | ||||||
|   lengthY?: number, |   lengthY?: number(Length), | ||||||
|   endAbsoluteX?: number, |   endAbsoluteX?: number(Length), | ||||||
|   endAbsoluteY?: number, |   endAbsoluteY?: number(Length), | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -27,13 +27,13 @@ angledLine( | |||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `angle` | [`number`](/docs/kcl-std/types/std-types-number) | Which angle should the line be drawn at? | Yes | | | `angle` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | Which angle should the line be drawn at? | Yes | | ||||||
| | `length` | [`number`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the given angle. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | | `length` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the given angle. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | ||||||
| | `lengthX` | [`number`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | | `lengthX` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | ||||||
| | `lengthY` | [`number`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | | `lengthY` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Draw the line this distance along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | ||||||
| | `endAbsoluteX` | [`number`](/docs/kcl-std/types/std-types-number) | Draw the line along the given angle until it reaches this point along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | | `endAbsoluteX` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Draw the line along the given angle until it reaches this point along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | ||||||
| | `endAbsoluteY` | [`number`](/docs/kcl-std/types/std-types-number) | Draw the line along the given angle until it reaches this point along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | | `endAbsoluteY` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Draw the line along the given angle until it reaches this point along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -46,7 +46,10 @@ angledLine( | |||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> yLine(endAbsolute = 15) |   |> yLine(endAbsolute = 15) | ||||||
|   |> angledLine(angle = 30, length = 15) |   |> angledLine( | ||||||
|  |     angle = 30, | ||||||
|  |     length = 15, | ||||||
|  |   ) | ||||||
|   |> line(end = [8, -10]) |   |> line(end = [8, -10]) | ||||||
|   |> yLine(endAbsolute = 0) |   |> yLine(endAbsolute = 0) | ||||||
|   |> close() |   |> close() | ||||||
| @ -10,10 +10,10 @@ Draw an angled line from the current origin, constructing a line segment such th | |||||||
| ```kcl | ```kcl | ||||||
| angledLineThatIntersects( | angledLineThatIntersects( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   angle: number, |   angle: number(Angle), | ||||||
|   intersectTag: TagIdentifier, |   intersectTag: tag, | ||||||
|   offset?: number, |   offset?: number(Length), | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -24,10 +24,10 @@ angledLineThatIntersects( | |||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `angle` | [`number`](/docs/kcl-std/types/std-types-number) | Which angle should the line be drawn at? | Yes | | | `angle` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | Which angle should the line be drawn at? | Yes | | ||||||
| | `intersectTag` | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The tag of the line to intersect with | Yes | | | `intersectTag` | [`tag`](/docs/kcl-std/types/std-types-tag) | The tag of the line to intersect with. | Yes | | ||||||
| | `offset` | [`number`](/docs/kcl-std/types/std-types-number) | The offset from the intersecting line. Defaults to 0. | No | | | `offset` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The offset from the intersecting line. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -42,7 +42,11 @@ exampleSketch = startSketchOn(XZ) | |||||||
|   |> line(endAbsolute = [5, 10]) |   |> line(endAbsolute = [5, 10]) | ||||||
|   |> line(endAbsolute = [-10, 10], tag = $lineToIntersect) |   |> line(endAbsolute = [-10, 10], tag = $lineToIntersect) | ||||||
|   |> line(endAbsolute = [0, 20]) |   |> line(endAbsolute = [0, 20]) | ||||||
|   |> angledLineThatIntersects(angle = 80, intersectTag = lineToIntersect, offset = 10) |   |> angledLineThatIntersects( | ||||||
|  |        angle = 80, | ||||||
|  |        intersectTag = lineToIntersect, | ||||||
|  |        offset = 10, | ||||||
|  |      ) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| example = extrude(exampleSketch, length = 10) | example = extrude(exampleSketch, length = 10) | ||||||
| @ -10,30 +10,37 @@ Draw a curved line segment along an imaginary circle. | |||||||
| ```kcl | ```kcl | ||||||
| arc( | arc( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   angleStart?: number, |   angleStart?: number(Angle), | ||||||
|   angleEnd?: number, |   angleEnd?: number(Angle), | ||||||
|   radius?: number, |   radius?: number(Length), | ||||||
|  |   diameter?: number(Length), | ||||||
|   interiorAbsolute?: Point2d, |   interiorAbsolute?: Point2d, | ||||||
|   endAbsolute?: Point2d, |   endAbsolute?: Point2d, | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| The arc is constructed such that the current position of the sketch is placed along an imaginary circle of the specified radius, at angleStart degrees. The resulting arc is the segment of the imaginary circle from that origin point to angleEnd, radius away from the center of the imaginary circle. | The arc is constructed such that the current position of the sketch is | ||||||
|  | placed along an imaginary circle of the specified radius, at angleStart | ||||||
|  | degrees. The resulting arc is the segment of the imaginary circle from | ||||||
|  | that origin point to angleEnd, radius away from the center of the imaginary | ||||||
|  | circle. | ||||||
| 
 | 
 | ||||||
| Unless this makes a lot of sense and feels like what you're looking for to construct your shape, you're likely looking for tangentialArc. | Unless this makes a lot of sense and feels like what you're looking | ||||||
|  | for to construct your shape, you're likely looking for tangentialArc. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `angleStart` | [`number`](/docs/kcl-std/types/std-types-number) | Where along the circle should this arc start? | No | | | `angleStart` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | Where along the circle should this arc start? | No | | ||||||
| | `angleEnd` | [`number`](/docs/kcl-std/types/std-types-number) | Where along the circle should this arc end? | No | | | `angleEnd` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | Where along the circle should this arc end? | No | | ||||||
| | `radius` | [`number`](/docs/kcl-std/types/std-types-number) | How large should the circle be? | No | | | `radius` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | How large should the circle be? Incompatible with `diameter`. | No | | ||||||
| | `interiorAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Any point between the arc's start and end? Requires `endAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | | | `diameter` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | How large should the circle be? Incompatible with `radius`. | No | | ||||||
| | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Where should this arc end? Requires `interiorAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | | | `interiorAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Any point between the arc's start and end? Requires `endAbsolute`. Incompatible with `angleStart` or `angleEnd`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Where should this arc end? Requires `interiorAbsolute`. Incompatible with `angleStart` or `angleEnd`. | No | | ||||||
|  | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this arc. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -46,7 +53,11 @@ Unless this makes a lot of sense and feels like what you're looking for to const | |||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
|   |> arc(angleStart = 0, angleEnd = 280, radius = 16) |   |> arc( | ||||||
|  |        angleStart = 0, | ||||||
|  |        angleEnd = 280, | ||||||
|  |        radius = 16 | ||||||
|  |      ) | ||||||
|   |> close() |   |> close() | ||||||
| example = extrude(exampleSketch, length = 10) | example = extrude(exampleSketch, length = 10) | ||||||
| ``` | ``` | ||||||
| @ -56,7 +67,10 @@ example = extrude(exampleSketch, length = 10) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> arc(endAbsolute = [10, 0], interiorAbsolute = [5, 5]) |   |> arc( | ||||||
|  |         endAbsolute = [10,0], | ||||||
|  |         interiorAbsolute = [5,5] | ||||||
|  |      ) | ||||||
|   |> close() |   |> close() | ||||||
| example = extrude(exampleSketch, length = 10) | example = extrude(exampleSketch, length = 10) | ||||||
| ``` | ``` | ||||||
							
								
								
									
										74
									
								
								docs/kcl-std/functions/std-sketch-bezierCurve.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								docs/kcl-std/functions/std-sketch-bezierCurve.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,31 +1,32 @@ | |||||||
| --- | --- | ||||||
| title: "circle" | title: "circle" | ||||||
| subtitle: "Function in std::sketch" | subtitle: "Function in std::sketch" | ||||||
| excerpt: "" | excerpt: "Construct a 2-dimensional circle, of the specified radius, centered at the provided (x, y) origin point." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | Construct a 2-dimensional circle, of the specified radius, centered at the provided (x, y) origin point. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| circle( | circle( | ||||||
|   @sketch_or_surface: Sketch | Plane | Face, |   @sketchOrSurface: Sketch | Plane | Face, | ||||||
|   center: Point2d, |   center: Point2d, | ||||||
|   radius: number(Length), |   radius?: number(Length), | ||||||
|  |   diameter?: number(Length), | ||||||
|   tag?: tag, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Construct a 2-dimensional circle, of the specified radius, centered at |  | ||||||
| the provided (x, y) origin point. |  | ||||||
|  |  | ||||||
| ### Arguments | ### Arguments | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch_or_surface` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Sketch to extend, or plane or surface to sketch on. | Yes | | | `sketchOrSurface` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Sketch to extend, or plane or surface to sketch on. | Yes | | ||||||
| | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center of the circle. | Yes | | | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center of the circle. | Yes | | ||||||
| | `radius` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The radius of the circle. | Yes | | | `radius` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The radius of the circle. Incompatible with `diameter`. | No | | ||||||
|  | | `diameter` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The diameter of the circle. Incompatible with `radius`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this circle. | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this circle. | No | | ||||||
|  |  | ||||||
| ### Returns | ### Returns | ||||||
| @ -51,7 +52,7 @@ exampleSketch = startSketchOn(XZ) | |||||||
|   |> line(end = [0, 30]) |   |> line(end = [0, 30]) | ||||||
|   |> line(end = [-30, 0]) |   |> line(end = [-30, 0]) | ||||||
|   |> close() |   |> close() | ||||||
|   |> subtract2d(tool = circle(center = [0, 15], radius = 5)) |   |> subtract2d(tool = circle(center = [0, 15], diameter = 10)) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = 5) | example = extrude(exampleSketch, length = 5) | ||||||
| ``` | ``` | ||||||
|  | |||||||
| @ -9,11 +9,11 @@ Construct a circle derived from 3 points. | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| circleThreePoint( | circleThreePoint( | ||||||
|   @sketchSurfaceOrGroup: Sketch | Plane | Face, |   @sketchOrSurface: Sketch | Plane | Face, | ||||||
|   p1: Point2d, |   p1: Point2d, | ||||||
|   p2: Point2d, |   p2: Point2d, | ||||||
|   p3: Point2d, |   p3: Point2d, | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -23,11 +23,11 @@ circleThreePoint( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketchSurfaceOrGroup` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Plane or surface to sketch on. | Yes | | | `sketchOrSurface` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Plane or surface to sketch on. | Yes | | ||||||
| | `p1` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 1st point to derive the circle. | Yes | | | `p1` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 1st point to derive the circle. | Yes | | ||||||
| | `p2` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 2nd point to derive the circle. | Yes | | | `p2` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 2nd point to derive the circle. | Yes | | ||||||
| | `p3` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 3rd point to derive the circle. | Yes | | | `p3` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | 3rd point to derive the circle. | Yes | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Identifier for the circle to reference elsewhere. | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Identifier for the circle to reference elsewhere. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -38,7 +38,7 @@ circleThreePoint( | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XY) | exampleSketch = startSketchOn(XY) | ||||||
|   |> circleThreePoint(p1 = [10, 10], p2 = [20, 8], p3 = [15, 5]) |   |> circleThreePoint(p1 = [10,10], p2 = [20,8], p3 = [15,5]) | ||||||
|   |> extrude(length = 5) |   |> extrude(length = 5) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -10,18 +10,21 @@ Construct a line segment from the current origin back to the profile's origin, e | |||||||
| ```kcl | ```kcl | ||||||
| close( | close( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | If you want to perform some 3-dimensional operation on a sketch, like | ||||||
|  | extrude or sweep, you must `close` it first. `close` must be called even | ||||||
|  | if the end point of the last segment is coincident with the sketch | ||||||
|  | starting point. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch you want to close | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch you want to close. | Yes | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -9,31 +9,32 @@ Extend a 2-dimensional sketch through a third dimension in order to create new 3 | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| extrude( | extrude( | ||||||
|   @sketches: [Sketch], |   @sketches: [Sketch; 1+], | ||||||
|   length: number, |   length: number(Length), | ||||||
|   symmetric?: bool, |   symmetric?: bool, | ||||||
|   bidirectionalLength?: number, |   bidirectionalLength?: number(Length), | ||||||
|   tagStart?: TagDeclarator, |   tagStart?: tag, | ||||||
|   tagEnd?: TagDeclarator, |   tagEnd?: tag, | ||||||
| ): [Solid] | ): [Solid; 1+] | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| You can provide more than one sketch to extrude, and they will all be extruded in the same direction. | You can provide more than one sketch to extrude, and they will all be | ||||||
|  | extruded in the same direction. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketches` | [`[Sketch]`](/docs/kcl-std/types/std-types-Sketch) | Which sketch or sketches should be extruded | Yes | | | `sketches` | [`[Sketch; 1+]`](/docs/kcl-std/types/std-types-Sketch) | Which sketch or sketches should be extruded. | Yes | | ||||||
| | `length` | [`number`](/docs/kcl-std/types/std-types-number) | How far to extrude the given sketches | Yes | | | `length` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | How far to extrude the given sketches. | Yes | | ||||||
| | `symmetric` | [`bool`](/docs/kcl-std/types/std-types-bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the extrusion will happen on only one side of the sketch. | No | | | `symmetric` | [`bool`](/docs/kcl-std/types/std-types-bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the extrusion will happen on only one side of the sketch. | No | | ||||||
| | `bidirectionalLength` | [`number`](/docs/kcl-std/types/std-types-number) | If specified, will also extrude in the opposite direction to 'distance' to the specified distance. If 'symmetric' is true, this value is ignored. | No | | | `bidirectionalLength` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | If specified, will also extrude in the opposite direction to 'distance' to the specified distance. If 'symmetric' is true, this value is ignored. | No | | ||||||
| | `tagStart` | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | A named tag for the face at the start of the extrusion, i.e. the original sketch | No | | | `tagStart` | [`tag`](/docs/kcl-std/types/std-types-tag) | A named tag for the face at the start of the extrusion, i.e. the original sketch. | No | | ||||||
| | `tagEnd` | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | A named tag for the face at the end of the extrusion, i.e. the new face created by extruding the original sketch | No | | | `tagEnd` | [`tag`](/docs/kcl-std/types/std-types-tag) | A named tag for the face at the end of the extrusion, i.e. the new face created by extruding the original sketch. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[Solid]`](/docs/kcl-std/types/std-types-Solid) | [`[Solid; 1+]`](/docs/kcl-std/types/std-types-Solid) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -42,10 +43,18 @@ You can provide more than one sketch to extrude, and they will all be extruded i | |||||||
| example = startSketchOn(XZ) | example = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
|   |> arc(angleStart = 120, angleEnd = 0, radius = 5) |   |> arc( | ||||||
|  |     angleStart = 120, | ||||||
|  |     angleEnd = 0, | ||||||
|  |     radius = 5, | ||||||
|  |   ) | ||||||
|   |> line(end = [5, 0]) |   |> line(end = [5, 0]) | ||||||
|   |> line(end = [0, 10]) |   |> line(end = [0, 10]) | ||||||
|   |> bezierCurve(control1 = [-10, 0], control2 = [2, 10], end = [-5, 10]) |   |> bezierCurve( | ||||||
|  |        control1 = [-10, 0], | ||||||
|  |        control2 = [2, 10], | ||||||
|  |        end = [-5, 10], | ||||||
|  |      ) | ||||||
|   |> line(end = [-5, -2]) |   |> line(end = [-5, -2]) | ||||||
|   |> close() |   |> close() | ||||||
|   |> extrude(length = 10) |   |> extrude(length = 10) | ||||||
| @ -56,10 +65,18 @@ example = startSketchOn(XZ) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [-10, 0]) |   |> startProfile(at = [-10, 0]) | ||||||
|   |> arc(angleStart = 120, angleEnd = -60, radius = 5) |   |> arc( | ||||||
|  |     angleStart = 120, | ||||||
|  |     angleEnd = -60, | ||||||
|  |     radius = 5, | ||||||
|  |   ) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
|   |> line(end = [5, 0]) |   |> line(end = [5, 0]) | ||||||
|   |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10]) |   |> bezierCurve( | ||||||
|  |        control1 = [-3, 0], | ||||||
|  |        control2 = [2, 10], | ||||||
|  |        end = [-5, 10], | ||||||
|  |      ) | ||||||
|   |> line(end = [-4, 10]) |   |> line(end = [-4, 10]) | ||||||
|   |> line(end = [-5, -2]) |   |> line(end = [-5, -2]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -72,10 +89,18 @@ example = extrude(exampleSketch, length = 10) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [-10, 0]) |   |> startProfile(at = [-10, 0]) | ||||||
|   |> arc(angleStart = 120, angleEnd = -60, radius = 5) |   |> arc( | ||||||
|  |     angleStart = 120, | ||||||
|  |     angleEnd = -60, | ||||||
|  |     radius = 5, | ||||||
|  |   ) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
|   |> line(end = [5, 0]) |   |> line(end = [5, 0]) | ||||||
|   |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10]) |   |> bezierCurve( | ||||||
|  |        control1 = [-3, 0], | ||||||
|  |        control2 = [2, 10], | ||||||
|  |        end = [-5, 10], | ||||||
|  |      ) | ||||||
|   |> line(end = [-4, 10]) |   |> line(end = [-4, 10]) | ||||||
|   |> line(end = [-5, -2]) |   |> line(end = [-5, -2]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -88,10 +113,18 @@ example = extrude(exampleSketch, length = 20, symmetric = true) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [-10, 0]) |   |> startProfile(at = [-10, 0]) | ||||||
|   |> arc(angleStart = 120, angleEnd = -60, radius = 5) |   |> arc( | ||||||
|  |     angleStart = 120, | ||||||
|  |     angleEnd = -60, | ||||||
|  |     radius = 5, | ||||||
|  |   ) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
|   |> line(end = [5, 0]) |   |> line(end = [5, 0]) | ||||||
|   |> bezierCurve(control1 = [-3, 0], control2 = [2, 10], end = [-5, 10]) |   |> bezierCurve( | ||||||
|  |        control1 = [-3, 0], | ||||||
|  |        control2 = [2, 10], | ||||||
|  |        end = [-5, 10], | ||||||
|  |      ) | ||||||
|   |> line(end = [-4, 10]) |   |> line(end = [-4, 10]) | ||||||
|   |> line(end = [-5, -2]) |   |> line(end = [-5, -2]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Get the shared edge between two faces. | Get the shared edge between two faces. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| getCommonEdge(faces: [TagIdentifier]): Uuid | getCommonEdge(faces: [tag; 2]): Edge | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ getCommonEdge(faces: [TagIdentifier]): Uuid | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `faces` | [`[TagIdentifier]`](/docs/kcl-lang/types#TagIdentifier) | The tags of the faces you want to find the common edge between | Yes | | | `faces` | `[tag; 2]` | The tags of the faces you want to find the common edge between. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| `Uuid` | [`Edge`](/docs/kcl-std/types/std-types-Edge) - An edge of a solid. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -29,7 +29,6 @@ getCommonEdge(faces: [TagIdentifier]): Uuid | |||||||
| ```kcl | ```kcl | ||||||
| // Get an edge shared between two faces, created after a chamfer. | // Get an edge shared between two faces, created after a chamfer. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| scale = 20 | scale = 20 | ||||||
| part001 = startSketchOn(XY) | part001 = startSketchOn(XY) | ||||||
|     |> startProfile(at = [0, 0]) |     |> startProfile(at = [0, 0]) | ||||||
										
											
												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
											
										
									
								
							| @ -8,7 +8,7 @@ layout: manual | |||||||
| Extract the 'x' axis value of the last line segment in the provided 2-d sketch. | Extract the 'x' axis value of the last line segment in the provided 2-d sketch. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| lastSegX(@sketch: Sketch): number | lastSegX(@sketch: Sketch): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ lastSegX(@sketch: Sketch): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch whose line segment is being queried | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch whose line segment is being queried. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Extract the 'y' axis value of the last line segment in the provided 2-d sketch. | Extract the 'y' axis value of the last line segment in the provided 2-d sketch. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| lastSegY(@sketch: Sketch): number | lastSegY(@sketch: Sketch): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ lastSegY(@sketch: Sketch): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch whose line segment is being queried | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | The sketch whose line segment is being queried. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -12,7 +12,7 @@ line( | |||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   endAbsolute?: Point2d, |   endAbsolute?: Point2d, | ||||||
|   end?: Point2d, |   end?: Point2d, | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -25,7 +25,7 @@ line( | |||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Which absolute point should this line go to? Incompatible with `end`. | No | | | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Which absolute point should this line go to? Incompatible with `end`. | No | | ||||||
| | `end` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | How far away (along the X and Y axes) should this line go? Incompatible with `endAbsolute`. | No | | | `end` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | How far away (along the X and Y axes) should this line go? Incompatible with `endAbsolute`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -9,13 +9,13 @@ Repeat a 2-dimensional sketch some number of times along a partial or complete c | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| patternCircular2d( | patternCircular2d( | ||||||
|   @sketchSet: [Sketch], |   @sketches: [Sketch; 1+], | ||||||
|   instances: number, |   instances: number(_), | ||||||
|   center: Point2d, |   center: Point2d, | ||||||
|   arcDegrees: number, |   arcDegrees?: number(Angle), | ||||||
|   rotateDuplicates: bool, |   rotateDuplicates?: bool, | ||||||
|   useOriginal?: bool, |   useOriginal?: bool, | ||||||
| ): [Sketch] | ): [Sketch; 1+] | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -24,16 +24,16 @@ patternCircular2d( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketchSet` | [`[Sketch]`](/docs/kcl-std/types/std-types-Sketch) | Which sketch(es) to pattern | Yes | | | `sketches` | [`[Sketch; 1+]`](/docs/kcl-std/types/std-types-Sketch) | The sketch(es) to duplicate. | Yes | | ||||||
| | `instances` | [`number`](/docs/kcl-std/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | | `instances` | [`number(_)`](/docs/kcl-std/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | ||||||
| | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center about which to make the pattern. This is a 2D vector. | Yes | | | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center about which to make the pattern. This is a 2D vector. | Yes | | ||||||
| | `arcDegrees` | [`number`](/docs/kcl-std/types/std-types-number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | Yes | | | `arcDegrees` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | No | | ||||||
| | `rotateDuplicates` | [`bool`](/docs/kcl-std/types/std-types-bool) | Whether or not to rotate the duplicates as they are copied. | Yes | | | `rotateDuplicates` | [`bool`](/docs/kcl-std/types/std-types-bool) | Whether or not to rotate the duplicates as they are copied. | No | | ||||||
| | `useOriginal` | [`bool`](/docs/kcl-std/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | | | `useOriginal` | [`bool`](/docs/kcl-std/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[Sketch]`](/docs/kcl-std/types/std-types-Sketch) | [`[Sketch; 1+]`](/docs/kcl-std/types/std-types-Sketch) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -49,7 +49,7 @@ exampleSketch = startSketchOn(XZ) | |||||||
|        center = [0, 0], |        center = [0, 0], | ||||||
|        instances = 13, |        instances = 13, | ||||||
|        arcDegrees = 360, |        arcDegrees = 360, | ||||||
|        rotateDuplicates = true, |        rotateDuplicates = true | ||||||
|      ) |      ) | ||||||
| 
 | 
 | ||||||
| example = extrude(exampleSketch, length = 1) | example = extrude(exampleSketch, length = 1) | ||||||
							
								
								
									
										71
									
								
								docs/kcl-std/functions/std-sketch-patternLinear2d.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								docs/kcl-std/functions/std-sketch-patternLinear2d.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,19 +1,19 @@ | |||||||
| --- | --- | ||||||
| title: "patternTransform2d" | title: "patternTransform2d" | ||||||
| subtitle: "Function in std::sketch" | subtitle: "Function in std::sketch" | ||||||
| excerpt: "Just like patternTransform, but works on 2D sketches not 3D solids." | excerpt: "Just like `patternTransform`, but works on 2D sketches not 3D solids." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| Just like patternTransform, but works on 2D sketches not 3D solids. | Just like `patternTransform`, but works on 2D sketches not 3D solids. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| patternTransform2d( | patternTransform2d( | ||||||
|   @sketches: [Sketch], |   @sketches: [Sketch; 1+], | ||||||
|   instances: number, |   instances: number(_), | ||||||
|   transform: FunctionSource, |   transform: fn(number(_)): { }, | ||||||
|   useOriginal?: bool, |   useOriginal?: boolean, | ||||||
| ): [Sketch] | ): [Sketch; 1+] | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -22,14 +22,14 @@ patternTransform2d( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketches` | [`[Sketch]`](/docs/kcl-std/types/std-types-Sketch) | The sketch(es) to duplicate | Yes | | | `sketches` | [`[Sketch; 1+]`](/docs/kcl-std/types/std-types-Sketch) | The sketch(es) to duplicate. | Yes | | ||||||
| | `instances` | [`number`](/docs/kcl-std/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | | `instances` | [`number(_)`](/docs/kcl-std/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | ||||||
| | `transform` | `FunctionSource` | How each replica should be transformed. The transform function takes a single parameter: an integer representing which number replication the transform is for. E.g. the first replica to be transformed will be passed the argument `1`. This simplifies your math: the transform function can rely on id `0` being the original instance passed into the `patternTransform`. See the examples. | Yes | | | `transform` | [`fn(number(_)): { }`](/docs/kcl-std/types/std-types-fn) | How each replica should be transformed. The transform function takes a single parameter: an integer representing which number replication the transform is for. E.g. the first replica to be transformed will be passed the argument `1`. This simplifies your math: the transform function can rely on id `0` being the original instance passed into the `patternTransform`. See the examples. | Yes | | ||||||
| | `useOriginal` | [`bool`](/docs/kcl-std/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | | | `useOriginal` | `boolean` | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[Sketch]`](/docs/kcl-std/types/std-types-Sketch) | [`[Sketch; 1+]`](/docs/kcl-std/types/std-types-Sketch) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -9,9 +9,9 @@ Create a regular polygon with the specified number of sides that is either inscr | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| polygon( | polygon( | ||||||
|   @sketchSurfaceOrGroup: Sketch | Plane | Face, |   @sketchOrSurface: Sketch | Plane | Face, | ||||||
|   radius: number, |   radius: number(Length), | ||||||
|   numSides: u64, |   numSides: number(_), | ||||||
|   center: Point2d, |   center: Point2d, | ||||||
|   inscribed?: bool, |   inscribed?: bool, | ||||||
| ): Sketch | ): Sketch | ||||||
| @ -23,11 +23,11 @@ polygon( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketchSurfaceOrGroup` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Plane or surface to sketch on | Yes | | | `sketchOrSurface` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) or [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | Plane or surface to sketch on. | Yes | | ||||||
| | `radius` | [`number`](/docs/kcl-std/types/std-types-number) | The radius of the polygon | Yes | | | `radius` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The radius of the polygon. | Yes | | ||||||
| | `numSides` | `u64` | The number of sides in the polygon | Yes | | | `numSides` | [`number(_)`](/docs/kcl-std/types/std-types-number) | The number of sides in the polygon. | Yes | | ||||||
| | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center point of the polygon | Yes | | | `center` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | The center point of the polygon. | Yes | | ||||||
| | `inscribed` | [`bool`](/docs/kcl-std/types/std-types-bool) | Whether the polygon is inscribed (true, the default) or circumscribed (false) about a circle with the specified radius | No | | | `inscribed` | [`bool`](/docs/kcl-std/types/std-types-bool) | Whether the polygon is inscribed (true, the default) or circumscribed (false) about a circle with the specified radius. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Extract the provided 2-dimensional sketch's profile's origin value. | Extract the provided 2-dimensional sketch's profile's origin value. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| profileStart(@profile: Sketch): [number] | profileStart(@profile: Sketch): Point2d | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ profileStart(@profile: Sketch): [number] | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used | Yes | | | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[number]`](/docs/kcl-std/types/std-types-number) | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) - A point in two dimensional space. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -29,8 +29,8 @@ profileStart(@profile: Sketch): [number] | |||||||
| ```kcl | ```kcl | ||||||
| sketch001 = startSketchOn(XY) | sketch001 = startSketchOn(XY) | ||||||
|  |> startProfile(at = [5, 2]) |  |> startProfile(at = [5, 2]) | ||||||
|   |> angledLine(angle = 120, length = 50, tag = $seg01) |  |> angledLine(angle = 120, length = 50 , tag = $seg01) | ||||||
|   |> angledLine(angle = segAng(seg01) + 120, length = 50) |  |> angledLine(angle = segAng(seg01) + 120, length = 50 ) | ||||||
|  |> line(end = profileStart(%)) |  |> line(end = profileStart(%)) | ||||||
|  |> close() |  |> close() | ||||||
|  |> extrude(length = 20) |  |> extrude(length = 20) | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Extract the provided 2-dimensional sketch's profile's origin's 'x' value. | Extract the provided 2-dimensional sketch's profile's origin's 'x' value. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| profileStartX(@profile: Sketch): number | profileStartX(@profile: Sketch): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ profileStartX(@profile: Sketch): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used | Yes | | | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Extract the provided 2-dimensional sketch's profile's origin's 'y' value. | Extract the provided 2-dimensional sketch's profile's origin's 'y' value. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| profileStartY(@profile: Sketch): number | profileStartY(@profile: Sketch): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ profileStartY(@profile: Sketch): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used | Yes | | | `profile` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Profile whose start is being used. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -29,7 +29,7 @@ profileStartY(@profile: Sketch): number | |||||||
| ```kcl | ```kcl | ||||||
| sketch001 = startSketchOn(XY) | sketch001 = startSketchOn(XY) | ||||||
|  |> startProfile(at = [5, 2]) |  |> startProfile(at = [5, 2]) | ||||||
|   |> angledLine(angle = -60, length = 14) |  |> angledLine(angle = -60, length = 14 ) | ||||||
|  |> angledLine(angle = 30, endAbsoluteY =  profileStartY(%)) |  |> angledLine(angle = 30, endAbsoluteY =  profileStartY(%)) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the angle (in degrees) of the provided line segment. | Compute the angle (in degrees) of the provided line segment. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segAng(@tag: TagIdentifier): number | segAng(@tag: tag): number(Angle) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segAng(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Angle)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the ending point of the provided line segment. | Compute the ending point of the provided line segment. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segEnd(@tag: TagIdentifier): Point2d | segEnd(@tag: tag): Point2d | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,7 +17,7 @@ segEnd(@tag: TagIdentifier): Point2d | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -40,7 +40,7 @@ cube = startSketchOn(XY) | |||||||
| fn cylinder(radius, tag) { | fn cylinder(radius, tag) { | ||||||
|   return startSketchOn(XY) |   return startSketchOn(XY) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|     |> circle(radius = radius, center = segEnd(tag)) |   |> circle(radius = radius, center = segEnd(tag) ) | ||||||
|   |> extrude(length = radius) |   |> extrude(length = radius) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the ending point of the provided line segment along the 'x' axis. | Compute the ending point of the provided line segment along the 'x' axis. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segEndX(@tag: TagIdentifier): number | segEndX(@tag: tag): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segEndX(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the ending point of the provided line segment along the 'y' axis. | Compute the ending point of the provided line segment along the 'y' axis. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segEndY(@tag: TagIdentifier): number | segEndY(@tag: tag): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segEndY(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the length of the provided line segment. | Compute the length of the provided line segment. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segLen(@tag: TagIdentifier): number | segLen(@tag: tag): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segLen(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -29,9 +29,16 @@ segLen(@tag: TagIdentifier): number | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> angledLine(angle = 60, length = 10, tag = $thing) |   |> angledLine( | ||||||
|  |     angle = 60, | ||||||
|  |     length = 10, | ||||||
|  |     tag = $thing, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(angle = -120, radius = 5) |   |> tangentialArc(angle = -120, radius = 5) | ||||||
|   |> angledLine(angle = -60, length = segLen(thing)) |   |> angledLine( | ||||||
|  |     angle = -60, | ||||||
|  |     length = segLen(thing), | ||||||
|  |   ) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| example = extrude(exampleSketch, length = 5) | example = extrude(exampleSketch, length = 5) | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the starting point of the provided line segment. | Compute the starting point of the provided line segment. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segStart(@tag: TagIdentifier): Point2d | segStart(@tag: tag): Point2d | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,7 +17,7 @@ segStart(@tag: TagIdentifier): Point2d | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -40,7 +40,7 @@ cube = startSketchOn(XY) | |||||||
| fn cylinder(radius, tag) { | fn cylinder(radius, tag) { | ||||||
|   return startSketchOn(XY) |   return startSketchOn(XY) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|     |> circle(radius = radius, center = segStart(tag)) |   |> circle( radius = radius, center = segStart(tag) ) | ||||||
|   |> extrude(length = radius) |   |> extrude(length = radius) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the starting point of the provided line segment along the 'x' axis. | Compute the starting point of the provided line segment along the 'x' axis. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segStartX(@tag: TagIdentifier): number | segStartX(@tag: tag): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segStartX(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -8,7 +8,7 @@ layout: manual | |||||||
| Compute the starting point of the provided line segment along the 'y' axis. | Compute the starting point of the provided line segment along the 'y' axis. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| segStartY(@tag: TagIdentifier): number | segStartY(@tag: tag): number(Length) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ segStartY(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Length)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -32,7 +32,7 @@ exampleSketch = startSketchOn(XZ) | |||||||
|   |> line(end = [20, 0]) |   |> line(end = [20, 0]) | ||||||
|   |> line(end = [0, 3], tag = $thing) |   |> line(end = [0, 3], tag = $thing) | ||||||
|   |> line(end = [-10, 0]) |   |> line(end = [-10, 0]) | ||||||
|   |> line(end = [0, 20 - segStartY(thing)]) |   |> line(end = [0, 20-segStartY(thing)]) | ||||||
|   |> line(end = [-10, 0]) |   |> line(end = [-10, 0]) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| @ -9,9 +9,9 @@ Start a new profile at a given point. | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| startProfile( | startProfile( | ||||||
|   @sketchSurface: Plane | Face, |   @startProfileOn: Plane | Face, | ||||||
|   at: Point2d, |   at: Point2d, | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -21,9 +21,9 @@ startProfile( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketchSurface` | [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | What to start the profile on | Yes | | | `startProfileOn` | [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | What to start the profile on. | Yes | | ||||||
| | `at` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Where to start the profile. An absolute point. | Yes | | | `at` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Where to start the profile. An absolute point. | Yes | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Tag this first starting point | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Tag this first starting point. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -9,8 +9,8 @@ Start a new 2-dimensional sketch on a specific plane or face. | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| startSketchOn( | startSketchOn( | ||||||
|   @planeOrSolid: Plane | Solid, |   @planeOrSolid: Solid | Plane, | ||||||
|   face?: TagIdentifier | Start | End, |   face?: tag, | ||||||
| ): Plane | Face | ): Plane | Face | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -18,22 +18,29 @@ startSketchOn( | |||||||
| 
 | 
 | ||||||
| There are some important behaviors to understand when sketching on a face: | There are some important behaviors to understand when sketching on a face: | ||||||
| 
 | 
 | ||||||
| The resulting sketch will _include_ the face and thus Solid that was sketched on. So say you were to export the resulting Sketch / Solid from a sketch on a face, you would get both the artifact of the sketch on the face and the parent face / Solid itself. | The resulting sketch will _include_ the face and thus Solid | ||||||
|  | that was sketched on. So say you were to export the resulting Sketch / Solid | ||||||
|  | from a sketch on a face, you would get both the artifact of the sketch | ||||||
|  | on the face and the parent face / Solid itself. | ||||||
| 
 | 
 | ||||||
| This is important to understand because if you were to then sketch on the resulting Solid, it would again include the face and parent Solid that was sketched on. This could go on indefinitely. | This is important to understand because if you were to then sketch on the | ||||||
|  | resulting Solid, it would again include the face and parent Solid that was | ||||||
|  | sketched on. This could go on indefinitely. | ||||||
| 
 | 
 | ||||||
| The point is if you want to export the result of a sketch on a face, you only need to export the final Solid that was created from the sketch on the face, since it will include all the parent faces and Solids. | The point is if you want to export the result of a sketch on a face, you | ||||||
|  | only need to export the final Solid that was created from the sketch on the | ||||||
|  | face, since it will include all the parent faces and Solids. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `planeOrSolid` | [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Solid`](/docs/kcl-std/types/std-types-Solid) | The plane or solid to sketch on | Yes | | | `planeOrSolid` | [`Solid`](/docs/kcl-std/types/std-types-Solid) or [`Plane`](/docs/kcl-std/types/std-types-Plane) | Profile whose start is being used. | Yes | | ||||||
| | `face` | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) or [`Start`](/docs/kcl-lang/types#Start) or [`End`](/docs/kcl-lang/types#End) | Identify a face of a solid if a solid is specified as the input argument (`plane_or_solid`) | No | | | `face` | [`tag`](/docs/kcl-std/types/std-types-tag) | Identify a face of a solid if a solid is specified as the input argument (`planeOrSolid`). | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) - A sketch type. | [`Plane`](/docs/kcl-std/types/std-types-Plane) or [`Face`](/docs/kcl-std/types/std-types-Face) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -72,7 +79,6 @@ example003 = extrude(exampleSketch003, length = 5) | |||||||
| ```kcl | ```kcl | ||||||
| // Sketch on the end of an extruded face by tagging the end face. | // Sketch on the end of an extruded face by tagging the end face. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| exampleSketch = startSketchOn(XY) | exampleSketch = startSketchOn(XY) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [10, 0]) |   |> line(end = [10, 0]) | ||||||
| @ -163,7 +169,6 @@ example002 = extrude(exampleSketch002, length = 5) | |||||||
| ```kcl | ```kcl | ||||||
| // Sketch on the end of a revolved face by tagging the end face. | // Sketch on the end of a revolved face by tagging the end face. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| exampleSketch = startSketchOn(XY) | exampleSketch = startSketchOn(XY) | ||||||
|   |> startProfile(at = [4, 12]) |   |> startProfile(at = [4, 12]) | ||||||
|   |> line(end = [2, 0]) |   |> line(end = [2, 0]) | ||||||
| @ -175,12 +180,7 @@ exampleSketch = startSketchOn(XY) | |||||||
|   |> line(end = [-2, 0]) |   |> line(end = [-2, 0]) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| example = revolve( | example = revolve(exampleSketch, axis = Y, angle = 180, tagEnd = $end01) | ||||||
|   exampleSketch, |  | ||||||
|   axis = Y, |  | ||||||
|   angle = 180, |  | ||||||
|   tagEnd = $end01, |  | ||||||
| ) |  | ||||||
| 
 | 
 | ||||||
| exampleSketch002 = startSketchOn(example, face = end01) | exampleSketch002 = startSketchOn(example, face = end01) | ||||||
|   |> startProfile(at = [4.5, -5]) |   |> startProfile(at = [4.5, -5]) | ||||||
							
								
								
									
										67
									
								
								docs/kcl-std/functions/std-sketch-subtract2d.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								docs/kcl-std/functions/std-sketch-subtract2d.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										149
									
								
								docs/kcl-std/functions/std-sketch-sweep.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								docs/kcl-std/functions/std-sketch-sweep.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -8,7 +8,7 @@ layout: manual | |||||||
| Returns the angle coming out of the end of the segment in degrees. | Returns the angle coming out of the end of the segment in degrees. | ||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| tangentToEnd(@tag: TagIdentifier): number | tangentToEnd(@tag: tag): number(Angle) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -17,11 +17,11 @@ tangentToEnd(@tag: TagIdentifier): number | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) | The line segment being queried by its tag | Yes | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | The line segment being queried by its tag. | Yes | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. | [`number(Angle)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -32,7 +32,10 @@ pillSketch = startSketchOn(XZ) | |||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [20, 0]) |   |> line(end = [20, 0]) | ||||||
|   |> tangentialArc(end = [0, 10], tag = $arc1) |   |> tangentialArc(end = [0, 10], tag = $arc1) | ||||||
|   |> angledLine(angle = tangentToEnd(arc1), length = 20) |   |> angledLine( | ||||||
|  |     angle = tangentToEnd(arc1), | ||||||
|  |     length = 20, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(end = [0, -10]) |   |> tangentialArc(end = [0, -10]) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| @ -47,7 +50,10 @@ pillSketch = startSketchOn(XZ) | |||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [0, 20]) |   |> line(end = [0, 20]) | ||||||
|   |> tangentialArc(endAbsolute = [10, 20], tag = $arc1) |   |> tangentialArc(endAbsolute = [10, 20], tag = $arc1) | ||||||
|   |> angledLine(angle = tangentToEnd(arc1), length = 20) |   |> angledLine( | ||||||
|  |     angle = tangentToEnd(arc1), | ||||||
|  |     length = 20, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(end = [-10, 0]) |   |> tangentialArc(end = [-10, 0]) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| @ -60,7 +66,10 @@ pillExtrude = extrude(pillSketch, length = 10) | |||||||
| rectangleSketch = startSketchOn(XZ) | rectangleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> line(end = [10, 0], tag = $seg1) |   |> line(end = [10, 0], tag = $seg1) | ||||||
|   |> angledLine(angle = tangentToEnd(seg1), length = 10) |   |> angledLine( | ||||||
|  |     angle = tangentToEnd(seg1), | ||||||
|  |     length = 10, | ||||||
|  |   ) | ||||||
|   |> line(end = [0, 10]) |   |> line(end = [0, 10]) | ||||||
|   |> line(end = [-20, 0]) |   |> line(end = [-20, 0]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -73,7 +82,11 @@ rectangleExtrude = extrude(rectangleSketch, length = 10) | |||||||
| ```kcl | ```kcl | ||||||
| bottom = startSketchOn(XY) | bottom = startSketchOn(XY) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> arc(endAbsolute = [10, 10], interiorAbsolute = [5, 1], tag = $arc1) |   |> arc( | ||||||
|  |        endAbsolute = [10, 10], | ||||||
|  |        interiorAbsolute = [5, 1], | ||||||
|  |        tag = $arc1, | ||||||
|  |      ) | ||||||
|   |> angledLine(angle = tangentToEnd(arc1), length = 20) |   |> angledLine(angle = tangentToEnd(arc1), length = 20) | ||||||
|   |> close() |   |> close() | ||||||
| ``` | ``` | ||||||
| @ -82,7 +95,7 @@ bottom = startSketchOn(XY) | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| circSketch = startSketchOn(XY) | circSketch = startSketchOn(XY) | ||||||
|   |> circle(center = [0, 0], radius = 3, tag = $circ) |   |> circle(center = [0, 0], radius= 3, tag = $circ) | ||||||
| 
 | 
 | ||||||
| triangleSketch = startSketchOn(XY) | triangleSketch = startSketchOn(XY) | ||||||
|   |> startProfile(at = [-5, 0]) |   |> startProfile(at = [-5, 0]) | ||||||
| @ -12,13 +12,18 @@ tangentialArc( | |||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   endAbsolute?: Point2d, |   endAbsolute?: Point2d, | ||||||
|   end?: Point2d, |   end?: Point2d, | ||||||
|   radius?: number, |   radius?: number(Length), | ||||||
|   angle?: number, |   diameter?: number(Length), | ||||||
|   tag?: TagDeclarator, |   angle?: number(Angle), | ||||||
|  |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| When using radius and angle, draw a curved line segment along part of an imaginary circle. The arc is constructed such that the last line segment is placed tangent to the imaginary circle of the specified radius. The resulting arc is the segment of the imaginary circle from that tangent point for 'angle' degrees along the imaginary circle. | When using radius and angle, draw a curved line segment along part of an | ||||||
|  | imaginary circle. The arc is constructed such that the last line segment is | ||||||
|  | placed tangent to the imaginary circle of the specified radius. The | ||||||
|  | resulting arc is the segment of the imaginary circle from that tangent point | ||||||
|  | for 'angle' degrees along the imaginary circle. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| @ -27,9 +32,10 @@ When using radius and angle, draw a curved line segment along part of an imagina | |||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Which absolute point should this arc go to? Incompatible with `end`, `radius`, and `offset`. | No | | | `endAbsolute` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | Which absolute point should this arc go to? Incompatible with `end`, `radius`, and `offset`. | No | | ||||||
| | `end` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | How far away (along the X and Y axes) should this arc go? Incompatible with `endAbsolute`, `radius`, and `offset`. | No | | | `end` | [`Point2d`](/docs/kcl-std/types/std-types-Point2d) | How far away (along the X and Y axes) should this arc go? Incompatible with `endAbsolute`, `radius`, and `offset`. | No | | ||||||
| | `radius` | [`number`](/docs/kcl-std/types/std-types-number) | Radius of the imaginary circle. `angle` must be given. Incompatible with `end` and `endAbsolute`. | No | | | `radius` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Radius of the imaginary circle. `angle` must be given. Incompatible with `end` and `endAbsolute` and `diameter`. | No | | ||||||
| | `angle` | [`number`](/docs/kcl-std/types/std-types-number) | Offset of the arc in degrees. `radius` must be given. Incompatible with `end` and `endAbsolute`. | No | | | `diameter` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Diameter of the imaginary circle. `angle` must be given. Incompatible with `end` and `endAbsolute` and `radius`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this arc | No | | | `angle` | [`number(Angle)`](/docs/kcl-std/types/std-types-number) | Offset of the arc. `radius` must be given. Incompatible with `end` and `endAbsolute`. | No | | ||||||
|  | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this arc. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -41,7 +47,10 @@ When using radius and angle, draw a curved line segment along part of an imagina | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> angledLine(angle = 45, length = 10) |   |> angledLine( | ||||||
|  |     angle = 45, | ||||||
|  |     length = 10, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(end = [0, -10]) |   |> tangentialArc(end = [0, -10]) | ||||||
|   |> line(end = [-10, 0]) |   |> line(end = [-10, 0]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -54,7 +63,10 @@ example = extrude(exampleSketch, length = 10) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> angledLine(angle = 60, length = 10) |   |> angledLine( | ||||||
|  |     angle = 60, | ||||||
|  |     length = 10, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(endAbsolute = [15, 15]) |   |> tangentialArc(endAbsolute = [15, 15]) | ||||||
|   |> line(end = [10, -15]) |   |> line(end = [10, -15]) | ||||||
|   |> close() |   |> close() | ||||||
| @ -67,9 +79,15 @@ example = extrude(exampleSketch, length = 10) | |||||||
| ```kcl | ```kcl | ||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> angledLine(angle = 60, length = 10) |   |> angledLine( | ||||||
|  |     angle = 60, | ||||||
|  |     length = 10, | ||||||
|  |   ) | ||||||
|   |> tangentialArc(radius = 10, angle = -120) |   |> tangentialArc(radius = 10, angle = -120) | ||||||
|   |> angledLine(angle = -60, length = 10) |   |> angledLine( | ||||||
|  |     angle = -60, | ||||||
|  |     length = 10, | ||||||
|  |   ) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| example = extrude(exampleSketch, length = 10) | example = extrude(exampleSketch, length = 10) | ||||||
| @ -10,9 +10,9 @@ Draw a line relative to the current origin to a specified distance away from the | |||||||
| ```kcl | ```kcl | ||||||
| xLine( | xLine( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   length?: number, |   length?: number(Length), | ||||||
|   endAbsolute?: number, |   endAbsolute?: number(Length), | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -23,9 +23,9 @@ xLine( | |||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `length` | [`number`](/docs/kcl-std/types/std-types-number) | How far away along the X axis should this line go? Incompatible with `endAbsolute`. | No | | | `length` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | How far away along the X axis should this line go? Incompatible with `endAbsolute`. | No | | ||||||
| | `endAbsolute` | [`number`](/docs/kcl-std/types/std-types-number) | Which absolute X value should this line go to? Incompatible with `length`. | No | | | `endAbsolute` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Which absolute X value should this line go to? Incompatible with `length`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -38,10 +38,16 @@ xLine( | |||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> xLine(length = 15) |   |> xLine(length = 15) | ||||||
|   |> angledLine(angle = 80, length = 15) |   |> angledLine( | ||||||
|  |     angle = 80, | ||||||
|  |     length = 15, | ||||||
|  |   ) | ||||||
|   |> line(end = [8, -10]) |   |> line(end = [8, -10]) | ||||||
|   |> xLine(length = 10) |   |> xLine(length = 10) | ||||||
|   |> angledLine(angle = 120, length = 30) |   |> angledLine( | ||||||
|  |     angle = 120, | ||||||
|  |     length = 30, | ||||||
|  |   ) | ||||||
|   |> xLine(length = -15) |   |> xLine(length = -15) | ||||||
|   |> close() |   |> close() | ||||||
| 
 | 
 | ||||||
| @ -10,9 +10,9 @@ Draw a line relative to the current origin to a specified distance away from the | |||||||
| ```kcl | ```kcl | ||||||
| yLine( | yLine( | ||||||
|   @sketch: Sketch, |   @sketch: Sketch, | ||||||
|   length?: number, |   length?: number(Length), | ||||||
|   endAbsolute?: number, |   endAbsolute?: number(Length), | ||||||
|   tag?: TagDeclarator, |   tag?: tag, | ||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| @ -23,9 +23,9 @@ yLine( | |||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | | `sketch` | [`Sketch`](/docs/kcl-std/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | | ||||||
| | `length` | [`number`](/docs/kcl-std/types/std-types-number) | How far away along the Y axis should this line go? Incompatible with `endAbsolute`. | No | | | `length` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | How far away along the Y axis should this line go? Incompatible with `endAbsolute`. | No | | ||||||
| | `endAbsolute` | [`number`](/docs/kcl-std/types/std-types-number) | Which absolute Y value should this line go to? Incompatible with `length`. | No | | | `endAbsolute` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | Which absolute Y value should this line go to? Incompatible with `length`. | No | | ||||||
| | [`tag`](/docs/kcl-std/types/std-types-tag) | [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) | Create a new tag which refers to this line | No | | | [`tag`](/docs/kcl-std/types/std-types-tag) | [`tag`](/docs/kcl-std/types/std-types-tag) | Create a new tag which refers to this line. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| @ -38,7 +38,10 @@ yLine( | |||||||
| exampleSketch = startSketchOn(XZ) | exampleSketch = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> yLine(length = 15) |   |> yLine(length = 15) | ||||||
|   |> angledLine(angle = 30, length = 15) |   |> angledLine( | ||||||
|  |     angle = 30, | ||||||
|  |     length = 15, | ||||||
|  |   ) | ||||||
|   |> line(end = [8, -10]) |   |> line(end = [8, -10]) | ||||||
|   |> yLine(length = -5) |   |> yLine(length = -5) | ||||||
|   |> close() |   |> close() | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -9,23 +9,26 @@ Intersect returns the shared volume between multiple solids, preserving only ove | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| intersect( | intersect( | ||||||
|   @solids: [Solid], |   @solids: [Solid; 2+], | ||||||
|   tolerance?: number, |   tolerance?: number(Length), | ||||||
| ): [Solid] | ): [Solid; 1+] | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| Intersect computes the geometric intersection of multiple solid bodies, returning a new solid representing the volume that is common to all input solids. This operation is useful for determining shared material regions, verifying fit, and analyzing overlapping geometries in assemblies. | Intersect computes the geometric intersection of multiple solid bodies, | ||||||
|  | returning a new solid representing the volume that is common to all input | ||||||
|  | solids. This operation is useful for determining shared material regions, | ||||||
|  | verifying fit, and analyzing overlapping geometries in assemblies. | ||||||
| 
 | 
 | ||||||
| ### Arguments | ### Arguments | ||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `solids` | [`[Solid]`](/docs/kcl-std/types/std-types-Solid) | The solids to intersect. | Yes | | | `solids` | `[Solid; 2+]` | The solids to intersect. | Yes | | ||||||
| | `tolerance` | [`number`](/docs/kcl-std/types/std-types-number) | The tolerance to use for the intersection operation. | No | | | `tolerance` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The tolerance to use for the intersection operation. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[Solid]`](/docs/kcl-std/types/std-types-Solid) | [`[Solid; 1+]`](/docs/kcl-std/types/std-types-Solid) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -33,7 +36,6 @@ Intersect computes the geometric intersection of multiple solid bodies, returnin | |||||||
| ```kcl | ```kcl | ||||||
| // Intersect two cubes using the stdlib functions. | // Intersect two cubes using the stdlib functions. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| fn cube(center, size) { | fn cube(center, size) { | ||||||
|     return startSketchOn(XY) |     return startSketchOn(XY) | ||||||
|         |> startProfile(at = [center[0] - size, center[1] - size]) |         |> startProfile(at = [center[0] - size, center[1] - size]) | ||||||
| @ -58,7 +60,6 @@ intersectedPart = intersect([part001, part002]) | |||||||
| // NOTE: This will not work when using codemods through the UI. | // NOTE: This will not work when using codemods through the UI. | ||||||
| // Codemods will generate the stdlib function call instead. | // Codemods will generate the stdlib function call instead. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| fn cube(center, size) { | fn cube(center, size) { | ||||||
|     return startSketchOn(XY) |     return startSketchOn(XY) | ||||||
|         |> startProfile(at = [center[0] - size, center[1] - size]) |         |> startProfile(at = [center[0] - size, center[1] - size]) | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,11 +1,11 @@ | |||||||
| --- | --- | ||||||
| title: "shell" | title: "shell" | ||||||
| subtitle: "Function in std::solid" | subtitle: "Function in std::solid" | ||||||
| excerpt: "" | excerpt: "Remove volume from a 3-dimensional shape such that a wall of the provided thickness remains, taking volume starting at the provided face, leaving it open in that direction." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
|  | Remove volume from a 3-dimensional shape such that a wall of the provided thickness remains, taking volume starting at the provided face, leaving it open in that direction. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| shell( | shell( | ||||||
| @ -15,8 +15,7 @@ shell( | |||||||
| ): [Solid] | ): [Solid] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Remove volume from a 3-dimensional shape such that a wall of the |  | ||||||
| provided thickness remains, taking volume starting at the providedface, leaving it open in that direction. |  | ||||||
|  |  | ||||||
| ### Arguments | ### Arguments | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -9,9 +9,9 @@ Union two or more solids into a single solid. | |||||||
| 
 | 
 | ||||||
| ```kcl | ```kcl | ||||||
| union( | union( | ||||||
|   @solids: [Solid], |   @solids: [Solid; 2+], | ||||||
|   tolerance?: number, |   tolerance?: number(Length), | ||||||
| ): [Solid] | ): [Solid; 1+] | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -20,12 +20,12 @@ union( | |||||||
| 
 | 
 | ||||||
| | Name | Type | Description | Required | | | Name | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `solids` | [`[Solid]`](/docs/kcl-std/types/std-types-Solid) | The solids to union. | Yes | | | `solids` | `[Solid; 2+]` | The solids to union. | Yes | | ||||||
| | `tolerance` | [`number`](/docs/kcl-std/types/std-types-number) | The tolerance to use for the union operation. | No | | | `tolerance` | [`number(Length)`](/docs/kcl-std/types/std-types-number) | The tolerance to use for the union operation. | No | | ||||||
| 
 | 
 | ||||||
| ### Returns | ### Returns | ||||||
| 
 | 
 | ||||||
| [`[Solid]`](/docs/kcl-std/types/std-types-Solid) | [`[Solid; 1+]`](/docs/kcl-std/types/std-types-Solid) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| @ -33,7 +33,6 @@ union( | |||||||
| ```kcl | ```kcl | ||||||
| // Union two cubes using the stdlib functions. | // Union two cubes using the stdlib functions. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| fn cube(center, size) { | fn cube(center, size) { | ||||||
|     return startSketchOn(XY) |     return startSketchOn(XY) | ||||||
|         |> startProfile(at = [center[0] - size, center[1] - size]) |         |> startProfile(at = [center[0] - size, center[1] - size]) | ||||||
| @ -58,7 +57,6 @@ unionedPart = union([part001, part002]) | |||||||
| // NOTE: This will not work when using codemods through the UI. | // NOTE: This will not work when using codemods through the UI. | ||||||
| // Codemods will generate the stdlib function call instead. | // Codemods will generate the stdlib function call instead. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| fn cube(center, size) { | fn cube(center, size) { | ||||||
|     return startSketchOn(XY) |     return startSketchOn(XY) | ||||||
|         |> startProfile(at = [center[0] - size, center[1] - size]) |         |> startProfile(at = [center[0] - size, center[1] - size]) | ||||||
| @ -84,7 +82,6 @@ unionedPart = part001 + part002 | |||||||
| // NOTE: This will not work when using codemods through the UI. | // NOTE: This will not work when using codemods through the UI. | ||||||
| // Codemods will generate the stdlib function call instead. | // Codemods will generate the stdlib function call instead. | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| fn cube(center, size) { | fn cube(center, size) { | ||||||
|     return startSketchOn(XY) |     return startSketchOn(XY) | ||||||
|         |> startProfile(at = [center[0] - size, center[1] - size]) |         |> startProfile(at = [center[0] - size, center[1] - size]) | ||||||
| @ -99,8 +96,8 @@ part001 = cube(center = [0, 0], size = 10) | |||||||
| part002 = cube(center = [7, 3], size = 5) | part002 = cube(center = [7, 3], size = 5) | ||||||
|     |> translate(z = 1) |     |> translate(z = 1) | ||||||
| 
 | 
 | ||||||
|   // This is the equivalent of: union([part001, part002]) | // This is the equivalent of: union([part001, part002]) | ||||||
|   // Programmers will understand `|` as a union operation, but mechanical engineers | // Programmers will understand `|` as a union operation, but mechanical engineers | ||||||
| // will understand `+`, we made both work. | // will understand `+`, we made both work. | ||||||
| unionedPart = part001 | part002 | unionedPart = part001 | part002 | ||||||
| ``` | ``` | ||||||
| @ -14,8 +14,6 @@ mirror2d( | |||||||
| ): Sketch | ): Sketch | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Only works on unclosed sketches for now. |  | ||||||
|  |  | ||||||
| Mirror occurs around a local sketch axis rather than a global axis. | Mirror occurs around a local sketch axis rather than a global axis. | ||||||
|  |  | ||||||
| ### Arguments | ### Arguments | ||||||
|  | |||||||
							
								
								
									
										275
									
								
								docs/kcl-std/functions/std-transform-rotate.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										275
									
								
								docs/kcl-std/functions/std-transform-rotate.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										129
									
								
								docs/kcl-std/functions/std-transform-scale.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								docs/kcl-std/functions/std-transform-scale.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
											
										
									
								
							| @ -9,18 +9,18 @@ layout: manual | |||||||
| ### Functions | ### Functions | ||||||
|  |  | ||||||
| * [**std**](/docs/kcl-std/modules/std) | * [**std**](/docs/kcl-std/modules/std) | ||||||
|   * [`appearance`](/docs/kcl-std/appearance) |   * [`assert`](/docs/kcl-std/functions/std-assert) | ||||||
|   * [`assert`](/docs/kcl-std/assert) |   * [`assertIs`](/docs/kcl-std/functions/std-assertIs) | ||||||
|   * [`assertIs`](/docs/kcl-std/assertIs) |   * [`clone`](/docs/kcl-std/functions/std-clone) | ||||||
|   * [`clone`](/docs/kcl-std/clone) |  | ||||||
|   * [`helix`](/docs/kcl-std/functions/std-helix) |   * [`helix`](/docs/kcl-std/functions/std-helix) | ||||||
|   * [`offsetPlane`](/docs/kcl-std/functions/std-offsetPlane) |   * [`offsetPlane`](/docs/kcl-std/functions/std-offsetPlane) | ||||||
|   * [`patternLinear2d`](/docs/kcl-std/patternLinear2d) | * [**std::appearance**](/docs/kcl-std/modules/std-appearance) | ||||||
|  |   * [`appearance::hexString`](/docs/kcl-std/functions/std-appearance-hexString) | ||||||
| * [**std::array**](/docs/kcl-std/modules/std-array) | * [**std::array**](/docs/kcl-std/modules/std-array) | ||||||
|   * [`map`](/docs/kcl-std/map) |   * [`map`](/docs/kcl-std/functions/std-array-map) | ||||||
|   * [`pop`](/docs/kcl-std/pop) |   * [`pop`](/docs/kcl-std/functions/std-array-pop) | ||||||
|   * [`push`](/docs/kcl-std/push) |   * [`push`](/docs/kcl-std/functions/std-array-push) | ||||||
|   * [`reduce`](/docs/kcl-std/reduce) |   * [`reduce`](/docs/kcl-std/functions/std-array-reduce) | ||||||
| * [**std::math**](/docs/kcl-std/modules/std-math) | * [**std::math**](/docs/kcl-std/modules/std-math) | ||||||
|   * [`abs`](/docs/kcl-std/functions/std-math-abs) |   * [`abs`](/docs/kcl-std/functions/std-math-abs) | ||||||
|   * [`acos`](/docs/kcl-std/functions/std-math-acos) |   * [`acos`](/docs/kcl-std/functions/std-math-acos) | ||||||
| @ -30,9 +30,9 @@ layout: manual | |||||||
|   * [`ceil`](/docs/kcl-std/functions/std-math-ceil) |   * [`ceil`](/docs/kcl-std/functions/std-math-ceil) | ||||||
|   * [`cos`](/docs/kcl-std/functions/std-math-cos) |   * [`cos`](/docs/kcl-std/functions/std-math-cos) | ||||||
|   * [`floor`](/docs/kcl-std/functions/std-math-floor) |   * [`floor`](/docs/kcl-std/functions/std-math-floor) | ||||||
|   * [`legAngX`](/docs/kcl-std/legAngX) |   * [`legAngX`](/docs/kcl-std/functions/std-math-legAngX) | ||||||
|   * [`legAngY`](/docs/kcl-std/legAngY) |   * [`legAngY`](/docs/kcl-std/functions/std-math-legAngY) | ||||||
|   * [`legLen`](/docs/kcl-std/legLen) |   * [`legLen`](/docs/kcl-std/functions/std-math-legLen) | ||||||
|   * [`ln`](/docs/kcl-std/functions/std-math-ln) |   * [`ln`](/docs/kcl-std/functions/std-math-ln) | ||||||
|   * [`log`](/docs/kcl-std/functions/std-math-log) |   * [`log`](/docs/kcl-std/functions/std-math-log) | ||||||
|   * [`log10`](/docs/kcl-std/functions/std-math-log10) |   * [`log10`](/docs/kcl-std/functions/std-math-log10) | ||||||
| @ -47,62 +47,64 @@ layout: manual | |||||||
|   * [`sqrt`](/docs/kcl-std/functions/std-math-sqrt) |   * [`sqrt`](/docs/kcl-std/functions/std-math-sqrt) | ||||||
|   * [`tan`](/docs/kcl-std/functions/std-math-tan) |   * [`tan`](/docs/kcl-std/functions/std-math-tan) | ||||||
| * [**std::sketch**](/docs/kcl-std/modules/std-sketch) | * [**std::sketch**](/docs/kcl-std/modules/std-sketch) | ||||||
|   * [`angledLine`](/docs/kcl-std/angledLine) |   * [`angledLine`](/docs/kcl-std/functions/std-sketch-angledLine) | ||||||
|   * [`angledLineThatIntersects`](/docs/kcl-std/angledLineThatIntersects) |   * [`angledLineThatIntersects`](/docs/kcl-std/functions/std-sketch-angledLineThatIntersects) | ||||||
|   * [`arc`](/docs/kcl-std/arc) |   * [`arc`](/docs/kcl-std/functions/std-sketch-arc) | ||||||
|   * [`bezierCurve`](/docs/kcl-std/bezierCurve) |   * [`bezierCurve`](/docs/kcl-std/functions/std-sketch-bezierCurve) | ||||||
|   * [`circle`](/docs/kcl-std/functions/std-sketch-circle) |   * [`circle`](/docs/kcl-std/functions/std-sketch-circle) | ||||||
|   * [`circleThreePoint`](/docs/kcl-std/circleThreePoint) |   * [`circleThreePoint`](/docs/kcl-std/functions/std-sketch-circleThreePoint) | ||||||
|   * [`close`](/docs/kcl-std/close) |   * [`close`](/docs/kcl-std/functions/std-sketch-close) | ||||||
|   * [`extrude`](/docs/kcl-std/extrude) |   * [`extrude`](/docs/kcl-std/functions/std-sketch-extrude) | ||||||
|   * [`getCommonEdge`](/docs/kcl-std/getCommonEdge) |   * [`getCommonEdge`](/docs/kcl-std/functions/std-sketch-getCommonEdge) | ||||||
|   * [`getNextAdjacentEdge`](/docs/kcl-std/getNextAdjacentEdge) |   * [`getNextAdjacentEdge`](/docs/kcl-std/functions/std-sketch-getNextAdjacentEdge) | ||||||
|   * [`getOppositeEdge`](/docs/kcl-std/getOppositeEdge) |   * [`getOppositeEdge`](/docs/kcl-std/functions/std-sketch-getOppositeEdge) | ||||||
|   * [`getPreviousAdjacentEdge`](/docs/kcl-std/getPreviousAdjacentEdge) |   * [`getPreviousAdjacentEdge`](/docs/kcl-std/functions/std-sketch-getPreviousAdjacentEdge) | ||||||
|   * [`involuteCircular`](/docs/kcl-std/involuteCircular) |   * [`involuteCircular`](/docs/kcl-std/functions/std-sketch-involuteCircular) | ||||||
|   * [`lastSegX`](/docs/kcl-std/lastSegX) |   * [`lastSegX`](/docs/kcl-std/functions/std-sketch-lastSegX) | ||||||
|   * [`lastSegY`](/docs/kcl-std/lastSegY) |   * [`lastSegY`](/docs/kcl-std/functions/std-sketch-lastSegY) | ||||||
|   * [`line`](/docs/kcl-std/line) |   * [`line`](/docs/kcl-std/functions/std-sketch-line) | ||||||
|   * [`loft`](/docs/kcl-std/loft) |   * [`loft`](/docs/kcl-std/functions/std-sketch-loft) | ||||||
|   * [`patternCircular2d`](/docs/kcl-std/patternCircular2d) |   * [`patternCircular2d`](/docs/kcl-std/functions/std-sketch-patternCircular2d) | ||||||
|   * [`patternTransform2d`](/docs/kcl-std/patternTransform2d) |   * [`patternLinear2d`](/docs/kcl-std/functions/std-sketch-patternLinear2d) | ||||||
|   * [`polygon`](/docs/kcl-std/polygon) |   * [`patternTransform2d`](/docs/kcl-std/functions/std-sketch-patternTransform2d) | ||||||
|   * [`profileStart`](/docs/kcl-std/profileStart) |   * [`polygon`](/docs/kcl-std/functions/std-sketch-polygon) | ||||||
|   * [`profileStartX`](/docs/kcl-std/profileStartX) |   * [`profileStart`](/docs/kcl-std/functions/std-sketch-profileStart) | ||||||
|   * [`profileStartY`](/docs/kcl-std/profileStartY) |   * [`profileStartX`](/docs/kcl-std/functions/std-sketch-profileStartX) | ||||||
|  |   * [`profileStartY`](/docs/kcl-std/functions/std-sketch-profileStartY) | ||||||
|   * [`revolve`](/docs/kcl-std/functions/std-sketch-revolve) |   * [`revolve`](/docs/kcl-std/functions/std-sketch-revolve) | ||||||
|   * [`segAng`](/docs/kcl-std/segAng) |   * [`segAng`](/docs/kcl-std/functions/std-sketch-segAng) | ||||||
|   * [`segEnd`](/docs/kcl-std/segEnd) |   * [`segEnd`](/docs/kcl-std/functions/std-sketch-segEnd) | ||||||
|   * [`segEndX`](/docs/kcl-std/segEndX) |   * [`segEndX`](/docs/kcl-std/functions/std-sketch-segEndX) | ||||||
|   * [`segEndY`](/docs/kcl-std/segEndY) |   * [`segEndY`](/docs/kcl-std/functions/std-sketch-segEndY) | ||||||
|   * [`segLen`](/docs/kcl-std/segLen) |   * [`segLen`](/docs/kcl-std/functions/std-sketch-segLen) | ||||||
|   * [`segStart`](/docs/kcl-std/segStart) |   * [`segStart`](/docs/kcl-std/functions/std-sketch-segStart) | ||||||
|   * [`segStartX`](/docs/kcl-std/segStartX) |   * [`segStartX`](/docs/kcl-std/functions/std-sketch-segStartX) | ||||||
|   * [`segStartY`](/docs/kcl-std/segStartY) |   * [`segStartY`](/docs/kcl-std/functions/std-sketch-segStartY) | ||||||
|   * [`startProfile`](/docs/kcl-std/startProfile) |   * [`startProfile`](/docs/kcl-std/functions/std-sketch-startProfile) | ||||||
|   * [`startSketchOn`](/docs/kcl-std/startSketchOn) |   * [`startSketchOn`](/docs/kcl-std/functions/std-sketch-startSketchOn) | ||||||
|   * [`subtract2d`](/docs/kcl-std/subtract2d) |   * [`subtract2d`](/docs/kcl-std/functions/std-sketch-subtract2d) | ||||||
|   * [`sweep`](/docs/kcl-std/sweep) |   * [`sweep`](/docs/kcl-std/functions/std-sketch-sweep) | ||||||
|   * [`tangentToEnd`](/docs/kcl-std/tangentToEnd) |   * [`tangentToEnd`](/docs/kcl-std/functions/std-sketch-tangentToEnd) | ||||||
|   * [`tangentialArc`](/docs/kcl-std/tangentialArc) |   * [`tangentialArc`](/docs/kcl-std/functions/std-sketch-tangentialArc) | ||||||
|   * [`xLine`](/docs/kcl-std/xLine) |   * [`xLine`](/docs/kcl-std/functions/std-sketch-xLine) | ||||||
|   * [`yLine`](/docs/kcl-std/yLine) |   * [`yLine`](/docs/kcl-std/functions/std-sketch-yLine) | ||||||
| * [**std::solid**](/docs/kcl-std/modules/std-solid) | * [**std::solid**](/docs/kcl-std/modules/std-solid) | ||||||
|  |   * [`appearance`](/docs/kcl-std/functions/std-solid-appearance) | ||||||
|   * [`chamfer`](/docs/kcl-std/functions/std-solid-chamfer) |   * [`chamfer`](/docs/kcl-std/functions/std-solid-chamfer) | ||||||
|   * [`fillet`](/docs/kcl-std/functions/std-solid-fillet) |   * [`fillet`](/docs/kcl-std/functions/std-solid-fillet) | ||||||
|   * [`hollow`](/docs/kcl-std/functions/std-solid-hollow) |   * [`hollow`](/docs/kcl-std/functions/std-solid-hollow) | ||||||
|   * [`intersect`](/docs/kcl-std/intersect) |   * [`intersect`](/docs/kcl-std/functions/std-solid-intersect) | ||||||
|   * [`patternCircular3d`](/docs/kcl-std/patternCircular3d) |   * [`patternCircular3d`](/docs/kcl-std/functions/std-solid-patternCircular3d) | ||||||
|   * [`patternLinear3d`](/docs/kcl-std/patternLinear3d) |   * [`patternLinear3d`](/docs/kcl-std/functions/std-solid-patternLinear3d) | ||||||
|   * [`patternTransform`](/docs/kcl-std/patternTransform) |   * [`patternTransform`](/docs/kcl-std/functions/std-solid-patternTransform) | ||||||
|   * [`shell`](/docs/kcl-std/functions/std-solid-shell) |   * [`shell`](/docs/kcl-std/functions/std-solid-shell) | ||||||
|   * [`subtract`](/docs/kcl-std/subtract) |   * [`subtract`](/docs/kcl-std/functions/std-solid-subtract) | ||||||
|   * [`union`](/docs/kcl-std/union) |   * [`union`](/docs/kcl-std/functions/std-solid-union) | ||||||
| * [**std::transform**](/docs/kcl-std/modules/std-transform) | * [**std::transform**](/docs/kcl-std/modules/std-transform) | ||||||
|   * [`mirror2d`](/docs/kcl-std/functions/std-transform-mirror2d) |   * [`mirror2d`](/docs/kcl-std/functions/std-transform-mirror2d) | ||||||
|   * [`rotate`](/docs/kcl-std/rotate) |   * [`rotate`](/docs/kcl-std/functions/std-transform-rotate) | ||||||
|   * [`scale`](/docs/kcl-std/scale) |   * [`scale`](/docs/kcl-std/functions/std-transform-scale) | ||||||
|   * [`translate`](/docs/kcl-std/translate) |   * [`translate`](/docs/kcl-std/functions/std-transform-translate) | ||||||
| * [**std::units**](/docs/kcl-std/modules/std-units) | * [**std::units**](/docs/kcl-std/modules/std-units) | ||||||
|   * [`units::toCentimeters`](/docs/kcl-std/functions/std-units-toCentimeters) |   * [`units::toCentimeters`](/docs/kcl-std/functions/std-units-toCentimeters) | ||||||
|   * [`units::toDegrees`](/docs/kcl-std/functions/std-units-toDegrees) |   * [`units::toDegrees`](/docs/kcl-std/functions/std-units-toDegrees) | ||||||
| @ -128,6 +130,9 @@ layout: manual | |||||||
|   * [`E`](/docs/kcl-std/consts/std-math-E) |   * [`E`](/docs/kcl-std/consts/std-math-E) | ||||||
|   * [`PI`](/docs/kcl-std/consts/std-math-PI) |   * [`PI`](/docs/kcl-std/consts/std-math-PI) | ||||||
|   * [`TAU`](/docs/kcl-std/consts/std-math-TAU) |   * [`TAU`](/docs/kcl-std/consts/std-math-TAU) | ||||||
|  | * [**std::sweep**](/docs/kcl-std/modules/std-sweep) | ||||||
|  |   * [`sweep::SKETCH_PLANE`](/docs/kcl-std/consts/std-sweep-SKETCH_PLANE) | ||||||
|  |   * [`sweep::TRAJECTORY`](/docs/kcl-std/consts/std-sweep-TRAJECTORY) | ||||||
| * [**std::turns**](/docs/kcl-std/modules/std-turns) | * [**std::turns**](/docs/kcl-std/modules/std-turns) | ||||||
|   * [`turns::HALF_TURN`](/docs/kcl-std/consts/std-turns-HALF_TURN) |   * [`turns::HALF_TURN`](/docs/kcl-std/consts/std-turns-HALF_TURN) | ||||||
|   * [`turns::QUARTER_TURN`](/docs/kcl-std/consts/std-turns-QUARTER_TURN) |   * [`turns::QUARTER_TURN`](/docs/kcl-std/consts/std-turns-QUARTER_TURN) | ||||||
| @ -139,13 +144,10 @@ layout: manual | |||||||
| See also the [types overview](/docs/kcl-lang/types) | See also the [types overview](/docs/kcl-lang/types) | ||||||
|  |  | ||||||
| * [**Primitive types**](/docs/kcl-lang/types) | * [**Primitive types**](/docs/kcl-lang/types) | ||||||
|   * [`End`](/docs/kcl-lang/types#End) |   * [`ImportedGeometry`](/docs/kcl-std/types/std-types-ImportedGeometry) | ||||||
|   * [`ImportedGeometry`](/docs/kcl-lang/types#ImportedGeometry) |  | ||||||
|   * [`Start`](/docs/kcl-lang/types#Start) |  | ||||||
|   * [`TagDeclarator`](/docs/kcl-lang/types#TagDeclarator) |  | ||||||
|   * [`TagIdentifier`](/docs/kcl-lang/types#TagIdentifier) |  | ||||||
|   * [`any`](/docs/kcl-std/types/std-types-any) |   * [`any`](/docs/kcl-std/types/std-types-any) | ||||||
|   * [`bool`](/docs/kcl-std/types/std-types-bool) |   * [`bool`](/docs/kcl-std/types/std-types-bool) | ||||||
|  |   * [`fn`](/docs/kcl-std/types/std-types-fn) | ||||||
|   * [`number`](/docs/kcl-std/types/std-types-number) |   * [`number`](/docs/kcl-std/types/std-types-number) | ||||||
|   * [`string`](/docs/kcl-std/types/std-types-string) |   * [`string`](/docs/kcl-std/types/std-types-string) | ||||||
|   * [`tag`](/docs/kcl-std/types/std-types-tag) |   * [`tag`](/docs/kcl-std/types/std-types-tag) | ||||||
|  | |||||||
| @ -1,38 +0,0 @@ | |||||||
| --- |  | ||||||
| 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, |  | ||||||
|   leg: number, |  | ||||||
| ): number |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | [`number`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse | Yes | |  | ||||||
| | `leg` | [`number`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples |  | ||||||
|  |  | ||||||
| ```kcl |  | ||||||
| legAngX(hypotenuse = 5, leg = 3) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,38 +0,0 @@ | |||||||
| --- |  | ||||||
| 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, |  | ||||||
|   leg: number, |  | ||||||
| ): number |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | [`number`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse | Yes | |  | ||||||
| | `leg` | [`number`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples |  | ||||||
|  |  | ||||||
| ```kcl |  | ||||||
| legAngY(hypotenuse = 5, leg = 3) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,38 +0,0 @@ | |||||||
| --- |  | ||||||
| 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, |  | ||||||
|   leg: number, |  | ||||||
| ): number |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | [`number`](/docs/kcl-std/types/std-types-number) | The length of the triangle's hypotenuse | Yes | |  | ||||||
| | `leg` | [`number`](/docs/kcl-std/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| [`number`](/docs/kcl-std/types/std-types-number) - A number. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples |  | ||||||
|  |  | ||||||
| ```kcl |  | ||||||
| legLen(hypotenuse = 5, leg = 3) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	