Compare commits
	
		
			111 Commits
		
	
	
		
			v1.0.4
			...
			pierremtb/
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4251dfdbf7 | |||
| 5a9c3f0d6f | |||
| cb3b45747c | |||
| fe66310f2d | |||
| fefb6cfe87 | |||
| 0f8375cbb4 | |||
| 107adc77b3 | |||
| 4356885aa2 | |||
| 6a2027cd51 | |||
| f49cf8281c | |||
| 7de27c648f | |||
| 344fb6f84d | |||
| df808b3e58 | |||
| e1ab6bbc48 | |||
| 0a1f35b89a | |||
| 78278d6889 | |||
| 6f1a539e83 | |||
| 0ad619e1d2 | |||
| 8d876a806e | |||
| c7f0a6c2a0 | |||
| e4941cb524 | |||
| 1b687a82a6 | |||
| 1bb882acf8 | |||
| 478bf34f2b | |||
| dbc87292e4 | |||
| bb3a74076f | |||
| 0cd6031aae | |||
| 1e1bdbd6e7 | |||
| 631b63b1b6 | |||
| eabcf86436 | |||
| 7ce0ef770a | |||
| 599ab33e40 | |||
| c584d942d4 | |||
| 35b8872678 | |||
| 2f245fe445 | |||
| 4b95980e9e | |||
| 53d6613d0d | |||
| 416d0b37a2 | |||
| 5f2a10ec7e | |||
| 24edb66b3c | |||
| 903ba33c46 | |||
| c5bf6ad42d | |||
| eeaa71142a | |||
| 0d1fc1b513 | |||
| d510e58ebc | |||
| 23a01e86e6 | |||
| 9dd6e3e852 | |||
| 9eaacc2a51 | |||
| de6e0f6b18 | |||
| d02a9f59ae | |||
| 92f930dfc0 | |||
| e651e0c2cf | |||
| 6358eed7e4 | |||
| fe581ff1d2 | |||
| b301fbba22 | |||
| 0c702e4bab | |||
| 25b9a34640 | |||
| b2152a5684 | |||
| 832bf77c92 | |||
| acb43fc82c | |||
| 7486d25cf1 | |||
| 1a4a030671 | |||
| 3049d939e1 | |||
| ad9822e8ac | |||
| aae34cf1e5 | |||
| d6278cf075 | |||
| 4159cc0047 | |||
| 3936017f10 | |||
| 2b0ced179a | |||
| c2f6ce065d | |||
| b3bdc35da2 | |||
| 8fe4f67a29 | |||
| c6b1d11700 | |||
| 2ef84382a6 | |||
| 939c2c77b0 | |||
| 31ec0184a1 | |||
| 62c4546658 | |||
| 383b38c2d2 | |||
| e0025f7fad | |||
| 2a13888c54 | |||
| 1443f3ab39 | |||
| bf87c23ea8 | |||
| 5d23b0e487 | |||
| df6c81b0b4 | |||
| 5f1f579d4b | |||
| 9a549ff379 | |||
| 851ea28bd3 | |||
| ff15c7b9db | |||
| f304577d5d | |||
| b03b0d3b53 | |||
| dd4d0f6d98 | |||
| 1cd742df5d | |||
| 6460ed8ea8 | |||
| 5c51b27f29 | |||
| 77690b4419 | |||
| 6996670020 | |||
| 1fd4e93091 | |||
| a1ac029333 | |||
| 29cf16d744 | |||
| 9b3afccf53 | |||
| 231ca0fa35 | |||
| 4608c02442 | |||
| de6184c622 | |||
| 0bce7d3c1c | |||
| c43ec280f2 | |||
| 8e6483a47b | |||
| e116bbaae8 | |||
| 18b458fbca | |||
| 4d1524f03b | |||
| 11d8179368 | |||
| 3c23cada8e | 
| @ -9,6 +9,7 @@ VITE_KC_SITE_BASE_URL=https://dev.zoo.dev | |||||||
| VITE_KC_SITE_APP_URL=https://app.dev.zoo.dev | VITE_KC_SITE_APP_URL=https://app.dev.zoo.dev | ||||||
| VITE_KC_SKIP_AUTH=false | VITE_KC_SKIP_AUTH=false | ||||||
| VITE_KC_CONNECTION_TIMEOUT_MS=5000 | VITE_KC_CONNECTION_TIMEOUT_MS=5000 | ||||||
|  | #VITE_WASM_URL="optional way of overriding the wasm url, particular for unit tests which need this if you running not on the default 3000 port" | ||||||
| #VITE_KC_DEV_TOKEN="optional token to skip auth in the app" | #VITE_KC_DEV_TOKEN="optional token to skip auth in the app" | ||||||
| #token="required token for playwright. TODO: clean up env vars in #3973" | #token="required token for playwright. TODO: clean up env vars in #3973" | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | |||||||
|  | * @KittyCAD/frontend | ||||||
|  | /src/ @KittyCAD/frontend | ||||||
|  | /rust/ @KittyCAD/kcl | ||||||
							
								
								
									
										41
									
								
								.github/ISSUE_TEMPLATE/release.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								.github/ISSUE_TEMPLATE/release.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | |||||||
|  | --- | ||||||
|  | name: Release | ||||||
|  | about: Create a new release for the Zoo Design Studio | ||||||
|  | title: "Cut release v1.?.?" | ||||||
|  | labels: [meta/release] | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | > Instructions: https://github.com/KittyCAD/modeling-app/blob/main/CONTRIBUTING.md#shipping-releases | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | # Manual Checklist | ||||||
|  |  | ||||||
|  | Release builds URL: ??? | ||||||
|  |  | ||||||
|  | ## Windows via ??? | ||||||
|  |  | ||||||
|  | * [ ] Download the release build for this platform | ||||||
|  | * [ ] Confirm the application opens (dismiss the updater) | ||||||
|  | * [ ] Create a project with a basic Text-to-CAD prompt | ||||||
|  | * [ ] Confirm the result is viewable in an engine stream | ||||||
|  | * [ ] Use 'Check for updates' to bring back the updater toast | ||||||
|  | * [ ] Confirm the app can update to the previous release | ||||||
|  |  | ||||||
|  | ## macOS via ??? | ||||||
|  |  | ||||||
|  | * [ ] Download the release build for this platform | ||||||
|  | * [ ] Confirm the application opens (dismiss the updater) | ||||||
|  | * [ ] Create a project with a basic Text-to-CAD prompt | ||||||
|  | * [ ] Confirm the result is viewable in an engine stream | ||||||
|  | * [ ] Use 'Check for updates' to bring back the updater toast | ||||||
|  | * [ ] Confirm the app can update to the previous release | ||||||
|  |  | ||||||
|  | ## Linux via ??? | ||||||
|  |  | ||||||
|  | * [ ] Download the release build for this platform | ||||||
|  | * [ ] Confirm the application opens (dismiss the updater) | ||||||
|  | * [ ] Create a project with a basic Text-to-CAD prompt | ||||||
|  | * [ ] Confirm the result is viewable in an engine stream | ||||||
|  | * [ ] Use 'Check for updates' to bring back the updater toast | ||||||
|  | * [ ] Confirm the app can update to the previous release | ||||||
							
								
								
									
										73
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										73
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							| @ -10,7 +10,7 @@ on: | |||||||
|  |  | ||||||
| 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.event_name == 'push' && github.ref == 'refs/heads/main' }} |   IS_STAGING: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||||
|  |  | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.ref }} |   group: ${{ github.workflow }}-${{ github.ref }} | ||||||
| @ -91,14 +91,14 @@ jobs: | |||||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} |         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||||
|         run: "npm run build:wasm" |         run: "npm run build:wasm" | ||||||
|  |  | ||||||
|       - name: Set nightly version, product name, release notes, and icons |       - name: Set staging version, product name, release notes, and icons | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_STAGING == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           COMMIT=$(git rev-parse --short HEAD) |           COMMIT=$(git rev-parse --short HEAD) | ||||||
|           DATE=$(date +'%-y.%-m.%-d') |           DATE=$(date +'%-y.%-m.%-d') | ||||||
|           export VERSION=$DATE-main.$COMMIT |           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-staging | ||||||
|  |  | ||||||
|       - name: Set release version |       - name: Set release version | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
| @ -130,13 +130,14 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         include: |         include: | ||||||
|           - os: macos-14 |           - os: namespace-profile-macos-6-cores | ||||||
|             platform: mac |             platform: macos | ||||||
|           - os: windows-2022 |           - os: namespace-profile-windows-4-cores | ||||||
|             platform: win |             platform: windows | ||||||
|           - os: ubuntu-22.04 |           - os: ubuntu-22.04 | ||||||
|             platform: linux |             platform: linux | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|  |     name: build-apps (${{ matrix.platform }}) | ||||||
|     env: |     env: | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|     steps: |     steps: | ||||||
| @ -166,14 +167,14 @@ jobs: | |||||||
|       - run: npm install |       - run: npm install | ||||||
|  |  | ||||||
|       - name: Prepare certificate and variables (Windows only) |       - name: Prepare certificate and variables (Windows only) | ||||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} |         if: ${{ (env.IS_RELEASE == 'true' || env.IS_STAGING == 'true') && matrix.platform == 'windows' }} | ||||||
|         run: | |         run: | | ||||||
|           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 |           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /c/Certificate_pkcs12.p12 | ||||||
|           cat /d/Certificate_pkcs12.p12 |           cat /c/Certificate_pkcs12.p12 | ||||||
|           echo "::set-output name=version::${GITHUB_REF#refs/tags/v}" |           echo "::set-output name=version::${GITHUB_REF#refs/tags/v}" | ||||||
|           echo "SM_HOST=${{ secrets.SM_HOST }}" >> "$GITHUB_ENV" |           echo "SM_HOST=${{ secrets.SM_HOST }}" >> "$GITHUB_ENV" | ||||||
|           echo "SM_API_KEY=${{ secrets.SM_API_KEY }}" >> "$GITHUB_ENV" |           echo "SM_API_KEY=${{ secrets.SM_API_KEY }}" >> "$GITHUB_ENV" | ||||||
|           echo "SM_CLIENT_CERT_FILE=D:\\Certificate_pkcs12.p12" >> "$GITHUB_ENV" |           echo "SM_CLIENT_CERT_FILE=C:\\Certificate_pkcs12.p12" >> "$GITHUB_ENV" | ||||||
|           echo "SM_CLIENT_CERT_PASSWORD=${{ secrets.SM_CLIENT_CERT_PASSWORD }}" >> "$GITHUB_ENV" |           echo "SM_CLIENT_CERT_PASSWORD=${{ secrets.SM_CLIENT_CERT_PASSWORD }}" >> "$GITHUB_ENV" | ||||||
|           echo "C:\Program Files (x86)\Windows Kits\10\App Certification Kit" >> $GITHUB_PATH |           echo "C:\Program Files (x86)\Windows Kits\10\App Certification Kit" >> $GITHUB_PATH | ||||||
|           echo "C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools" >> $GITHUB_PATH |           echo "C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools" >> $GITHUB_PATH | ||||||
| @ -181,7 +182,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|  |  | ||||||
|       - name: Setup certicate with SSM KSP (Windows only) |       - name: Setup certicate with SSM KSP (Windows only) | ||||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} |         if: ${{ (env.IS_RELEASE == 'true' || env.IS_STAGING == 'true') && matrix.platform == 'windows' }} | ||||||
|         run: | |         run: | | ||||||
|           curl -X GET  https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download -H "x-api-key:%SM_API_KEY%" -o smtools-windows-x64.msi |           curl -X GET  https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download -H "x-api-key:%SM_API_KEY%" -o smtools-windows-x64.msi | ||||||
|           msiexec /i smtools-windows-x64.msi /quiet /qn |           msiexec /i smtools-windows-x64.msi /quiet /qn | ||||||
| @ -191,7 +192,7 @@ jobs: | |||||||
|           smksp_cert_sync.exe |           smksp_cert_sync.exe | ||||||
|           smctl windows certsync |           smctl windows certsync | ||||||
|         # This last line `smctl windows certsync` was added after windows codesign failures started happening |         # This last line `smctl windows certsync` was added after windows codesign failures started happening | ||||||
|         # with nightly-v25.4.10. It looks like `smksp_cert_sync.exe` used to do the sync to the local cert store, |         # with staging-v25.4.10. It looks like `smksp_cert_sync.exe` used to do the sync to the local cert store, | ||||||
|         # but stopped doing it overnight. This extra call that I randomly got from this azure-related doc page |         # but stopped doing it overnight. This extra call that I randomly got from this azure-related doc page | ||||||
|         # https://docs.digicert.com/en/digicert-keylocker/code-signing/sign-with-third-party-signing-tools/windows-applications/sign-azure-apps-with-signtool-using-ksp-library.html#sync-certificates--windows-only--618365 |         # https://docs.digicert.com/en/digicert-keylocker/code-signing/sign-with-third-party-signing-tools/windows-applications/sign-azure-apps-with-signtool-using-ksp-library.html#sync-certificates--windows-only--618365 | ||||||
|         # seems to be doing that extra sync that we need for scripts/sign-win.js to work. |         # seems to be doing that extra sync that we need for scripts/sign-win.js to work. | ||||||
| @ -199,13 +200,13 @@ jobs: | |||||||
|         shell: cmd |         shell: cmd | ||||||
|  |  | ||||||
|       - name: Build the app (debug) |       - name: Build the app (debug) | ||||||
|         if: ${{ env.IS_RELEASE == 'false' && env.IS_NIGHTLY == 'false' }} |         if: ${{ env.IS_RELEASE == 'false' && env.IS_STAGING == 'false' }} | ||||||
|         # electron-builder doesn't have a concept of release vs debug, |         # electron-builder doesn't have a concept of release vs debug, | ||||||
|         # this is just not doing any codesign or release yml generation, and points to dev infra |         # this is just not doing any codesign or release yml generation, and points to dev infra | ||||||
|         run: npm run tronb:package:dev |         run: npm run tronb:package:dev | ||||||
|  |  | ||||||
|       - name: Build the app (release) |       - name: Build the app (release) | ||||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' || env.IS_STAGING == 'true' }} | ||||||
|         env: |         env: | ||||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} |           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||||
| @ -215,7 +216,7 @@ jobs: | |||||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} |           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} |           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} |           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||||
|         run: npm run tronb:package:prod |         run: npm run tronb:package:${{ env.IS_STAGING == 'true' && 'dev' || 'prod' }} | ||||||
|  |  | ||||||
|       - name: List artifacts in out/ |       - name: List artifacts in out/ | ||||||
|         run: ls -R out |         run: ls -R out | ||||||
| @ -239,20 +240,20 @@ jobs: | |||||||
|             out/*-x86_64-linux.* |             out/*-x86_64-linux.* | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' || env.IS_STAGING == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: out-yml-${{ matrix.platform }} |           name: out-yml-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
|             out/latest*.yml |             out/latest*.yml | ||||||
|  |  | ||||||
|       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back |       # TODO: add the 'Build for Mac TestFlight' stage back | ||||||
|  |  | ||||||
|  |  | ||||||
|   upload-apps-release: |   upload-apps-release: | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     # Equivalent to IS_RELEASE || IS_NIGHTLY (but we can't access those env vars here) |     # Equivalent to IS_RELEASE || IS_STAGING (but we can't access those env vars here) | ||||||
|     if: ${{ (github.ref_type == 'tag' && startsWith(github.ref_name, 'v')) || (github.event_name == 'push' && github.ref == 'refs/heads/main') }} |     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 }} | ||||||
| @ -263,32 +264,32 @@ jobs: | |||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-win |           name: out-arm64-windows | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-win |           name: out-x64-windows | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-yml-win |           name: out-yml-windows | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-mac |           name: out-arm64-macos | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-mac |           name: out-x64-macos | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-yml-mac |           name: out-yml-macos | ||||||
|           path: out |           path: out | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
| @ -310,8 +311,8 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           NOTES: ${{ needs.prepare-files.outputs.notes }} |           NOTES: ${{ needs.prepare-files.outputs.notes }} | ||||||
|           PUB_DATE: ${{ github.event.repository.updated_at }} |           PUB_DATE: ${{ github.event.repository.updated_at }} | ||||||
|           WEBSITE_DIR: ${{ env.IS_NIGHTLY == 'true' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} |           WEBSITE_DIR: ${{ env.IS_STAGING == 'true' && 'dl.zoo.dev/releases/modeling-app/staging' || 'dl.zoo.dev/releases/modeling-app' }} | ||||||
|           URL_CODED_NAME: ${{ env.IS_NIGHTLY == 'true' && 'Zoo%20Design%20Studio%20%28Nightly%29' || 'Zoo%20Design%20Studio' }} |           URL_CODED_NAME: ${{ env.IS_STAGING == 'true' && 'Zoo%20Design%20Studio%20%28Staging%29' || 'Zoo%20Design%20Studio' }} | ||||||
|         run: | |         run: | | ||||||
|           RELEASE_DIR=https://${WEBSITE_DIR} |           RELEASE_DIR=https://${WEBSITE_DIR} | ||||||
|           jq --null-input \ |           jq --null-input \ | ||||||
| @ -360,26 +361,26 @@ jobs: | |||||||
|         run: "ls -R out" |         run: "ls -R out" | ||||||
|  |  | ||||||
|       - name: Authenticate to Google Cloud |       - name: Authenticate to Google Cloud | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_STAGING == 'true' }} | ||||||
|         uses: 'google-github-actions/auth@v2.1.8' |         uses: 'google-github-actions/auth@v2.1.10' | ||||||
|         with: |         with: | ||||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' |           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||||
|  |  | ||||||
|       - name: Set up Google Cloud SDK |       - name: Set up Google Cloud SDK | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_STAGING == 'true' }} | ||||||
|         uses: google-github-actions/setup-gcloud@v2.1.4 |         uses: google-github-actions/setup-gcloud@v2.1.4 | ||||||
|         with: |         with: | ||||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} |           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} | ||||||
|  |  | ||||||
|       - name: Upload nightly files to public bucket |       - name: Upload staging files to public bucket | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_STAGING == 'true' }} | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.2 |         uses: google-github-actions/upload-cloud-storage@v2.2.2 | ||||||
|         with: |         with: | ||||||
|           path: out |           path: out | ||||||
|           glob: '*' |           glob: '*' | ||||||
|           parent: false |           parent: false | ||||||
|           destination: 'dl.kittycad.io/releases/modeling-app/nightly' |           destination: 'dl.kittycad.io/releases/modeling-app/staging' | ||||||
|  |  | ||||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files |       - name: Invalidate bucket cache on latest*.yml and last_download.json files | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: ${{ env.IS_STAGING == 'true' }} | ||||||
|         run: npm run files:invalidate-bucket:nightly |         run: npm run files:invalidate-bucket:staging | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								.github/workflows/cargo-fmt.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/cargo-fmt.yml
									
									
									
									
										vendored
									
									
								
							| @ -31,15 +31,15 @@ jobs: | |||||||
|       - name: Use correct Rust toolchain |       - name: Use correct Rust toolchain | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           [ -e rust-toolchain.toml ] || cp rust/rust-toolchain.toml ./ |           cp .github/workflows/nightly-rust-toolchain.toml 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-workspaces: rust |           cache-workspaces: rust | ||||||
|           components: rustfmt |           components: rustfmt | ||||||
|  |  | ||||||
|       - name: Run cargo fmt |       - name: Run nightly cargo fmt | ||||||
|         run: | |         run: | | ||||||
|           cd rust |           cd rust | ||||||
|           cargo fmt -- --check |           cargo +nightly fmt -- --check | ||||||
|         shell: bash |         shell: bash | ||||||
|  | |||||||
							
								
								
									
										35
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										35
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -95,7 +95,8 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|         run: npm run build:wasm |         run: npm run build:wasm | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - name: Upload compiled wasm artifacts | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: prepared-wasm |           name: prepared-wasm | ||||||
|           path: | |           path: | | ||||||
| @ -176,17 +177,18 @@ jobs: | |||||||
|           CI_SUITE: e2e:snapshots |           CI_SUITE: e2e:snapshots | ||||||
|           TARGET: web |           TARGET: web | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - name: Upload playwright report | ||||||
|         if: ${{ !cancelled() && (success() || failure()) }} |         uses: actions/upload-artifact@v4 | ||||||
|  |         if: ${{ !cancelled() }} | ||||||
|         with: |         with: | ||||||
|           name: playwright-report-ubuntu-snapshot-${{ github.sha }} |           name: playwright-report-snapshot-${{ github.sha }} | ||||||
|           path: playwright-report/ |           path: playwright-report/ | ||||||
|           include-hidden-files: true |           include-hidden-files: true | ||||||
|           retention-days: 30 |           retention-days: 30 | ||||||
|           overwrite: true |           overwrite: true | ||||||
|  |  | ||||||
|       - name: Check diff |       - name: Check diff | ||||||
|         if: ${{ github.ref != 'refs/heads/main' }} |         if: ${{ always() && github.ref != 'refs/heads/main' }} | ||||||
|         shell: bash |         shell: bash | ||||||
|         id: git-check |         id: git-check | ||||||
|         run: | |         run: | | ||||||
| @ -197,7 +199,7 @@ jobs: | |||||||
|             fi |             fi | ||||||
|  |  | ||||||
|       - name: Commit changes |       - name: Commit changes | ||||||
|         if: ${{ steps.git-check.outputs.modified == 'true' }} |         if: ${{ always() && 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 | ||||||
| @ -220,7 +222,7 @@ jobs: | |||||||
|         include: |         include: | ||||||
|           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" |           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" | ||||||
|           - os: namespace-profile-macos-8-cores |           - os: namespace-profile-macos-8-cores | ||||||
|           - os: windows-latest-8-cores |           - os: namespace-profile-windows-8-cores | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     name: e2e:web (${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}) |     name: e2e:web (${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}) | ||||||
|     env: |     env: | ||||||
| @ -290,9 +292,11 @@ jobs: | |||||||
|           CI_SUITE: e2e:web |           CI_SUITE: e2e:web | ||||||
|           TARGET: web |           TARGET: web | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - name: Upload playwright report | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ !cancelled() && (success() || failure()) }} |         if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|         with: |         with: | ||||||
|  |           name: playwright-report-web-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: playwright-report/ |           path: playwright-report/ | ||||||
|           include-hidden-files: true |           include-hidden-files: true | ||||||
|           retention-days: 30 |           retention-days: 30 | ||||||
| @ -304,7 +308,6 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         # TODO: enable namespace-profile-windows-latest once available |  | ||||||
|         include: |         include: | ||||||
|           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" |           - os: "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" | ||||||
|             shardIndex: 1 |             shardIndex: 1 | ||||||
| @ -336,10 +339,10 @@ jobs: | |||||||
|           - os: namespace-profile-macos-8-cores |           - os: namespace-profile-macos-8-cores | ||||||
|             shardIndex: 2 |             shardIndex: 2 | ||||||
|             shardTotal: 2 |             shardTotal: 2 | ||||||
|           - os: windows-latest-8-cores |           - os: namespace-profile-windows-8-cores | ||||||
|             shardIndex: 1 |             shardIndex: 1 | ||||||
|             shardTotal: 2 |             shardTotal: 2 | ||||||
|           - os: windows-latest-8-cores |           - os: namespace-profile-windows-8-cores | ||||||
|             shardIndex: 2 |             shardIndex: 2 | ||||||
|             shardTotal: 2 |             shardTotal: 2 | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
| @ -415,19 +418,21 @@ jobs: | |||||||
|           CI_SUITE: e2e:desktop |           CI_SUITE: e2e:desktop | ||||||
|           TARGET: desktop |           TARGET: desktop | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - name: Upload test report | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|         if: always() |         if: always() | ||||||
|         with: |         with: | ||||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} |           name: test-results-desktop-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: test-results/ |           path: test-results/ | ||||||
|           include-hidden-files: true |           include-hidden-files: true | ||||||
|           retention-days: 30 |           retention-days: 30 | ||||||
|           overwrite: true |           overwrite: true | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v4 |       - name: Upload playwright report | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|         if: always() |         if: always() | ||||||
|         with: |         with: | ||||||
|           name: playwright-report-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} |           name: playwright-report-desktop-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|           path: playwright-report/ |           path: playwright-report/ | ||||||
|           include-hidden-files: true |           include-hidden-files: true | ||||||
|           retention-days: 30 |           retention-days: 30 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							| @ -328,7 +328,7 @@ jobs: | |||||||
|           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.10" | ||||||
|         with: |         with: | ||||||
|           credentials_json: "${{ secrets.GOOGLE_CLOUD_DL_SA }}" |           credentials_json: "${{ secrets.GOOGLE_CLOUD_DL_SA }}" | ||||||
|       - name: Set up Cloud SDK |       - name: Set up Cloud SDK | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								.github/workflows/nightly-rust-toolchain.toml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/nightly-rust-toolchain.toml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | |||||||
|  | [toolchain] | ||||||
|  | channel = "nightly" | ||||||
|  | components = ["rustfmt"] | ||||||
							
								
								
									
										14
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							| @ -31,42 +31,42 @@ jobs: | |||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-win |           name: out-arm64-windows | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|            |            | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-win |           name: out-x64-windows | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-yml-win |           name: out-yml-windows | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-mac |           name: out-arm64-macos | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-mac |           name: out-x64-macos | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-yml-mac |           name: out-yml-macos | ||||||
|           path: out |           path: out | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
| @ -108,7 +108,7 @@ jobs: | |||||||
|         run: npm run files:set-notes |         run: npm run files:set-notes | ||||||
|  |  | ||||||
|       - 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.10' | ||||||
|         with: |         with: | ||||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' |           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||||
|  |  | ||||||
|  | |||||||
| @ -251,7 +251,8 @@ Before you submit a contribution PR to this repo, please ensure that: | |||||||
|  |  | ||||||
| #### 1. Create a 'Cut release $VERSION' issue | #### 1. Create a 'Cut release $VERSION' issue | ||||||
|  |  | ||||||
| It will be used to document changelog discussions and release testing. | Use the **Release** issue template. | ||||||
|  | This will be used to facilitate changelog discussions and release testing. | ||||||
|  |  | ||||||
| https://github.com/KittyCAD/modeling-app/issues/new | https://github.com/KittyCAD/modeling-app/issues/new | ||||||
|  |  | ||||||
| @ -270,33 +271,18 @@ The workflow should be listed right away [in this list](https://github.com/Kitty | |||||||
|  |  | ||||||
| #### 3. Manually test artifacts | #### 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). | 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. | Assign someone to each section of the manual checklist generated by the issue template. | ||||||
|  |  | ||||||
| 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 | #### 4. Bump the KCL version | ||||||
|  |  | ||||||
| Follow the instructions [here](./rust/README.md) to publish new crates. | 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. | This ensures that the KCL accepted by the app is also accepted by the CLI. | ||||||
|  |  | ||||||
|  | If there are documentation changes, merge the corresponding Dependabot PRs [here](https://github.com/KittyCAD/website/pulls/app%2Fdependabot) for the website. | ||||||
|  | You can trigger Dependabot to check for updates [here](https://github.com/KittyCAD/website/network/updates/17261214/jobs). | ||||||
|  |  | ||||||
| #### 5. Publish the release | #### 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. | 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. | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								Makefile
									
									
									
									
									
								
							| @ -62,7 +62,10 @@ else | |||||||
| endif | endif | ||||||
|  |  | ||||||
| public/kcl-samples/manifest.json: $(KCL_SOURCES) | public/kcl-samples/manifest.json: $(KCL_SOURCES) | ||||||
|  | ifndef WINDOWS | ||||||
| 	cd rust/kcl-lib && EXPECTORATE=overwrite cargo test generate_manifest | 	cd rust/kcl-lib && EXPECTORATE=overwrite cargo test generate_manifest | ||||||
|  | 	@ touch $@ | ||||||
|  | endif | ||||||
|  |  | ||||||
| .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 | ||||||
|  | |||||||
| Before Width: | Height: | Size: 119 KiB After Width: | Height: | Size: 119 KiB | 
| Before Width: | Height: | Size: 259 KiB After Width: | Height: | Size: 259 KiB | 
| @ -46,3 +46,7 @@ KCL has no support for area, volume, or other higher dimension units. When inter | |||||||
| ## Explicit conversions | ## Explicit conversions | ||||||
|  |  | ||||||
| You might sometimes need to convert from one unit to another for some calculation. You can do this implicitly when calling a function (see above), but if you can't or don't want to, then you can use the explicit conversion functions in the [`std::units`](/docs/kcl-std/modules/std-units) module. | You might sometimes need to convert from one unit to another for some calculation. You can do this implicitly when calling a function (see above), but if you can't or don't want to, then you can use the explicit conversion functions in the [`std::units`](/docs/kcl-std/modules/std-units) module. | ||||||
|  |  | ||||||
|  | KCL cannot know about changes to units caused by arithmetic. For example, you may intend for `10in * 25.4` to be the value `254mm` (i.e., `10in` in mm), however, the result of that computation in KCL is `254in`. It is always better to rely on automatic conversion or to use the explicit conversion functions, where possible. | ||||||
|  |  | ||||||
|  | Converting between degrees and radians using π ([`PI`](/docs/kcl-std/consts/std-math-PI) in KCL) is especially prone to this error and so the `PI` constant always requires specifying units of any computation it is used with. E.g., `radius = (circumference / (2 * PI)): number(mm)`. | ||||||
|  | |||||||
| @ -4,8 +4,6 @@ excerpt: "Project specific settings for the app. These live in `project.toml` in | |||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
| # Project Settings |  | ||||||
|  |  | ||||||
| Project specific settings for the app. These live in `project.toml` in the base of the project directory. Updating the settings for the project in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | Project specific settings for the app. These live in `project.toml` in the base of the project directory. Updating the settings for the project in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | ||||||
|  |  | ||||||
| ## Project Configuration Structure | ## Project Configuration Structure | ||||||
| @ -184,4 +182,4 @@ color = 240.0 | |||||||
| # Use inches as the default measurement unit | # Use inches as the default measurement unit | ||||||
| base_unit = "in" | base_unit = "in" | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  | |||||||
| @ -4,8 +4,6 @@ excerpt: "User specific settings for the app. These live in `user.toml` in the a | |||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
| # User Settings |  | ||||||
|  |  | ||||||
| User specific settings for the app. These live in `user.toml` in the app's configuration directory. Updating the settings in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | User specific settings for the app. These live in `user.toml` in the app's configuration directory. Updating the settings in the app will update this file automatically. Do not edit this file manually, as it may be overwritten by the app. Manual edits can cause corruption of the settings file. | ||||||
|  |  | ||||||
| ## User Configuration Structure | ## User Configuration Structure | ||||||
| @ -85,6 +83,13 @@ Allow orbiting in sketch mode. | |||||||
| Whether to show the debug panel, which lets you see various states of the app to aid in development. | Whether to show the debug panel, which lets you see various states of the app to aid in development. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | **Default:** None | ||||||
|  |  | ||||||
|  | ##### fixed_size_grid | ||||||
|  |  | ||||||
|  | If true, the grid cells will be fixed-size, where the width is your default length unit. If false, the grid will get larger as you zoom out, and smaller as you zoom in. | ||||||
|  |  | ||||||
|  |  | ||||||
| **Default:** None | **Default:** None | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -234,4 +239,4 @@ base_unit = "mm" | |||||||
| # Disable text wrapping in the editor | # Disable text wrapping in the editor | ||||||
| text_wrapping = false | text_wrapping = false | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  | |||||||
| @ -44,7 +44,7 @@ detail on importing geometry. | |||||||
|  |  | ||||||
| Tags are used to give a name (tag) to a specific path. | Tags are used to give a name (tag) to a specific path. | ||||||
|  |  | ||||||
| ### `TagDeclarator` | ### Tag declarations - `TagDecl` | ||||||
|  |  | ||||||
| The syntax for declaring a tag is `$myTag` you would use it in the following | The syntax for declaring a tag is `$myTag` you would use it in the following | ||||||
| way: | way: | ||||||
| @ -67,24 +67,28 @@ startSketchOn(XZ) | |||||||
|   |> close() |   |> close() | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### `TagIdentifier` | When a function requires declaring a new tag (using the `$` syntax), the argument has type [`TagDecl`](/docs/kcl-std/types/std-types-TagDecl). | ||||||
|  |  | ||||||
| As per the example above you can use the tag identifier to get a reference to the  | ### Tag identifiers | ||||||
| tagged object. The syntax for this is `myTag`. |  | ||||||
|  |  | ||||||
| In the example above we use the tag identifier to get the angle of the segment | A tag created using a tag declarator can be used by writing its name without the `$`, e.g., `myTag`. | ||||||
| `segAng(rectangleSegmentA001)`. | Where necessary to disambiguate from tag declarations, we call these tag identifiers. | ||||||
|  |  | ||||||
| ### `Start` | In the example above we use the tag identifier `rectangleSegmentA001` to get the angle of the segment | ||||||
|  | using `segAng(rectangleSegmentA001)`. | ||||||
|  |  | ||||||
| There is a special tag, `START` (with type `Start`, although under the cover, it's a string) | Tags can identify either an edge or face of a solid, or a line or other edge of a sketch. Functions | ||||||
| for identifying the face of a solid which was the start of an extrusion (i.e., the surface which | which take a tag identifier as an argument will use either [`TaggedEdge`](/docs/kcl-std/types/std-types-TaggedEdge) (for the edge of a | ||||||
| is extruded). | solid or sketch) or [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace). | ||||||
|  |  | ||||||
| ### `End` | If a line in a sketch is tagged and then the sketch is extruded, the tag is a `TaggedEdge` before | ||||||
|  | extrusion and a `TaggedFace` after extrusion. | ||||||
|  |  | ||||||
|  | #### `START` and `END` | ||||||
|  |  | ||||||
|  | [`START`](/docs/kcl-std/consts/std-START) and [`END`](/docs/kcl-std/consts/std-END) are special tags | ||||||
|  | for identifying the starting and ending faces of an extruded solid. | ||||||
|  |  | ||||||
| There is a special tag, `END` (with type `End`, although under the cover, it's a string) |  | ||||||
| for identifying the face of a solid which was finishes an extrusion. |  | ||||||
|  |  | ||||||
| ### Tag Scope | ### Tag Scope | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "KCL Constants" |  | ||||||
| excerpt: "Documentation for the KCL constants." |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| ## Table of Contents |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### `std` |  | ||||||
|  |  | ||||||
| - [`END`](/docs/kcl/consts/std-END) |  | ||||||
| - [`START`](/docs/kcl/consts/std-START) |  | ||||||
| - [`X`](/docs/kcl/consts/std-X) |  | ||||||
| - [`XY`](/docs/kcl/consts/std-XY) |  | ||||||
| - [`XZ`](/docs/kcl/consts/std-XZ) |  | ||||||
| - [`Y`](/docs/kcl/consts/std-Y) |  | ||||||
| - [`YZ`](/docs/kcl/consts/std-YZ) |  | ||||||
| - [`Z`](/docs/kcl/consts/std-Z) |  | ||||||
|  |  | ||||||
| ### `std::math` |  | ||||||
|  |  | ||||||
| - [`E`](/docs/kcl/consts/std-math-E) |  | ||||||
| - [`PI`](/docs/kcl/consts/std-math-PI) |  | ||||||
| - [`TAU`](/docs/kcl/consts/std-math-TAU) |  | ||||||
|  |  | ||||||
| ### `std::turns` |  | ||||||
|  |  | ||||||
| - [`HALF_TURN`](/docs/kcl/consts/std-turns-HALF_TURN) |  | ||||||
| - [`QUARTER_TURN`](/docs/kcl/consts/std-turns-QUARTER_TURN) |  | ||||||
| - [`THREE_QUARTER_TURN`](/docs/kcl/consts/std-turns-THREE_QUARTER_TURN) |  | ||||||
| - [`ZERO`](/docs/kcl/consts/std-turns-ZERO) |  | ||||||
|  |  | ||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| Identifies the ending face of an extrusion. I.e., the new face created by an extrusion. | Identifies the ending face of an extrusion. I.e., the new face created by an extrusion. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| END: string = 'end' | END: TaggedFace | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace) - A tag which references a face of a solid, including the distinguished tags `START` and `END`. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| Identifies the starting face of an extrusion. I.e., the face which is extruded. | Identifies the starting face of an extrusion. I.e., the face which is extruded. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| START: string = 'start' | START: TaggedFace | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`TaggedFace`](/docs/kcl-std/types/std-types-TaggedFace) - A tag which references a face of a solid, including the distinguished tags `START` and `END`. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| The X-axis (can be used in both 2d and 3d contexts). | The X-axis (can be used in both 2d and 3d contexts). | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| X | X: Axis3d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| An abstract 3d plane aligned with the X and Y axes. Its normal is the positive Z axis. | An abstract 3d plane aligned with the X and Y axes. Its normal is the positive Z axis. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| XY | XY: Plane | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| An abstract 3d plane aligned with the X and Z axes. Its normal is the negative Y axis. | An abstract 3d plane aligned with the X and Z axes. Its normal is the negative Y axis. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| XZ | XZ: Plane | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| The Y-axis (can be used in both 2d and 3d contexts). | The Y-axis (can be used in both 2d and 3d contexts). | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| Y | Y: Axis3d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| An abstract 3d plane aligned with the Y and Z axes. Its normal is the positive X axis. | An abstract 3d plane aligned with the Y and Z axes. Its normal is the positive X axis. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| YZ | YZ: Plane | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Plane`](/docs/kcl-std/types/std-types-Plane) - An abstract plane. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| The 3D Z-axis. | The 3D Z-axis. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| Z | Z: Axis3d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`Axis3d`](/docs/kcl-std/types/std-types-Axis3d) - An abstract and infinite line in 3d space. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -13,4 +13,8 @@ sweep::SKETCH_PLANE: string = 'sketchPlane' | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`string`](/docs/kcl-std/types/std-types-string) - A sequence of characters | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -13,4 +13,8 @@ sweep::TRAJECTORY: string = 'trajectoryCurve' | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`string`](/docs/kcl-std/types/std-types-string) - A sequence of characters | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -13,4 +13,8 @@ turns::HALF_TURN: number(deg) = 180deg | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -13,4 +13,8 @@ turns::QUARTER_TURN: number(deg) = 90deg | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -13,4 +13,8 @@ turns::THREE_QUARTER_TURN: number(deg) = 270deg | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`number(deg)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -8,9 +8,13 @@ layout: manual | |||||||
| No turn, zero degrees/radians. | No turn, zero degrees/radians. | ||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| turns::ZERO: number = 0 | turns::ZERO: number(Angle) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Type | ||||||
|  |  | ||||||
|  | [`number(Angle)`](/docs/kcl-std/types/std-types-number) - A number. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -41,8 +41,19 @@ assert( | |||||||
| ```kcl | ```kcl | ||||||
| n = 10 | n = 10 | ||||||
| assert(n, isEqualTo = 10) | assert(n, isEqualTo = 10) | ||||||
| assert(n, isGreaterThanOrEqual = 0, isLessThan = 100, error = "number should be between 0 and 100") | assert( | ||||||
| assert(1.0000000000012, isEqualTo = 1, tolerance = 0.0001, error = "number should be almost exactly 1") |   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", | ||||||
|  | ) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ assertIs( | |||||||
| ```kcl | ```kcl | ||||||
| kclIsFun = true | kclIsFun = true | ||||||
| assertIs(kclIsFun) | assertIs(kclIsFun) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -29,14 +29,12 @@ Consider using `atan2()` instead for the true inverse of tangent. | |||||||
| ```kcl | ```kcl | ||||||
| sketch001 = startSketchOn(XZ) | sketch001 = startSketchOn(XZ) | ||||||
|   |> startProfile(at = [0, 0]) |   |> startProfile(at = [0, 0]) | ||||||
|   |> angledLine( |   |> angledLine(angle = atan(1.25), length = 20) | ||||||
|     angle = atan(1.25), |  | ||||||
|     length = 20, |  | ||||||
|   ) |  | ||||||
|   |> yLine(endAbsolute = 0) |   |> yLine(endAbsolute = 0) | ||||||
|   |> close() |   |> close() | ||||||
|  |  | ||||||
| extrude001 = extrude(sketch001, length = 5) | extrude001 = extrude(sketch001, length = 5) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -32,6 +32,7 @@ legAngX( | |||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| legAngX(hypotenuse = 5, leg = 3) | legAngX(hypotenuse = 5, leg = 3) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -32,6 +32,7 @@ legAngY( | |||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| legAngY(hypotenuse = 5, leg = 3) | legAngY(hypotenuse = 5, leg = 3) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -32,6 +32,7 @@ legLen( | |||||||
|  |  | ||||||
| ```kcl | ```kcl | ||||||
| legLen(hypotenuse = 5, leg = 3) | legLen(hypotenuse = 5, leg = 3) | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	![github-actions[bot]](/assets/img/avatar_default.png)