Compare commits
	
		
			127 Commits
		
	
	
		
			jtran/fix-
			...
			nightly-v2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 157b76cc78 | |||
| cf957d880e | |||
| dfc3d19677 | |||
| dd370a9365 | |||
| 2274d6459c | |||
| 32ce857119 | |||
| 88b51da417 | |||
| 30d365aeb3 | |||
| 7af62399ac | |||
| 441d957228 | |||
| 9e57034873 | |||
| eb96d6539c | |||
| 513c76ecc8 | |||
| 51d9449280 | |||
| 6366bc4766 | |||
| 7a21918223 | |||
| 8072f1db63 | |||
| 18e1855fa9 | |||
| 7be53c7d4a | |||
| 2bf20988ef | |||
| 1495cc6d18 | |||
| f876e6ca3c | |||
| 60a0c811ab | |||
| cab0c1e6a1 | |||
| 417d720b22 | |||
| 77293952c0 | |||
| ea3d604b73 | |||
| 023a659491 | |||
| dd3a2b14f9 | |||
| 424b409cc1 | |||
| 82a58e69c2 | |||
| 776b420031 | |||
| 1087d4223b | |||
| 089d6df889 | |||
| efb067af58 | |||
| 2aa27eab01 | |||
| 9c47ac5b57 | |||
| 5ae1aecd74 | |||
| 68ae7e98f9 | |||
| 56771d561a | |||
| f09411817c | |||
| bed7ae3b8b | |||
| c43510732c | |||
| 51f0b669a4 | |||
| 3cbedcd3e7 | |||
| 5d2fa43150 | |||
| ec49b0752e | |||
| 3b171fb881 | |||
| 0548409da0 | |||
| dd052b35fd | |||
| 46be4e7eef | |||
| 412d1b7a99 | |||
| cfdd22af74 | |||
| 68a11e7aa5 | |||
| 3139e18dc7 | |||
| d461b09a4d | |||
| 9c42c39ba9 | |||
| aa3f40e22c | |||
| 4423ae16dc | |||
| 1d45bed649 | |||
| 64aac7bccc | |||
| 002edeaf19 | |||
| 5424252dac | |||
| 30bc85add8 | |||
| 39a2bd685b | |||
| 23a3e330f6 | |||
| 99dd8b87dc | |||
| 5ff1d9e268 | |||
| ce1a37e0bc | |||
| ac605c2434 | |||
| f6ecdfcb02 | |||
| 28815eb2f1 | |||
| 166fa71f7e | |||
| 00c45114ba | |||
| 6cfefd8611 | |||
| 4fe17fe3ab | |||
| 66f6b741c4 | |||
| f760a77b14 | |||
| 7b36a5d1ee | |||
| b415349af6 | |||
| 6f169ab297 | |||
| 2529066f38 | |||
| 79dc537900 | |||
| 77bae6983d | |||
| 56ef859bb3 | |||
| 455fb49fb6 | |||
| 676ac201bb | |||
| 0092922565 | |||
| d6b26ff718 | |||
| fcb0a6d9ca | |||
| 59e0df7879 | |||
| c17cb1067f | |||
| 6fb493f209 | |||
| 30afa65ccf | |||
| a2f9e70d18 | |||
| 986675fe89 | |||
| d8ce5ad8bd | |||
| 1a9926be8a | |||
| 54b5774f9e | |||
| 66bbbf81e2 | |||
| 652519aeae | |||
| f826afb32d | |||
| f71fafdece | |||
| 16b7544d69 | |||
| 34f019305b | |||
| 79e06b3a00 | |||
| 24bc4fcd8c | |||
| 97b9529c81 | |||
| 8e5fc02941 | |||
| 909690f3c7 | |||
| 14ba66378d | |||
| b2e895e508 | |||
| 05f4f34269 | |||
| fbb7b08b62 | |||
| 16c7a2457a | |||
| c429bc6ed7 | |||
| a0493cb332 | |||
| b798f7da03 | |||
| c5d051855f | |||
| 0b24216dc5 | |||
| 2d3841bf61 | |||
| 51a71a180e | |||
| 1ec25dfe96 | |||
| 8de29dd461 | |||
| b11040c23c | |||
| 2bc4f076cb | |||
| 9e1cf90c81 | 
| @ -1,21 +1,20 @@ | |||||||
| name: build-publish-apps | name: build-apps | ||||||
| 
 | 
 | ||||||
| on: | on: | ||||||
|   pull_request: |   pull_request: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|   release: |     tags: | ||||||
|     types: [published] |       - 'v[0-9]+.[0-9]+.[0-9]+' | ||||||
|   schedule: |   schedule: | ||||||
|     - cron: '0 4 * * *' |     - cron: '0 4 * * *' | ||||||
|   # Daily at 04:00 AM UTC |   # Daily at 04:00 AM UTC | ||||||
|   # Will checkout the last commit from the default branch (main as of 2023-10-04) |   # Will checkout the last commit from the default branch (main as of 2023-10-04) | ||||||
| 
 | 
 | ||||||
| env: | env: | ||||||
|   CUT_RELEASE_PR: ${{ github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} |   IS_RELEASE: ${{ github.ref_type == 'tag' }} | ||||||
|   BUILD_RELEASE: ${{ github.event_name == 'release' || github.event_name == 'schedule' || github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} |   IS_NIGHTLY: ${{ github.event_name == 'schedule' }} | ||||||
|   NOTES: ${{ github.event_name == 'release' && github.event.release.body || format('Non-release build, commit {0}', github.sha) }} |  | ||||||
| 
 | 
 | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
| @ -26,6 +25,7 @@ jobs: | |||||||
|     runs-on: ubuntu-22.04  # seperate job on Ubuntu for easy string manipulations (compared to Windows) |     runs-on: ubuntu-22.04  # seperate job on Ubuntu for easy string manipulations (compared to Windows) | ||||||
|     outputs: |     outputs: | ||||||
|       version: ${{ steps.export_version.outputs.version }} |       version: ${{ steps.export_version.outputs.version }} | ||||||
|  |       notes: ${{ steps.export_notes.outputs.notes }} | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
| @ -47,48 +47,40 @@ jobs: | |||||||
|       - name: Run build:wasm |       - name: Run build:wasm | ||||||
|         run: "yarn build:wasm" |         run: "yarn build:wasm" | ||||||
| 
 | 
 | ||||||
|       - name: Set nightly version |       - name: Set nightly version, product name, release notes, and icons | ||||||
|         if: github.event_name == 'schedule' |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|  |         run: yarn files:flip-to-nightly | ||||||
|  | 
 | ||||||
|  |       - name: Set release version | ||||||
|  |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           VERSION=$(date +'%-y.%-m.%-d') yarn bump-jsons |           export VERSION=${GITHUB_REF_NAME#v} | ||||||
|  |           yarn files:set-version | ||||||
| 
 | 
 | ||||||
|       # TODO: see if we need to inject updater nightly URL here https://dl.zoo.dev/releases/modeling-app/nightly/last_update.json |       - uses: actions/upload-artifact@v4 | ||||||
| 
 |  | ||||||
|       - name: Generate release notes |  | ||||||
|         run: | |  | ||||||
|           echo "$NOTES" > release-notes.md |  | ||||||
|           cat release-notes.md |  | ||||||
| 
 |  | ||||||
|       - uses: actions/upload-artifact@v3 |  | ||||||
|         with: |         with: | ||||||
|           name: prepared-files |           name: prepared-files | ||||||
|           path: | |           path: | | ||||||
|             package.json |             package.json | ||||||
|  |             electron-builder.yml | ||||||
|             src/wasm-lib/pkg/wasm_lib* |             src/wasm-lib/pkg/wasm_lib* | ||||||
|             release-notes.md |             release-notes.md | ||||||
|  |             assets/icon.ico | ||||||
|  |             assets/icon.png | ||||||
| 
 | 
 | ||||||
|       - id: export_version |       - id: export_version | ||||||
|         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" |         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" | ||||||
| 
 | 
 | ||||||
|       - name: Prepare electron-builder.yml file for nightly |       - id: export_notes | ||||||
|         if: ${{ github.event_name == 'schedule' }} |         run: echo "notes=`cat release-notes.md`" >> "$GITHUB_OUTPUT" | ||||||
|         run: | |  | ||||||
|           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/nightly"' electron-builder.yml |  | ||||||
| 
 |  | ||||||
|       - uses: actions/upload-artifact@v3 |  | ||||||
|         if: ${{ github.event_name == 'schedule' }} |  | ||||||
|         with: |  | ||||||
|           name: prepared-files-nightly |  | ||||||
|           path: | |  | ||||||
|             electron-builder.yml |  | ||||||
| 
 | 
 | ||||||
|       - name: Prepare electron-builder.yml file for updater test |       - name: Prepare electron-builder.yml file for updater test | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test"' electron-builder.yml |           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test"' electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: prepared-files-updater-test |           name: prepared-files-updater-test | ||||||
|           path: | |           path: | | ||||||
| @ -109,32 +101,24 @@ jobs: | |||||||
|             platform: linux |             platform: linux | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     env: |     env: | ||||||
|       VERSION: ${{ github.event_name == 'schedule' && needs.prepare-files.outputs.version || format('v{0}', needs.prepare-files.outputs.version) }} |  | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         name: prepared-files |         name: prepared-files | ||||||
| 
 | 
 | ||||||
|       - name: Copy prepared files |       - name: Copy prepared files | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-files |           ls -R prepared-files | ||||||
|           cp prepared-files/package.json package.json |           cp prepared-files/package.json package.json | ||||||
|  |           cp prepared-files/electron-builder.yml electron-builder.yml | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib_bg.wasm public |           cp prepared-files/src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|           mkdir src/wasm-lib/pkg |           mkdir src/wasm-lib/pkg | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib* src/wasm-lib/pkg |           cp prepared-files/src/wasm-lib/pkg/wasm_lib* src/wasm-lib/pkg | ||||||
|           cp prepared-files/release-notes.md release-notes.md |           cp prepared-files/release-notes.md release-notes.md | ||||||
| 
 |           cp prepared-files/assets/icon.ico assets/icon.ico | ||||||
|       - uses: actions/download-artifact@v3 |           cp prepared-files/assets/icon.png assets/icon.png | ||||||
|         if: ${{ github.event_name == 'schedule' }} |  | ||||||
|         name: prepared-files-nightly |  | ||||||
| 
 |  | ||||||
|       - name: Copy updated electron-builder.yml file for nightly build |  | ||||||
|         if: ${{ github.event_name == 'schedule' }} |  | ||||||
|         run: | |  | ||||||
|           ls -R prepared-files-nightly |  | ||||||
|           cp prepared-files-nightly/electron-builder.yml electron-builder.yml |  | ||||||
| 
 | 
 | ||||||
|       - name: Sync node version and setup cache |       - name: Sync node version and setup cache | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
| @ -147,7 +131,7 @@ jobs: | |||||||
|       - run: yarn tronb:vite |       - run: yarn tronb:vite | ||||||
| 
 | 
 | ||||||
|       - name: Prepare certificate and variables (Windows only) |       - name: Prepare certificate and variables (Windows only) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} |         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} | ||||||
|         run: | |         run: | | ||||||
|           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 |           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 | ||||||
|           cat /d/Certificate_pkcs12.p12 |           cat /d/Certificate_pkcs12.p12 | ||||||
| @ -162,7 +146,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
| 
 | 
 | ||||||
|       - name: Setup certicate with SSM KSP (Windows only) |       - name: Setup certicate with SSM KSP (Windows only) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} |         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} | ||||||
|         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 | ||||||
| @ -173,13 +157,13 @@ jobs: | |||||||
|         shell: cmd |         shell: cmd | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (debug) |       - name: Build the app (debug) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'false' }} |         if: ${{ env.IS_RELEASE == 'false' && env.IS_NIGHTLY == '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 |         # this is just not doing any codesign or release yml generation | ||||||
|         run: yarn electron-builder --config |         run: yarn electron-builder --config | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (release) |       - name: Build the app (release) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} | ||||||
|         env: |         env: | ||||||
|           PUBLISH_FOR_PULL_REQUEST: true |           PUBLISH_FOR_PULL_REQUEST: true | ||||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} |           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
| @ -196,7 +180,7 @@ jobs: | |||||||
|       - name: List artifacts in out/ |       - name: List artifacts in out/ | ||||||
|         run: ls -R out |         run: ls -R out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-${{ matrix.platform }} |           name: out-arm64-${{ matrix.platform }} | ||||||
|           # first two will pick both Zoo Modeling App-$VERSION-arm64-win.exe and Zoo Modeling App-$VERSION-win.exe |           # first two will pick both Zoo Modeling App-$VERSION-arm64-win.exe and Zoo Modeling App-$VERSION-win.exe | ||||||
| @ -206,7 +190,7 @@ jobs: | |||||||
|             out/*-arm64-mac.* |             out/*-arm64-mac.* | ||||||
|             out/*-arm64-linux.* |             out/*-arm64-linux.* | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-${{ matrix.platform }} |           name: out-x64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -214,27 +198,29 @@ jobs: | |||||||
|             out/*-x64-mac.* |             out/*-x64-mac.* | ||||||
|             out/*-x86_64-linux.* |             out/*-x86_64-linux.* | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: out-yml |           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 (nightly)' stage back | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       # The steps below are for updater-test builds, only on release | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} | 
 | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         name: prepared-files-updater-test |         name: prepared-files-updater-test | ||||||
| 
 | 
 | ||||||
|       - name: Copy updated electron-builder.yml file for updater test |       - name: Copy updated electron-builder.yml file for updater test | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-files-updater-test |           ls -R prepared-files-updater-test | ||||||
|           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml |           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (updater-test) |       - name: Build the app (updater-test) | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         env: |         env: | ||||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} |           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||||
| @ -247,8 +233,8 @@ jobs: | |||||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} |           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||||
|         run: yarn electron-builder --config --publish always |         run: yarn electron-builder --config --publish always | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: updater-test-arm64-${{ matrix.platform }} |           name: updater-test-arm64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -256,8 +242,8 @@ jobs: | |||||||
|             out/*-arm64-mac.dmg |             out/*-arm64-mac.dmg | ||||||
|             out/*-arm64-linux.AppImage |             out/*-arm64-linux.AppImage | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |         if: ${{ env.IS_RELEASE == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: updater-test-x64-${{ matrix.platform }} |           name: updater-test-x64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -266,58 +252,69 @@ jobs: | |||||||
|             out/*-x86_64-linux.AppImage |             out/*-x86_64-linux.AppImage | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   publish-apps-release: |   upload-apps-release: | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     if: ${{ github.event_name == 'release' || github.event_name == 'schedule' }} |     if: ${{ github.ref_type == 'tag' || github.event_name == 'schedule' }} | ||||||
|     needs: [prepare-files, build-apps] |  | ||||||
|     env: |     env: | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|       VERSION: ${{ github.event_name == 'schedule' && needs.prepare-files.outputs.version || format('v{0}', needs.prepare-files.outputs.version) }} |       VERSION: ${{ format('v{0}', needs.prepare-files.outputs.version) }} | ||||||
|       PUB_DATE: ${{ github.event_name == 'release' && github.event.release.created_at || github.event.repository.updated_at }} |     needs: [prepare-files, build-apps] | ||||||
|       BUCKET_DIR: ${{ github.event_name == 'schedule' && 'dl.kittycad.io/releases/modeling-app/nightly' || 'dl.kittycad.io/releases/modeling-app' }} |  | ||||||
|       WEBSITE_DIR: ${{ github.event_name == 'schedule' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} |  | ||||||
|       URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-win |           name: out-arm64-win | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-win |           name: out-x64-win | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-yml-win | ||||||
|  |           path: out | ||||||
|  | 
 | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-mac |           name: out-arm64-mac | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-mac |           name: out-x64-mac | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-yml-mac | ||||||
|  |           path: out | ||||||
|  | 
 | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-linux |           name: out-arm64-linux | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-linux |           name: out-x64-linux | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: out-yml |           name: out-yml-linux | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - name: Generate the download static endpoint |       - name: Generate the download static endpoint | ||||||
|  |         env: | ||||||
|  |           NOTES: ${{ needs.prepare-files.outputs.notes }} | ||||||
|  |           PUB_DATE: ${{ github.event.repository.updated_at }} | ||||||
|  |           WEBSITE_DIR: ${{ github.event_name == 'schedule' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} | ||||||
|  |           URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} | ||||||
|         run: | |         run: | | ||||||
|           RELEASE_DIR=https://${WEBSITE_DIR} |           RELEASE_DIR=https://${WEBSITE_DIR} | ||||||
|           jq --null-input \ |           jq --null-input \ | ||||||
| @ -354,78 +351,56 @@ jobs: | |||||||
|                   "url": $linux_x64_url |                   "url": $linux_x64_url | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|             }' > last_download.json |             }' > out/last_download.json | ||||||
|             cat last_download.json |             cat out/last_download.json | ||||||
|  | 
 | ||||||
|  |       - uses: actions/upload-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-download-json | ||||||
|  |           path: out/last_download.json | ||||||
| 
 | 
 | ||||||
|       - 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: prefered 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 describe --tags --match="nightly-v[0-9]*" --abbrev=0) | ||||||
|  |           export NOTES=$(./scripts/get-nightly-changelog.sh) | ||||||
|  |           yarn files:set-notes | ||||||
|  | 
 | ||||||
|       - name: Authenticate to Google Cloud |       - name: Authenticate to Google Cloud | ||||||
|  |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|         uses: 'google-github-actions/auth@v2.1.7' |         uses: 'google-github-actions/auth@v2.1.7' | ||||||
|         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' }} | ||||||
|         uses: google-github-actions/setup-gcloud@v2.1.2 |         uses: google-github-actions/setup-gcloud@v2.1.2 | ||||||
|         with: |         with: | ||||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} |           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} | ||||||
| 
 | 
 | ||||||
|       - name: Upload release files to public bucket |       - name: Upload nightly files to public bucket | ||||||
|  |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.1 |         uses: google-github-actions/upload-cloud-storage@v2.2.1 | ||||||
|         with: |         with: | ||||||
|           path: out |           path: out | ||||||
|           glob: 'Zoo*' |           glob: '*' | ||||||
|           parent: false |           parent: false | ||||||
|           destination: ${{ env.BUCKET_DIR }} |           destination: 'dl.kittycad.io/releases/modeling-app/nightly' | ||||||
| 
 | 
 | ||||||
|       - name: Upload update endpoint to public bucket |       - name: Tag nightly commit | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.1 |         if: ${{ env.IS_NIGHTLY == 'true' }} | ||||||
|  |         uses: actions/github-script@v7 | ||||||
|         with: |         with: | ||||||
|           path: out |           script: | | ||||||
|           glob: 'latest*' |             const { VERSION } = process.env           | ||||||
|           parent: false |             const { owner, repo } = context.repo | ||||||
|           destination: ${{ env.BUCKET_DIR }} |             const { sha } = context | ||||||
| 
 |             const ref = `refs/tags/nightly-${VERSION}` | ||||||
|       - name: Upload download endpoint to public bucket |             github.rest.git.createRef({ owner, repo, sha, ref }) | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.1 |  | ||||||
|         with: |  | ||||||
|           path: last_download.json |  | ||||||
|           destination: ${{ env.BUCKET_DIR }} |  | ||||||
| 
 |  | ||||||
|       - name: Upload release files to Github |  | ||||||
|         if: ${{ github.event_name == 'release' }} |  | ||||||
|         uses: softprops/action-gh-release@v2 |  | ||||||
|         with: |  | ||||||
|           files: 'out/Zoo*' |  | ||||||
| 
 |  | ||||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files |  | ||||||
|         run: | |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/last_download.json" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-linux-arm64.yml" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-mac.yml" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest.yml" --async |  | ||||||
| 
 |  | ||||||
|   announce_release: |  | ||||||
|     needs: [publish-apps-release] |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     if: github.event_name == 'release' |  | ||||||
|     steps: |  | ||||||
|       - name: Check out code |  | ||||||
|         uses: actions/checkout@v4 |  | ||||||
| 
 |  | ||||||
|       - name: Set up Python |  | ||||||
|         uses: actions/setup-python@v5 |  | ||||||
|         with: |  | ||||||
|           python-version: '3.x' |  | ||||||
| 
 |  | ||||||
|       - name: Install dependencies |  | ||||||
|         run: | |  | ||||||
|           python -m pip install --upgrade pip |  | ||||||
|           pip install requests |  | ||||||
| 
 |  | ||||||
|       - name: Announce Release |  | ||||||
|         env: |  | ||||||
|           DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }} |  | ||||||
|           RELEASE_VERSION: ${{ github.event.release.tag_name }} |  | ||||||
|           RELEASE_BODY: ${{ github.event.release.body}} |  | ||||||
|         run: python public/announce_release.py |  | ||||||
							
								
								
									
										4
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -5,6 +5,8 @@ on: | |||||||
|     paths: |     paths: | ||||||
|       - 'src/wasm-lib/**.rs' |       - 'src/wasm-lib/**.rs' | ||||||
|       - 'src/wasm-lib/**.hbs' |       - 'src/wasm-lib/**.hbs' | ||||||
|  |       - 'src/wasm-lib/**.gen' | ||||||
|  |       - 'src/wasm-lib/**.snap' | ||||||
|       - '**/Cargo.toml' |       - '**/Cargo.toml' | ||||||
|       - '**/Cargo.lock' |       - '**/Cargo.lock' | ||||||
|       - '**/rust-toolchain.toml' |       - '**/rust-toolchain.toml' | ||||||
| @ -15,6 +17,8 @@ on: | |||||||
|     paths: |     paths: | ||||||
|       - 'src/wasm-lib/**.rs' |       - 'src/wasm-lib/**.rs' | ||||||
|       - 'src/wasm-lib/**.hbs' |       - 'src/wasm-lib/**.hbs' | ||||||
|  |       - 'src/wasm-lib/**.gen' | ||||||
|  |       - 'src/wasm-lib/**.snap' | ||||||
|       - '**/Cargo.toml' |       - '**/Cargo.toml' | ||||||
|       - '**/Cargo.lock' |       - '**/Cargo.lock' | ||||||
|       - '**/rust-toolchain.toml' |       - '**/rust-toolchain.toml' | ||||||
|  | |||||||
							
								
								
									
										37
									
								
								.github/workflows/create-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								.github/workflows/create-release.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,37 +0,0 @@ | |||||||
| name: Create Release |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   create-release: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     permissions: |  | ||||||
|       contents: write |  | ||||||
|       pull-requests: read |  | ||||||
|     if: contains(github.event.head_commit.message, 'Cut release v') |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/github-script@v7 |  | ||||||
|         name: Read Cut release PR info and create release |  | ||||||
|         with: |  | ||||||
|           script: | |  | ||||||
|             const { owner, repo } = context.repo |  | ||||||
|             const pulls = await github.rest.repos.listPullRequestsAssociatedWithCommit({ |  | ||||||
|               owner, |  | ||||||
|               repo, |  | ||||||
|               commit_sha: context.sha, |  | ||||||
|             }) |  | ||||||
|             const { title, body } = pulls.data[0] |  | ||||||
|             const version = title.split('Cut release ')[1] |  | ||||||
|  |  | ||||||
|             const result = await github.rest.repos.createRelease({ |  | ||||||
|               owner, |  | ||||||
|               repo, |  | ||||||
|               body, |  | ||||||
|               tag_name: version, |  | ||||||
|               name: version, |  | ||||||
|               draft: true, |  | ||||||
|             }) |  | ||||||
|             console.log(result) |  | ||||||
							
								
								
									
										4
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -68,7 +68,7 @@ jobs: | |||||||
|     - name: Download Wasm Cache |     - name: Download Wasm Cache | ||||||
|       id: download-wasm |       id: download-wasm | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|       uses: dawidd6/action-download-artifact@v6 |       uses: dawidd6/action-download-artifact@v7 | ||||||
|       continue-on-error: true |       continue-on-error: true | ||||||
|       with: |       with: | ||||||
|         github_token: ${{secrets.GITHUB_TOKEN}} |         github_token: ${{secrets.GITHUB_TOKEN}} | ||||||
| @ -255,7 +255,7 @@ jobs: | |||||||
|     - name: Download Wasm Cache |     - name: Download Wasm Cache | ||||||
|       id: download-wasm |       id: download-wasm | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|       uses: dawidd6/action-download-artifact@v6 |       uses: dawidd6/action-download-artifact@v7 | ||||||
|       continue-on-error: true |       continue-on-error: true | ||||||
|       with: |       with: | ||||||
|         github_token: ${{secrets.GITHUB_TOKEN}} |         github_token: ${{secrets.GITHUB_TOKEN}} | ||||||
|  | |||||||
							
								
								
									
										164
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,164 @@ | |||||||
|  | name: publish-apps-release | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [published] | ||||||
|  |  | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   publish-apps-release: | ||||||
|  |     runs-on: ubuntu-22.04 | ||||||
|  |     permissions: | ||||||
|  |       contents: write | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - uses: actions/setup-node@v4 | ||||||
|  |         with: | ||||||
|  |           node-version-file: '.nvmrc' | ||||||
|  |           cache: 'yarn' | ||||||
|  |  | ||||||
|  |       - name: Find tag workflow id | ||||||
|  |         id: tag_workflow_id | ||||||
|  |         env: | ||||||
|  |           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |         run: | | ||||||
|  |           id=$(gh run ls --repo kittycad/modeling-app -w build-apps.yml --branch ${{ github.event.release.tag_name }} --json databaseId | jq '.[0].databaseId') | ||||||
|  |           echo "id=$id" >> "$GITHUB_OUTPUT" | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-arm64-win | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |            | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-x64-win | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-yml-win | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-arm64-mac | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-x64-mac | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-yml-mac | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-arm64-linux | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-x64-linux | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-yml-linux | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: out-download-json | ||||||
|  |           path: out | ||||||
|  |           run-id: ${{ steps.tag_workflow_id.outputs.id }} | ||||||
|  |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |  | ||||||
|  |       - name: List artifacts | ||||||
|  |         run: ls -R out | ||||||
|  |  | ||||||
|  |       - name: Override release notes | ||||||
|  |         env: | ||||||
|  |           NOTES: ${{ github.event.release.body }} | ||||||
|  |         run: yarn files:set-notes | ||||||
|  |  | ||||||
|  |       - name: Authenticate to Google Cloud | ||||||
|  |         uses: 'google-github-actions/auth@v2.1.7' | ||||||
|  |         with: | ||||||
|  |           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||||
|  |  | ||||||
|  |       - name: Set up Google Cloud SDK | ||||||
|  |         uses: google-github-actions/setup-gcloud@v2.1.2 | ||||||
|  |         with: | ||||||
|  |           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} | ||||||
|  |  | ||||||
|  |       - name: Upload release files to public bucket | ||||||
|  |         uses: google-github-actions/upload-cloud-storage@v2.2.1 | ||||||
|  |         with: | ||||||
|  |           path: out | ||||||
|  |           glob: '*' | ||||||
|  |           parent: false | ||||||
|  |           destination: 'dl.kittycad.io/releases/modeling-app' | ||||||
|  |  | ||||||
|  |       - name: Invalidate bucket cache on latest*.yml and last_download.json files | ||||||
|  |         run: | | ||||||
|  |           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/last_download.json" --async | ||||||
|  |           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-linux-arm64.yml" --async | ||||||
|  |           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-mac.yml" --async | ||||||
|  |           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest.yml" --async | ||||||
|  |  | ||||||
|  |       - name: Upload release files to Github | ||||||
|  |         if: ${{ github.event_name == 'release' }} | ||||||
|  |         uses: softprops/action-gh-release@v2 | ||||||
|  |         with: | ||||||
|  |           files: 'out/Zoo*' | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   announce_release: | ||||||
|  |     needs: [publish-apps-release] | ||||||
|  |     runs-on: ubuntu-22.04 | ||||||
|  |     steps: | ||||||
|  |       - name: Check out code | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - name: Set up Python | ||||||
|  |         uses: actions/setup-python@v5 | ||||||
|  |         with: | ||||||
|  |           python-version: '3.x' | ||||||
|  |  | ||||||
|  |       - name: Install dependencies | ||||||
|  |         run: | | ||||||
|  |           python -m pip install --upgrade pip | ||||||
|  |           pip install requests | ||||||
|  |  | ||||||
|  |       - name: Announce Release | ||||||
|  |         env: | ||||||
|  |           DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }} | ||||||
|  |           RELEASE_VERSION: ${{ github.event.release.tag_name }} | ||||||
|  |           RELEASE_BODY: ${{ github.event.release.body }} | ||||||
|  |         run: python public/announce_release.py | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -61,6 +61,7 @@ Mac_App_Distribution.provisionprofile | |||||||
| *.tsbuildinfo | *.tsbuildinfo | ||||||
| src/wasm-lib/pkg | src/wasm-lib/pkg | ||||||
|  |  | ||||||
|  | .eslintcache | ||||||
| venv | venv | ||||||
| .vite/ | .vite/ | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
									
									
									
									
								
							| @ -19,7 +19,7 @@ $(XSTATE_TYPEGENS): $(TS_SRC) | |||||||
| 	yarn xstate typegen 'src/**/*.ts?(x)' | 	yarn xstate typegen 'src/**/*.ts?(x)' | ||||||
|  |  | ||||||
| public/wasm_lib_bg.wasm: $(WASM_LIB_FILES) | public/wasm_lib_bg.wasm: $(WASM_LIB_FILES) | ||||||
| 	yarn build:wasm-dev | 	yarn build:wasm | ||||||
|  |  | ||||||
| node_modules: package.json yarn.lock | node_modules: package.json yarn.lock | ||||||
| 	yarn install | 	yarn install | ||||||
|  | |||||||
							
								
								
									
										65
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										65
									
								
								README.md
									
									
									
									
									
								
							| @ -99,7 +99,7 @@ yarn tron:start | |||||||
|  |  | ||||||
| This will start the application and hot-reload on changes. | This will start the application and hot-reload on changes. | ||||||
|  |  | ||||||
| Devtools can be opened with the usual Cmd/Ctrl-Shift-I. | Devtools can be opened with the usual Cmd-Opt-I (Mac) or Ctrl-Shift-I (Linux and Windows). | ||||||
|  |  | ||||||
| To build, run `yarn tron:package`. | To build, run `yarn tron:package`. | ||||||
|  |  | ||||||
| @ -110,7 +110,7 @@ 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: | The following will need to be run when checking out a new commit and guarantees the build is not stale: | ||||||
| ```bash | ```bash | ||||||
| yarn install | yarn install | ||||||
| yarn build:wasm-dev # or yarn build:wasm for slower but more production-like build | yarn build:wasm | ||||||
| yarn start # or yarn build:local && yarn serve for slower but more production-like build | yarn start # or yarn build:local && yarn serve for slower but more production-like build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -128,45 +128,37 @@ Before you submit a contribution PR to this repo, please ensure that: | |||||||
|  |  | ||||||
| ## Release a new version | ## Release a new version | ||||||
|  |  | ||||||
| #### 1. Bump the versions by running `./make-release.sh` | #### 1. Create a 'Cut release $VERSION' issue | ||||||
|  |  | ||||||
| The `./make-release.sh` script has git commands to pull main but to be sure you can run the following git commands to have a fresh `main` locally. | 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`. | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| git branch -D main | VERSION=$(./scripts/semantic-release.sh) | ||||||
| git checkout main | git tag $VERSION | ||||||
| git pull origin | git push origin --tags | ||||||
| ./make-release.sh |  | ||||||
| # Copy within the back ticks and paste the stdout of the change log |  | ||||||
| git push --set-upstream origin <branch name created from ./make-release.sh> |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| That will create the branch with the updated json files for you: | This will trigger the `build-apps` workflow, set the version, build & sign the apps, and generate release files as well as updater-test artifacts. | ||||||
| - run `./make-release.sh` or `./make-release.sh patch` for a patch update; |  | ||||||
| - run `./make-release.sh minor` for minor; or |  | ||||||
| - run `./make-release.sh major` for major. |  | ||||||
|  |  | ||||||
| After it runs you should just need the push the branch and open a PR. | The workflow should be listed right away [in this list](https://github.com/KittyCAD/modeling-app/actions/workflows/build-apps.yml?query=event%3Apush)). | ||||||
|  |  | ||||||
| #### 2. Create a Cut Release PR | #### 3. Manually test artifacts | ||||||
|  |  | ||||||
| When you open the PR copy the change log from the output of the `./make-release.sh` script into the description of the PR. |  | ||||||
|  |  | ||||||
| **Important:** Pull request title needs to be prefixed with `Cut release v` to build in release mode and a few other things to test in the best context possible, the intent would be for instance to have `Cut release v1.2.3` for the `v1.2.3` release candidate. |  | ||||||
|  |  | ||||||
| The PR may then serve as a place to discuss the human-readable changelog and extra QA. The `make-release.sh` tool suggests a changelog for you too to be used as PR description, just make sure to delete lines that are not user facing. |  | ||||||
|  |  | ||||||
| #### 3. Manually test artifacts from the Cut Release PR |  | ||||||
|  |  | ||||||
| ##### Release builds | ##### Release builds | ||||||
|  |  | ||||||
| The release builds can be found under the `out-{platform}` zip, at the very bottom of the `build-publish-apps` summary page for each commit on this branch. | 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 Cut Release PR. | 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 | ##### Updater-test builds | ||||||
|  |  | ||||||
| The other `build-publish-apps` output in Cut Release PRs is `updater-test-{platform}`. As we don't have a way to test this fully automatically, we have 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 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. | 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. | ||||||
|  |  | ||||||
| @ -182,18 +174,17 @@ If the prompt doesn't show up, start the app in command line to grab the electro | |||||||
| ./Zoo Modeling App-{version}-{arch}-linux.AppImage | ./Zoo Modeling App-{version}-{arch}-linux.AppImage | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| #### 4. Merge the Cut Release PR | #### 4. Publish the release | ||||||
|  |  | ||||||
| This will kick the `create-release` action, that creates a _Draft_ release out of this Cut Release PR merge after less than a minute, with the new version as title and Cut Release PR as description. | 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_.  | ||||||
|  |  | ||||||
| #### 5. Publish the 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.  | ||||||
|  |  | ||||||
| Head over to https://github.com/KittyCAD/modeling-app/releases, the draft release corresponding to the merged Cut Release PR should show up at the top as _Draft_. Click on it, verify the content, and hit _Publish_. | #### 5. Close the issue | ||||||
|  |  | ||||||
| #### 6. Profit | If everything is well and the release is out to the public, the issue tracking the release shall be closed. | ||||||
|  |  | ||||||
| A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, which can be found under `release` event filter. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Fuzzing the parser | ## Fuzzing the parser | ||||||
| @ -459,3 +450,9 @@ PS: for the debug panel, the following JSON is useful for snapping the camera | |||||||
| ## KCL | ## KCL | ||||||
|  |  | ||||||
| For how to contribute to KCL, [see our KCL README](https://github.com/KittyCAD/modeling-app/tree/main/src/wasm-lib/kcl). | For how to contribute to KCL, [see our KCL README](https://github.com/KittyCAD/modeling-app/tree/main/src/wasm-lib/kcl). | ||||||
|  |  | ||||||
|  | ### Logging | ||||||
|  |  | ||||||
|  | To display logging (to the terminal or console) set `ZOO_LOG=1`. This will log some warnings and simple performance metrics. To view these in test runs, use `-- --nocapture`. | ||||||
|  |  | ||||||
|  | To enable memory metrics, build with `--features dhat-heap`. | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								assets/icon-nightly.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon-nightly.ico
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 119 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon-nightly.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon-nightly.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 259 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon.icns
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.icns
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								assets/icon.ico
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.ico
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 183 KiB After Width: | Height: | Size: 114 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon.png
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.png
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 113 KiB After Width: | Height: | Size: 113 KiB | 
										
											Binary file not shown.
										
									
								
							| @ -36,9 +36,9 @@ myAngle = -120 | |||||||
| sketch001 = startSketchOn('XZ') | sketch001 = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([8, 0], %) |   |> line([8, 0], %) | ||||||
|   |> angledLine({ angle: abs(myAngle), length: 5 }, %) |   |> angledLine({ angle = abs(myAngle), length = 5 }, %) | ||||||
|   |> line([-5, 0], %) |   |> line([-5, 0], %) | ||||||
|   |> angledLine({ angle: myAngle, length: 5 }, %) |   |> angledLine({ angle = myAngle, length = 5 }, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| baseExtrusion = extrude(5, sketch001) | baseExtrusion = extrude(5, sketch001) | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ acos(num: number) -> number | |||||||
| sketch001 = startSketchOn('XZ') | sketch001 = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: toDegrees(acos(0.5)), |        angle = toDegrees(acos(0.5)), | ||||||
|        length: 10 |        length = 10 | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([5, 0], %) |   |> line([5, 0], %) | ||||||
|   |> lineTo([12, 0], %) |   |> lineTo([12, 0], %) | ||||||
|  | |||||||
| @ -1,10 +1,10 @@ | |||||||
| --- | --- | ||||||
| title: "angleToMatchLengthX" | title: "angleToMatchLengthX" | ||||||
| excerpt: "Compute the angle (in degrees) in o" | excerpt: "Returns the angle to match the given length for x." | ||||||
| layout: manual | layout: manual | ||||||
| --- | --- | ||||||
|  |  | ||||||
| Compute the angle (in degrees) in o | Returns the angle to match the given length for x. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -33,8 +33,8 @@ sketch001 = startSketchOn('XZ') | |||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([1, 2], %, $seg01) |   |> line([1, 2], %, $seg01) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: angleToMatchLengthY(seg01, 15, %), |        angle = angleToMatchLengthY(seg01, 15, %), | ||||||
|        length: 5 |        length = 5 | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -32,7 +32,7 @@ angledLine(data: AngledLineData, sketch: Sketch, tag?: TagDeclarator) -> Sketch | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> yLineTo(15, %) |   |> yLineTo(15, %) | ||||||
|   |> angledLine({ angle: 30, length: 15 }, %) |   |> angledLine({ angle = 30, length = 15 }, %) | ||||||
|   |> line([8, -10], %) |   |> line([8, -10], %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -31,8 +31,8 @@ angledLineOfXLength(data: AngledLineData, sketch: Sketch, tag?: TagDeclarator) - | |||||||
| ```js | ```js | ||||||
| sketch001 = startSketchOn('XZ') | sketch001 = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLineOfXLength({ angle: 45, length: 10 }, %, $edge1) |   |> angledLineOfXLength({ angle = 45, length = 10 }, %, $edge1) | ||||||
|   |> angledLineOfXLength({ angle: -15, length: 20 }, %, $edge2) |   |> angledLineOfXLength({ angle = -15, length = 20 }, %, $edge2) | ||||||
|   |> line([0, -5], %) |   |> line([0, -5], %) | ||||||
|   |> close(%, $edge3) |   |> close(%, $edge3) | ||||||
|  |  | ||||||
|  | |||||||
| @ -32,9 +32,9 @@ angledLineOfYLength(data: AngledLineData, sketch: Sketch, tag?: TagDeclarator) - | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> angledLineOfYLength({ angle: 45, length: 10 }, %) |   |> angledLineOfYLength({ angle = 45, length = 10 }, %) | ||||||
|   |> line([0, 10], %) |   |> line([0, 10], %) | ||||||
|   |> angledLineOfYLength({ angle: 135, length: 10 }, %) |   |> angledLineOfYLength({ angle = 135, length = 10 }, %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> line([0, -30], %) |   |> line([0, -30], %) | ||||||
|  |  | ||||||
|  | |||||||
| @ -35,9 +35,9 @@ exampleSketch = startSketchOn('XZ') | |||||||
|   |> lineTo([-10, 10], %, $lineToIntersect) |   |> lineTo([-10, 10], %, $lineToIntersect) | ||||||
|   |> lineTo([0, 20], %) |   |> lineTo([0, 20], %) | ||||||
|   |> angledLineThatIntersects({ |   |> angledLineThatIntersects({ | ||||||
|        angle: 80, |        angle = 80, | ||||||
|        intersectTag: lineToIntersect, |        intersectTag = lineToIntersect, | ||||||
|        offset: 10 |        offset = 10 | ||||||
|      }, %) |      }, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ angledLineToX(data: AngledLineToData, sketch: Sketch, tag?: TagDeclarator) -> Sk | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLineToX({ angle: 30, to: 10 }, %) |   |> angledLineToX({ angle = 30, to = 10 }, %) | ||||||
|   |> line([0, 10], %) |   |> line([0, 10], %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -31,9 +31,9 @@ angledLineToY(data: AngledLineToData, sketch: Sketch, tag?: TagDeclarator) -> Sk | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLineToY({ angle: 60, to: 20 }, %) |   |> angledLineToY({ angle = 60, to = 20 }, %) | ||||||
|   |> line([-20, 0], %) |   |> line([-20, 0], %) | ||||||
|   |> angledLineToY({ angle: 70, to: 10 }, %) |   |> angledLineToY({ angle = 70, to = 10 }, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(10, exampleSketch) | example = extrude(10, exampleSketch) | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										41
									
								
								docs/kcl/arcTo.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								docs/kcl/arcTo.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -34,8 +34,8 @@ asin(num: number) -> number | |||||||
| sketch001 = startSketchOn('XZ') | sketch001 = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: toDegrees(asin(0.5)), |        angle = toDegrees(asin(0.5)), | ||||||
|        length: 20 |        length = 20 | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ atan(num: number) -> number | |||||||
| sketch001 = startSketchOn('XZ') | sketch001 = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: toDegrees(atan(1.25)), |        angle = toDegrees(atan(1.25)), | ||||||
|        length: 20 |        length = 20 | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -33,9 +33,9 @@ exampleSketch = startSketchOn('XZ') | |||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([0, 10], %) |   |> line([0, 10], %) | ||||||
|   |> bezierCurve({ |   |> bezierCurve({ | ||||||
|        to: [10, 10], |        to = [10, 10], | ||||||
|        control1: [5, 0], |        control1 = [5, 0], | ||||||
|        control2: [5, 10] |        control2 = [5, 10] | ||||||
|      }, %) |      }, %) | ||||||
|   |> lineTo([10, 0], %) |   |> lineTo([10, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -44,8 +44,8 @@ mountingPlateSketch = startSketchOn("XY") | |||||||
|  |  | ||||||
| mountingPlate = extrude(thickness, mountingPlateSketch) | mountingPlate = extrude(thickness, mountingPlateSketch) | ||||||
|   |> chamfer({ |   |> chamfer({ | ||||||
|        length: chamferLength, |        length = chamferLength, | ||||||
|        tags: [ |        tags = [ | ||||||
|          getNextAdjacentEdge(edge1), |          getNextAdjacentEdge(edge1), | ||||||
|          getNextAdjacentEdge(edge2), |          getNextAdjacentEdge(edge2), | ||||||
|          getNextAdjacentEdge(edge3), |          getNextAdjacentEdge(edge3), | ||||||
| @ -58,7 +58,7 @@ mountingPlate = extrude(thickness, mountingPlateSketch) | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| // Sketch on the face of a chamfer. | // Sketch on the face of a chamfer. | ||||||
| fn cube = (pos, scale) => { | fn cube(pos, scale) { | ||||||
|   sg = startSketchOn('XY') |   sg = startSketchOn('XY') | ||||||
|     |> startProfileAt(pos, %) |     |> startProfileAt(pos, %) | ||||||
|     |> line([0, scale], %) |     |> line([0, scale], %) | ||||||
| @ -72,8 +72,8 @@ part001 = cube([0, 0], 20) | |||||||
|   |> close(%, $line1) |   |> close(%, $line1) | ||||||
|   |> extrude(20, %) |   |> extrude(20, %) | ||||||
|   |> chamfer({ |   |> chamfer({ | ||||||
|        length: 10, |        length = 10, | ||||||
|        tags: [getOppositeEdge(line1)] |        tags = [getOppositeEdge(line1)] | ||||||
|      }, %, $chamfer1) // We tag the chamfer to reference it later. |      }, %, $chamfer1) // We tag the chamfer to reference it later. | ||||||
|  |  | ||||||
| sketch001 = startSketchOn(part001, chamfer1) | sketch001 = startSketchOn(part001, chamfer1) | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ circle(data: CircleData, sketch_surface_or_group: SketchOrSurface, tag?: TagDecl | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("-XZ") | exampleSketch = startSketchOn("-XZ") | ||||||
|   |> circle({ center: [0, 0], radius: 10 }, %) |   |> circle({ center = [0, 0], radius = 10 }, %) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
| ``` | ``` | ||||||
| @ -44,7 +44,7 @@ exampleSketch = startSketchOn("XZ") | |||||||
|   |> line([0, 30], %) |   |> line([0, 30], %) | ||||||
|   |> line([-30, 0], %) |   |> line([-30, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|   |> hole(circle({ center: [0, 15], radius: 5 }, %), %) |   |> hole(circle({ center = [0, 15], radius = 5 }, %), %) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
| ``` | ``` | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ cos(num: number) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 30, |        angle = 30, | ||||||
|        length: 3 / cos(toRadians(30)) |        length = 3 / cos(toRadians(30)) | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -28,7 +28,7 @@ e() -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 30, length: 2 * e() ^ 2 }, %) |   |> angledLine({ angle = 30, length = 2 * e() ^ 2 }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
| @ -32,16 +32,16 @@ example = startSketchOn('XZ') | |||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> arc({ |   |> arc({ | ||||||
|        angleStart: 120, |        angleStart = 120, | ||||||
|        angleEnd: 0, |        angleEnd = 0, | ||||||
|        radius: 5 |        radius = 5 | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([5, 0], %) |   |> line([5, 0], %) | ||||||
|   |> line([0, 10], %) |   |> line([0, 10], %) | ||||||
|   |> bezierCurve({ |   |> bezierCurve({ | ||||||
|        control1: [-10, 0], |        control1 = [-10, 0], | ||||||
|        control2: [2, 10], |        control2 = [2, 10], | ||||||
|        to: [-5, 10] |        to = [-5, 10] | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([-5, -2], %) |   |> line([-5, -2], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
| @ -54,16 +54,16 @@ example = startSketchOn('XZ') | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([-10, 0], %) |   |> startProfileAt([-10, 0], %) | ||||||
|   |> arc({ |   |> arc({ | ||||||
|        angleStart: 120, |        angleStart = 120, | ||||||
|        angleEnd: -60, |        angleEnd = -60, | ||||||
|        radius: 5 |        radius = 5 | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> line([5, 0], %) |   |> line([5, 0], %) | ||||||
|   |> bezierCurve({ |   |> bezierCurve({ | ||||||
|        control1: [-3, 0], |        control1 = [-3, 0], | ||||||
|        control2: [2, 10], |        control2 = [2, 10], | ||||||
|        to: [-5, 10] |        to = [-5, 10] | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([-4, 10], %) |   |> line([-4, 10], %) | ||||||
|   |> line([-5, -2], %) |   |> line([-5, -2], %) | ||||||
|  | |||||||
| @ -43,8 +43,8 @@ mountingPlateSketch = startSketchOn("XY") | |||||||
|  |  | ||||||
| mountingPlate = extrude(thickness, mountingPlateSketch) | mountingPlate = extrude(thickness, mountingPlateSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius: filletRadius, |        radius = filletRadius, | ||||||
|        tags: [ |        tags = [ | ||||||
|          getNextAdjacentEdge(edge1), |          getNextAdjacentEdge(edge1), | ||||||
|          getNextAdjacentEdge(edge2), |          getNextAdjacentEdge(edge2), | ||||||
|          getNextAdjacentEdge(edge3), |          getNextAdjacentEdge(edge3), | ||||||
| @ -70,9 +70,9 @@ mountingPlateSketch = startSketchOn("XY") | |||||||
|  |  | ||||||
| mountingPlate = extrude(thickness, mountingPlateSketch) | mountingPlate = extrude(thickness, mountingPlateSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius: filletRadius, |        radius = filletRadius, | ||||||
|        tolerance: 0.000001, |        tolerance = 0.000001, | ||||||
|        tags: [ |        tags = [ | ||||||
|          getNextAdjacentEdge(edge1), |          getNextAdjacentEdge(edge1), | ||||||
|          getNextAdjacentEdge(edge2), |          getNextAdjacentEdge(edge2), | ||||||
|          getNextAdjacentEdge(edge3), |          getNextAdjacentEdge(edge3), | ||||||
|  | |||||||
| @ -30,16 +30,16 @@ getNextAdjacentEdge(tag: TagIdentifier) -> Uuid | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %) |   |> angledLine({ angle = 60, length = 10 }, %) | ||||||
|   |> angledLine({ angle: 120, length: 10 }, %) |   |> angledLine({ angle = 120, length = 10 }, %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) |   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius: 3, |        radius = 3, | ||||||
|        tags: [getNextAdjacentEdge(referenceEdge)] |        tags = [getNextAdjacentEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -30,16 +30,16 @@ getOppositeEdge(tag: TagIdentifier) -> Uuid | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %) |   |> angledLine({ angle = 60, length = 10 }, %) | ||||||
|   |> angledLine({ angle: 120, length: 10 }, %) |   |> angledLine({ angle = 120, length = 10 }, %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) |   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius: 3, |        radius = 3, | ||||||
|        tags: [getOppositeEdge(referenceEdge)] |        tags = [getOppositeEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -30,16 +30,16 @@ getPreviousAdjacentEdge(tag: TagIdentifier) -> Uuid | |||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line([10, 0], %) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %) |   |> angledLine({ angle = 60, length = 10 }, %) | ||||||
|   |> angledLine({ angle: 120, length: 10 }, %) |   |> angledLine({ angle = 120, length = 10 }, %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) |   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius: 3, |        radius = 3, | ||||||
|        tags: [getPreviousAdjacentEdge(referenceEdge)] |        tags = [getPreviousAdjacentEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,12 +29,12 @@ helix(data: HelixData, solid: Solid) -> Solid | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| part001 = startSketchOn('XY') | part001 = startSketchOn('XY') | ||||||
|   |> circle({ center: [5, 5], radius: 10 }, %) |   |> circle({ center = [5, 5], radius = 10 }, %) | ||||||
|   |> extrude(10, %) |   |> extrude(10, %) | ||||||
|   |> helix({ |   |> helix({ | ||||||
|        angleStart: 0, |        angleStart = 0, | ||||||
|        ccw: true, |        ccw = true, | ||||||
|        revolutions: 16 |        revolutions = 16 | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -68,15 +68,15 @@ case = startSketchOn('-XZ') | |||||||
|  |  | ||||||
| thing1 = startSketchOn(case, 'end') | thing1 = startSketchOn(case, 'end') | ||||||
|   |> circle({ |   |> circle({ | ||||||
|        center: [-size / 2, -size / 2], |        center = [-size / 2, -size / 2], | ||||||
|        radius: 25 |        radius = 25 | ||||||
|      }, %) |      }, %) | ||||||
|   |> extrude(50, %) |   |> extrude(50, %) | ||||||
|  |  | ||||||
| thing2 = startSketchOn(case, 'end') | thing2 = startSketchOn(case, 'end') | ||||||
|   |> circle({ |   |> circle({ | ||||||
|        center: [size / 2, -size / 2], |        center = [size / 2, -size / 2], | ||||||
|        radius: 25 |        radius = 25 | ||||||
|      }, %) |      }, %) | ||||||
|   |> extrude(50, %) |   |> extrude(50, %) | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -7,6 +7,7 @@ layout: manual | |||||||
| ## Table of Contents | ## Table of Contents | ||||||
|  |  | ||||||
| * [Types](kcl/types) | * [Types](kcl/types) | ||||||
|  | * [Modules](kcl/modules) | ||||||
| * [Known Issues](kcl/KNOWN-ISSUES) | * [Known Issues](kcl/KNOWN-ISSUES) | ||||||
| * [`abs`](kcl/abs) | * [`abs`](kcl/abs) | ||||||
| * [`acos`](kcl/acos) | * [`acos`](kcl/acos) | ||||||
| @ -19,6 +20,7 @@ layout: manual | |||||||
| * [`angledLineToX`](kcl/angledLineToX) | * [`angledLineToX`](kcl/angledLineToX) | ||||||
| * [`angledLineToY`](kcl/angledLineToY) | * [`angledLineToY`](kcl/angledLineToY) | ||||||
| * [`arc`](kcl/arc) | * [`arc`](kcl/arc) | ||||||
|  | * [`arcTo`](kcl/arcTo) | ||||||
| * [`asin`](kcl/asin) | * [`asin`](kcl/asin) | ||||||
| * [`assert`](kcl/assert) | * [`assert`](kcl/assert) | ||||||
| * [`assertEqual`](kcl/assertEqual) | * [`assertEqual`](kcl/assertEqual) | ||||||
| @ -72,6 +74,7 @@ layout: manual | |||||||
| * [`patternLinear2d`](kcl/patternLinear2d) | * [`patternLinear2d`](kcl/patternLinear2d) | ||||||
| * [`patternLinear3d`](kcl/patternLinear3d) | * [`patternLinear3d`](kcl/patternLinear3d) | ||||||
| * [`patternTransform`](kcl/patternTransform) | * [`patternTransform`](kcl/patternTransform) | ||||||
|  | * [`patternTransform2d`](kcl/patternTransform2d) | ||||||
| * [`pi`](kcl/pi) | * [`pi`](kcl/pi) | ||||||
| * [`polar`](kcl/polar) | * [`polar`](kcl/polar) | ||||||
| * [`polygon`](kcl/polygon) | * [`polygon`](kcl/polygon) | ||||||
| @ -83,6 +86,7 @@ layout: manual | |||||||
| * [`reduce`](kcl/reduce) | * [`reduce`](kcl/reduce) | ||||||
| * [`rem`](kcl/rem) | * [`rem`](kcl/rem) | ||||||
| * [`revolve`](kcl/revolve) | * [`revolve`](kcl/revolve) | ||||||
|  | * [`round`](kcl/round) | ||||||
| * [`segAng`](kcl/segAng) | * [`segAng`](kcl/segAng) | ||||||
| * [`segEnd`](kcl/segEnd) | * [`segEnd`](kcl/segEnd) | ||||||
| * [`segEndX`](kcl/segEndX) | * [`segEndX`](kcl/segEndX) | ||||||
| @ -98,6 +102,7 @@ layout: manual | |||||||
| * [`startSketchAt`](kcl/startSketchAt) | * [`startSketchAt`](kcl/startSketchAt) | ||||||
| * [`startSketchOn`](kcl/startSketchOn) | * [`startSketchOn`](kcl/startSketchOn) | ||||||
| * [`tan`](kcl/tan) | * [`tan`](kcl/tan) | ||||||
|  | * [`tangentToEnd`](kcl/tangentToEnd) | ||||||
| * [`tangentialArc`](kcl/tangentialArc) | * [`tangentialArc`](kcl/tangentialArc) | ||||||
| * [`tangentialArcTo`](kcl/tangentialArcTo) | * [`tangentialArcTo`](kcl/tangentialArcTo) | ||||||
| * [`tangentialArcToRelative`](kcl/tangentialArcToRelative) | * [`tangentialArcToRelative`](kcl/tangentialArcToRelative) | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -60,10 +60,10 @@ squareSketch = startSketchOn('XY') | |||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| circleSketch0 = startSketchOn(offsetPlane('XY', 75)) | circleSketch0 = startSketchOn(offsetPlane('XY', 75)) | ||||||
|   |> circle({ center: [0, 100], radius: 50 }, %) |   |> circle({ center = [0, 100], radius = 50 }, %) | ||||||
|  |  | ||||||
| circleSketch1 = startSketchOn(offsetPlane('XY', 150)) | circleSketch1 = startSketchOn(offsetPlane('XY', 150)) | ||||||
|   |> circle({ center: [0, 100], radius: 20 }, %) |   |> circle({ center = [0, 100], radius = 20 }, %) | ||||||
|  |  | ||||||
| loft([ | loft([ | ||||||
|   squareSketch, |   squareSketch, | ||||||
| @ -85,10 +85,10 @@ squareSketch = startSketchOn('XY') | |||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| circleSketch0 = startSketchOn(offsetPlane('XY', 75)) | circleSketch0 = startSketchOn(offsetPlane('XY', 75)) | ||||||
|   |> circle({ center: [0, 100], radius: 50 }, %) |   |> circle({ center = [0, 100], radius = 50 }, %) | ||||||
|  |  | ||||||
| circleSketch1 = startSketchOn(offsetPlane('XY', 150)) | circleSketch1 = startSketchOn(offsetPlane('XY', 150)) | ||||||
|   |> circle({ center: [0, 100], radius: 20 }, %) |   |> circle({ center = [0, 100], radius = 20 }, %) | ||||||
|  |  | ||||||
| loft([ | loft([ | ||||||
|   squareSketch, |   squareSketch, | ||||||
| @ -97,17 +97,17 @@ loft([ | |||||||
| ], { | ], { | ||||||
|   // This can be set to override the automatically determined |   // This can be set to override the automatically determined | ||||||
|   // topological base curve, which is usually the first section encountered. |   // topological base curve, which is usually the first section encountered. | ||||||
|   baseCurveIndex: 0, |   baseCurveIndex = 0, | ||||||
|   // Attempt to approximate rational curves (such as arcs) using a bezier. |   // Attempt to approximate rational curves (such as arcs) using a bezier. | ||||||
|   // This will remove banding around interpolations between arcs and non-arcs. |   // This will remove banding around interpolations between arcs and non-arcs. | ||||||
|   // It may produce errors in other scenarios Over time, this field won't be necessary. |   // It may produce errors in other scenarios Over time, this field won't be necessary. | ||||||
|   bezApproximateRational: false, |   bezApproximateRational = false, | ||||||
|   // Tolerance for the loft operation. |   // Tolerance for the loft operation. | ||||||
|   tolerance: 0.000001, |   tolerance = 0.000001, | ||||||
|   // Degree of the interpolation. Must be greater than zero. |   // Degree of the interpolation. Must be greater than zero. | ||||||
|   // For example, use 2 for quadratic, or 3 for cubic interpolation in |   // For example, use 2 for quadratic, or 3 for cubic interpolation in | ||||||
|   // the V direction. This defaults to 2, if not specified. |   // the V direction. This defaults to 2, if not specified. | ||||||
|   vDegree: 2 |   vDegree = 2 | ||||||
| }) | }) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,9 +29,9 @@ map(array: [KclValue], map_fn: FunctionParam) -> [KclValue] | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| r = 10 // radius | r = 10 // radius | ||||||
| fn drawCircle = (id) => { | fn drawCircle(id) { | ||||||
|   return startSketchOn("XY") |   return startSketchOn("XY") | ||||||
|   |> circle({ center: [id * 2 * r, 0], radius: r }, %) |     |> circle({ center = [id * 2 * r, 0], radius = r }, %) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Call `drawCircle`, passing in each element of the array. | // Call `drawCircle`, passing in each element of the array. | ||||||
| @ -45,9 +45,9 @@ circles = map([1..3], drawCircle) | |||||||
| ```js | ```js | ||||||
| r = 10 // radius | r = 10 // radius | ||||||
| // Call `map`, using an anonymous function instead of a named one. | // Call `map`, using an anonymous function instead of a named one. | ||||||
| circles = map([1..3], (id) => { | circles = map([1..3], (id) { | ||||||
|   return startSketchOn("XY") |   return startSketchOn("XY") | ||||||
|   |> circle({ center: [id * 2 * r, 0], radius: r }, %) |     |> circle({ center = [id * 2 * r, 0], radius = r }, %) | ||||||
| }) | }) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ max(args: [number]) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 70, |        angle = 70, | ||||||
|        length: max(15, 31, 4, 13, 22) |        length = max(15, 31, 4, 13, 22) | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([20, 0], %) |   |> line([20, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ min(args: [number]) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 70, |        angle = 70, | ||||||
|        length: min(15, 31, 4, 13, 22) |        length = min(15, 31, 4, 13, 22) | ||||||
|      }, %) |      }, %) | ||||||
|   |> line([20, 0], %) |   |> line([20, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -41,7 +41,7 @@ sketch001 = startSketchOn('XZ') | |||||||
|   |> line([-8, -3], %) |   |> line([-8, -3], %) | ||||||
|   |> line([9, -1], %) |   |> line([9, -1], %) | ||||||
|   |> line([-19, -0], %) |   |> line([-19, -0], %) | ||||||
|   |> mirror2d({ axis: 'Y' }, %) |   |> mirror2d({ axis = 'Y' }, %) | ||||||
|  |  | ||||||
| example = extrude(10, sketch001) | example = extrude(10, sketch001) | ||||||
| ``` | ``` | ||||||
| @ -54,7 +54,7 @@ sketch001 = startSketchOn('XZ') | |||||||
|   |> startProfileAt([0, 8.5], %) |   |> startProfileAt([0, 8.5], %) | ||||||
|   |> line([20, -8.5], %) |   |> line([20, -8.5], %) | ||||||
|   |> line([-20, -8.5], %) |   |> line([-20, -8.5], %) | ||||||
|   |> mirror2d({ axis: 'Y' }, %) |   |> mirror2d({ axis = 'Y' }, %) | ||||||
|  |  | ||||||
| example = extrude(10, sketch001) | example = extrude(10, sketch001) | ||||||
| ``` | ``` | ||||||
| @ -71,7 +71,7 @@ sketch001 = startSketchOn('XZ') | |||||||
|   |> startProfileAt([0, 8.5], %) |   |> startProfileAt([0, 8.5], %) | ||||||
|   |> line([20, -8.5], %) |   |> line([20, -8.5], %) | ||||||
|   |> line([-20, -8.5], %) |   |> line([-20, -8.5], %) | ||||||
|   |> mirror2d({ axis: edge001 }, %) |   |> mirror2d({ axis = edge001 }, %) | ||||||
|  |  | ||||||
| example = extrude(10, sketch001) | example = extrude(10, sketch001) | ||||||
| ``` | ``` | ||||||
| @ -85,8 +85,11 @@ sketch001 = startSketchOn('XZ') | |||||||
|   |> line([20, -8.5], %) |   |> line([20, -8.5], %) | ||||||
|   |> line([-20, -8.5], %) |   |> line([-20, -8.5], %) | ||||||
|   |> mirror2d({ |   |> mirror2d({ | ||||||
|        axis: { |        axis = { | ||||||
|          custom: { axis: [0.0, 1.0], origin: [0.0, 0.0] } |          custom = { | ||||||
|  |            axis = [0.0, 1.0], | ||||||
|  |            origin = [0.0, 0.0] | ||||||
|  |          } | ||||||
|        } |        } | ||||||
|      }, %) |      }, %) | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										59
									
								
								docs/kcl/modules.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								docs/kcl/modules.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,59 @@ | |||||||
|  | --- | ||||||
|  | title: "KCL Modules" | ||||||
|  | excerpt: "Documentation of modules for the KCL language for the Zoo Modeling App." | ||||||
|  | layout: manual | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | `KCL` allows splitting code up into multiple files.  Each file is somewhat | ||||||
|  | isolated from other files as a separate module. | ||||||
|  |  | ||||||
|  | When you define a function, you can use `export` before it to make it available | ||||||
|  | to other modules. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | // util.kcl | ||||||
|  | export fn increment(x) { | ||||||
|  |   return x + 1 | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Other files in the project can now import functions that have been exported. | ||||||
|  | This makes them available to use in another file. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | // main.kcl | ||||||
|  | import increment from "util.kcl" | ||||||
|  |  | ||||||
|  | answer = increment(41) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Imported files _must_ be in the same project so that units are uniform across | ||||||
|  | modules. This means that it must be in the same directory. | ||||||
|  |  | ||||||
|  | Import statements must be at the top-level of a file. It is not allowed to have | ||||||
|  | an `import` statement inside a function or in the body of an if-else. | ||||||
|  |  | ||||||
|  | Multiple functions can be exported in a file. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | // util.kcl | ||||||
|  | export fn increment(x) { | ||||||
|  |   return x + 1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export fn decrement(x) { | ||||||
|  |   return x - 1 | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | When importing, you can import multiple functions at once. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | import increment, decrement from "util.kcl" | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Imported symbols can be renamed for convenience or to avoid name collisions. | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | import increment as inc, decrement as dec from "util.kcl" | ||||||
|  | ``` | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -35,10 +35,10 @@ exampleSketch = startSketchOn('XZ') | |||||||
|   |> line([0, -5], %) |   |> line([0, -5], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|   |> patternCircular2d({ |   |> patternCircular2d({ | ||||||
|        center: [0, 0], |        center = [0, 0], | ||||||
|        instances: 13, |        instances = 13, | ||||||
|        arcDegrees: 360, |        arcDegrees = 360, | ||||||
|        rotateDuplicates: true |        rotateDuplicates = true | ||||||
|      }, %) |      }, %) | ||||||
|  |  | ||||||
| example = extrude(1, exampleSketch) | example = extrude(1, exampleSketch) | ||||||
|  | |||||||
| @ -29,15 +29,15 @@ patternCircular3d(data: CircularPattern3dData, solid_set: SolidSet) -> [Solid] | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> circle({ center: [0, 0], radius: 1 }, %) |   |> circle({ center = [0, 0], radius = 1 }, %) | ||||||
|  |  | ||||||
| example = extrude(-5, exampleSketch) | example = extrude(-5, exampleSketch) | ||||||
|   |> patternCircular3d({ |   |> patternCircular3d({ | ||||||
|        axis: [1, -1, 0], |        axis = [1, -1, 0], | ||||||
|        center: [10, -20, 0], |        center = [10, -20, 0], | ||||||
|        instances: 11, |        instances = 11, | ||||||
|        arcDegrees: 360, |        arcDegrees = 360, | ||||||
|        rotateDuplicates: true |        rotateDuplicates = true | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,11 +29,11 @@ patternLinear2d(data: LinearPattern2dData, sketch_set: SketchSet) -> [Sketch] | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> circle({ center: [0, 0], radius: 1 }, %) |   |> circle({ center = [0, 0], radius = 1 }, %) | ||||||
|   |> patternLinear2d({ |   |> patternLinear2d({ | ||||||
|        axis: [1, 0], |        axis = [1, 0], | ||||||
|        instances: 7, |        instances = 7, | ||||||
|        distance: 4 |        distance = 4 | ||||||
|      }, %) |      }, %) | ||||||
|  |  | ||||||
| example = extrude(1, exampleSketch) | example = extrude(1, exampleSketch) | ||||||
|  | |||||||
| @ -37,9 +37,9 @@ exampleSketch = startSketchOn('XZ') | |||||||
|  |  | ||||||
| example = extrude(1, exampleSketch) | example = extrude(1, exampleSketch) | ||||||
|   |> patternLinear3d({ |   |> patternLinear3d({ | ||||||
|        axis: [1, 0, 1], |        axis = [1, 0, 1], | ||||||
|        instances: 7, |        instances = 7, | ||||||
|        distance: 6 |        distance = 6 | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										45
									
								
								docs/kcl/patternTransform2d.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								docs/kcl/patternTransform2d.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -30,8 +30,8 @@ circumference = 70 | |||||||
|  |  | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> circle({ |   |> circle({ | ||||||
|        center: [0, 0], |        center = [0, 0], | ||||||
|        radius: circumference / (2 * pi()) |        radius = circumference / (2 * pi()) | ||||||
|      }, %) |      }, %) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
|  | |||||||
| @ -29,7 +29,7 @@ polar(data: PolarCoordsData) -> [number] | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line(polar({ angle: 30, length: 5 }), %, $thing) |   |> line(polar({ angle = 30, length = 5 }), %, $thing) | ||||||
|   |> line([0, 5], %) |   |> line([0, 5], %) | ||||||
|   |> line([segEndX(thing), 0], %) |   |> line([segEndX(thing), 0], %) | ||||||
|   |> line([-20, 10], %) |   |> line([-20, 10], %) | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -34,7 +34,7 @@ pow(num: number, pow: number) -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 50, length: pow(5, 2) }, %) |   |> angledLine({ angle = 50, length = pow(5, 2) }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,10 +29,10 @@ profileStart(sketch: Sketch) -> [number] | |||||||
| ```js | ```js | ||||||
| sketch001 = startSketchOn('XY') | sketch001 = startSketchOn('XY') | ||||||
|   |> startProfileAt([5, 2], %) |   |> startProfileAt([5, 2], %) | ||||||
|   |> angledLine({ angle: 120, length: 50 }, %, $seg01) |   |> angledLine({ angle = 120, length = 50 }, %, $seg01) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: segAng(seg01) + 120, |        angle = segAng(seg01) + 120, | ||||||
|        length: 50 |        length = 50 | ||||||
|      }, %) |      }, %) | ||||||
|   |> lineTo(profileStart(%), %) |   |> lineTo(profileStart(%), %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							
							
								
								
									
										46
									
								
								docs/kcl/round.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								docs/kcl/round.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -36,10 +36,13 @@ cube = startSketchAt([0, 0]) | |||||||
|   |> close(%) |   |> close(%) | ||||||
|   |> extrude(5, %) |   |> extrude(5, %) | ||||||
|  |  | ||||||
| fn cylinder = (radius, tag) => { | fn cylinder(radius, tag) { | ||||||
|   return startSketchAt([0, 0]) |   return startSketchAt([0, 0]) | ||||||
|   |> circle({ radius: radius, center: segEnd(tag) }, %) |     |> circle({ | ||||||
|   |> extrude(radius, %) |          radius = radius, | ||||||
|  |          center = segEnd(tag) | ||||||
|  |        }, %) | ||||||
|  |     |> extrude(radius, %) | ||||||
| } | } | ||||||
|  |  | ||||||
| cylinder(1, line1) | cylinder(1, line1) | ||||||
|  | |||||||
| @ -29,9 +29,9 @@ segLen(tag: TagIdentifier) -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %, $thing) |   |> angledLine({ angle = 60, length = 10 }, %, $thing) | ||||||
|   |> tangentialArc({ offset: -120, radius: 5 }, %) |   |> tangentialArc({ offset = -120, radius = 5 }, %) | ||||||
|   |> angledLine({ angle: -60, length: segLen(thing) }, %) |   |> angledLine({ angle = -60, length = segLen(thing) }, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(5, exampleSketch) | example = extrude(5, exampleSketch) | ||||||
|  | |||||||
| @ -36,13 +36,13 @@ cube = startSketchAt([0, 0]) | |||||||
|   |> close(%) |   |> close(%) | ||||||
|   |> extrude(5, %) |   |> extrude(5, %) | ||||||
|  |  | ||||||
| fn cylinder = (radius, tag) => { | fn cylinder(radius, tag) { | ||||||
|   return startSketchAt([0, 0]) |   return startSketchAt([0, 0]) | ||||||
|   |> circle({ |     |> circle({ | ||||||
|        radius: radius, |          radius = radius, | ||||||
|        center: segStart(tag) |          center = segStart(tag) | ||||||
|      }, %) |        }, %) | ||||||
|   |> extrude(radius, %) |     |> extrude(radius, %) | ||||||
| } | } | ||||||
|  |  | ||||||
| cylinder(1, line1) | cylinder(1, line1) | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -34,8 +34,8 @@ sin(num: number) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 50, |        angle = 50, | ||||||
|        length: 15 / sin(toDegrees(135)) |        length = 15 / sin(toDegrees(135)) | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ sqrt(num: number) -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 50, length: sqrt(2500) }, %) |   |> angledLine({ angle = 50, length = sqrt(2500) }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
| @ -101,7 +101,7 @@ exampleSketch = startSketchOn('XY') | |||||||
|   |> line([-2, 0], %) |   |> line([-2, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = revolve({ axis: 'y', angle: 180 }, exampleSketch) | example = revolve({ axis = 'y', angle = 180 }, exampleSketch) | ||||||
|  |  | ||||||
| exampleSketch002 = startSketchOn(example, 'end') | exampleSketch002 = startSketchOn(example, 'end') | ||||||
|   |> startProfileAt([4.5, -5], %) |   |> startProfileAt([4.5, -5], %) | ||||||
| @ -117,11 +117,11 @@ example002 = extrude(5, exampleSketch002) | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| a1 = startSketchOn({ | a1 = startSketchOn({ | ||||||
|        plane: { |        plane = { | ||||||
|          origin: { x: 0, y: 0, z: 0 }, |          origin = { x = 0, y = 0, z = 0 }, | ||||||
|          xAxis: { x: 1, y: 0, z: 0 }, |          xAxis = { x = 1, y = 0, z = 0 }, | ||||||
|          yAxis: { x: 0, y: 1, z: 0 }, |          yAxis = { x = 0, y = 1, z = 0 }, | ||||||
|          zAxis: { x: 0, y: 0, z: 1 } |          zAxis = { x = 0, y = 0, z = 1 } | ||||||
|        } |        } | ||||||
|      }) |      }) | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|  | |||||||
							
								
								
									
										35318
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
							
						
						
									
										35318
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -33,7 +33,7 @@ tan(num: number) -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 50, length: 50 * tan(1 / 2) }, %) |   |> angledLine({ angle = 50, length = 50 * tan(1 / 2) }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										105
									
								
								docs/kcl/tangentToEnd.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								docs/kcl/tangentToEnd.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -31,9 +31,9 @@ tangentialArc(data: TangentialArcData, sketch: Sketch, tag?: TagDeclarator) -> S | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %) |   |> angledLine({ angle = 60, length = 10 }, %) | ||||||
|   |> tangentialArc({ radius: 10, offset: -120 }, %) |   |> tangentialArc({ radius = 10, offset = -120 }, %) | ||||||
|   |> angledLine({ angle: -60, length: 10 }, %) |   |> angledLine({ angle = -60, length = 10 }, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(10, exampleSketch) | example = extrude(10, exampleSketch) | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ tangentialArcTo(to: [number], sketch: Sketch, tag?: TagDeclarator) -> Sketch | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 60, length: 10 }, %) |   |> angledLine({ angle = 60, length = 10 }, %) | ||||||
|   |> tangentialArcTo([15, 15], %) |   |> tangentialArcTo([15, 15], %) | ||||||
|   |> line([10, -15], %) |   |> line([10, -15], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ tangentialArcToRelative(delta: [number], sketch: Sketch, tag?: TagDeclarator) -> | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 45, length: 10 }, %) |   |> angledLine({ angle = 45, length = 10 }, %) | ||||||
|   |> tangentialArcToRelative([0, -10], %) |   |> tangentialArcToRelative([0, -10], %) | ||||||
|   |> line([-10, 0], %) |   |> line([-10, 0], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -28,7 +28,7 @@ tau() -> number | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ angle: 50, length: 10 * tau() }, %) |   |> angledLine({ angle = 50, length = 10 * tau() }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  |  | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ toDegrees(num: number) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 50, |        angle = 50, | ||||||
|        length: 70 * cos(toDegrees(pi() / 4)) |        length = 70 * cos(toDegrees(pi() / 4)) | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ toRadians(num: number) -> number | |||||||
| exampleSketch = startSketchOn("XZ") | exampleSketch = startSketchOn("XZ") | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> angledLine({ |   |> angledLine({ | ||||||
|        angle: 50, |        angle = 50, | ||||||
|        length: 70 * cos(toRadians(45)) |        length = 70 * cos(toRadians(45)) | ||||||
|      }, %) |      }, %) | ||||||
|   |> yLineTo(0, %) |   |> yLineTo(0, %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
|  | |||||||
| @ -41,7 +41,7 @@ If you want to get a value from an array you can use the index like so: | |||||||
| An object is defined with `{}` braces. Here is an example object: | 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 | We support two different ways of getting properties from objects, you can call | ||||||
| @ -54,7 +54,7 @@ We also have support for defining your own functions. Functions can take in any | |||||||
| type of argument. Below is an example of the syntax: | type of argument. Below is an example of the syntax: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| fn myFn = (x) => { | fn myFn(x) { | ||||||
|   return x |   return x | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
| @ -90,12 +90,12 @@ startSketchOn('XZ') | |||||||
|   |> startProfileAt(origin, %) |   |> startProfileAt(origin, %) | ||||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) |   |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||||
|   |> angledLine([ |   |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %) - 90, |        segAng(rectangleSegmentA001) - 90, | ||||||
|        196.99 |        196.99 | ||||||
|      ], %, $rectangleSegmentB001) |      ], %, $rectangleSegmentB001) | ||||||
|   |> angledLine([ |   |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %), |        segAng(rectangleSegmentA001), | ||||||
|        -segLen(rectangleSegmentA001, %) |        -segLen(rectangleSegmentA001) | ||||||
|      ], %, $rectangleSegmentC001) |      ], %, $rectangleSegmentC001) | ||||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) |   |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||||
|   |> close(%) |   |> close(%) | ||||||
| @ -118,20 +118,20 @@ use the tag `rectangleSegmentA001` in any function or expression in the file. | |||||||
| However if the code was written like this: | However if the code was written like this: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| fn rect = (origin) => { | fn rect(origin) { | ||||||
|   return startSketchOn('XZ') |   return startSketchOn('XZ') | ||||||
|   |> startProfileAt(origin, %) |     |> startProfileAt(origin, %) | ||||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) |     |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||||
|   |> angledLine([ |     |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %) - 90, |          segAng(rectangleSegmentA001) - 90, | ||||||
|        196.99 |          196.99 | ||||||
|      ], %, $rectangleSegmentB001) |        ], %, $rectangleSegmentB001) | ||||||
|   |> angledLine([ |     |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %), |          segAng(rectangleSegmentA001), | ||||||
|        -segLen(rectangleSegmentA001, %) |          -segLen(rectangleSegmentA001) | ||||||
|      ], %, $rectangleSegmentC001) |        ], %, $rectangleSegmentC001) | ||||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) |     |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||||
|   |> close(%) |     |> close(%) | ||||||
| } | } | ||||||
|  |  | ||||||
| rect([0, 0]) | rect([0, 0]) | ||||||
| @ -146,28 +146,31 @@ Tags are accessible through the sketch group they are declared in. | |||||||
| For example the following code works. | For example the following code works. | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| fn rect = (origin) => { | fn rect(origin) { | ||||||
|   return startSketchOn('XZ') |   return startSketchOn('XZ') | ||||||
|   |> startProfileAt(origin, %) |     |> startProfileAt(origin, %) | ||||||
|   |> angledLine([0, 191.26], %, $rectangleSegmentA001) |     |> angledLine([0, 191.26], %, $rectangleSegmentA001) | ||||||
|   |> angledLine([ |     |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %) - 90, |          segAng(rectangleSegmentA001) - 90, | ||||||
|        196.99 |          196.99 | ||||||
|      ], %, $rectangleSegmentB001) |        ], %, $rectangleSegmentB001) | ||||||
|   |> angledLine([ |     |> angledLine([ | ||||||
|        segAng(rectangleSegmentA001, %), |          segAng(rectangleSegmentA001), | ||||||
|        -segLen(rectangleSegmentA001, %) |          -segLen(rectangleSegmentA001) | ||||||
|      ], %, $rectangleSegmentC001) |        ], %, $rectangleSegmentC001) | ||||||
|   |> lineTo([profileStartX(%), profileStartY(%)], %) |     |> lineTo([profileStartX(%), profileStartY(%)], %) | ||||||
|   |> close(%) |     |> close(%) | ||||||
| } | } | ||||||
|  |  | ||||||
| rect([0, 0]) | rect([0, 0]) | ||||||
| myRect = rect([20, 0]) | myRect = rect([20, 0]) | ||||||
|  |  | ||||||
| myRect  | myRect | ||||||
|   |> extrude(10, %) |   |> extrude(10, %) | ||||||
|   |> fillet({radius: 0.5, tags: [myRect.tags.rectangleSegmentA001]}, %) |   |> fillet({ | ||||||
|  |        radius = 0.5, | ||||||
|  |        tags = [myRect.tags.rectangleSegmentA001] | ||||||
|  |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| See how we use the tag `rectangleSegmentA001` in the `fillet` function outside | See how we use the tag `rectangleSegmentA001` in the `fillet` function outside | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								docs/kcl/types/ArcToData.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								docs/kcl/types/ArcToData.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | --- | ||||||
|  | title: "ArcToData" | ||||||
|  | excerpt: "Data to draw a three point arc (arcTo)." | ||||||
|  | layout: manual | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Data to draw a three point arc (arcTo). | ||||||
|  |  | ||||||
|  | **Type:** `object` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## Properties | ||||||
|  |  | ||||||
|  | | Property | Type | Description | Required | | ||||||
|  | |----------|------|-------------|----------| | ||||||
|  | | `end` |`[number, number]`| End point of the arc. A point in 3D space | No | | ||||||
|  | | `interior` |`[number, number]`| Interior point of the arc. A point in 3D space | No | | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,161 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "BinaryOperator" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **This schema accepts exactly one of the following:** |  | ||||||
|  |  | ||||||
| Add two numbers. |  | ||||||
|  |  | ||||||
| **enum:** `+` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Subtract two numbers. |  | ||||||
|  |  | ||||||
| **enum:** `-` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Multiply two numbers. |  | ||||||
|  |  | ||||||
| **enum:** `*` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Divide two numbers. |  | ||||||
|  |  | ||||||
| **enum:** `/` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Modulo two numbers. |  | ||||||
|  |  | ||||||
| **enum:** `%` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Raise a number to a power. |  | ||||||
|  |  | ||||||
| **enum:** `^` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Are two numbers equal? |  | ||||||
|  |  | ||||||
| **enum:** `==` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Are two numbers not equal? |  | ||||||
|  |  | ||||||
| **enum:** `!=` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Is left greater than right |  | ||||||
|  |  | ||||||
| **enum:** `>` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Is left greater than or equal to right |  | ||||||
|  |  | ||||||
| **enum:** `>=` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Is left less than right |  | ||||||
|  |  | ||||||
| **enum:** `<` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Is left less than or equal to right |  | ||||||
|  |  | ||||||
| **enum:** `<=` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,161 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "BinaryPart" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **This schema accepts exactly one of the following:** |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `Literal`|  | No | |  | ||||||
| | `value` |[`LiteralValue`](/docs/kcl/types/LiteralValue)|  | No | |  | ||||||
| | `raw` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)|  | No | |  | ||||||
| | `name` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `BinaryExpression`|  | No | |  | ||||||
| | `operator` |[`BinaryOperator`](/docs/kcl/types/BinaryOperator)|  | No | |  | ||||||
| | `left` |[`BinaryPart`](/docs/kcl/types/BinaryPart)|  | No | |  | ||||||
| | `right` |[`BinaryPart`](/docs/kcl/types/BinaryPart)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `CallExpression`|  | No | |  | ||||||
| | `callee` |[`Identifier`](/docs/kcl/types/Identifier)|  | No | |  | ||||||
| | `arguments` |`[` [`Expr`](/docs/kcl/types/Expr) `]`|  | No | |  | ||||||
| | `optional` |`boolean`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `UnaryExpression`|  | No | |  | ||||||
| | `operator` |[`UnaryOperator`](/docs/kcl/types/UnaryOperator)|  | No | |  | ||||||
| | `argument` |[`BinaryPart`](/docs/kcl/types/BinaryPart)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `MemberExpression`|  | No | |  | ||||||
| | `object` |[`MemberObject`](/docs/kcl/types/MemberObject)|  | No | |  | ||||||
| | `property` |[`LiteralIdentifier`](/docs/kcl/types/LiteralIdentifier)|  | No | |  | ||||||
| | `computed` |`boolean`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `IfExpression`|  | No | |  | ||||||
| | `cond` |[`Expr`](/docs/kcl/types/Expr)|  | No | |  | ||||||
| | `then_val` |[`Program`](/docs/kcl/types/Program)|  | No | |  | ||||||
| | `else_ifs` |`[` [`ElseIf`](/docs/kcl/types/ElseIf) `]`|  | No | |  | ||||||
| | `final_else` |[`Program`](/docs/kcl/types/Program)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,97 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "BodyItem" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **This schema accepts exactly one of the following:** |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ImportStatement`|  | No | |  | ||||||
| | `items` |`[` [`ImportItem`](/docs/kcl/types/ImportItem) `]`|  | No | |  | ||||||
| | `path` |`string`|  | No | |  | ||||||
| | `raw_path` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ExpressionStatement`|  | No | |  | ||||||
| | `expression` |[`Expr`](/docs/kcl/types/Expr)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `VariableDeclaration`|  | No | |  | ||||||
| | `declarations` |`[` [`VariableDeclarator`](/docs/kcl/types/VariableDeclarator) `]`|  | No | |  | ||||||
| | `visibility` |[`ItemVisibility`](/docs/kcl/types/ItemVisibility)|  | No | |  | ||||||
| | `kind` |[`VariableKind`](/docs/kcl/types/VariableKind)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ReturnStatement`|  | No | |  | ||||||
| | `argument` |[`Expr`](/docs/kcl/types/Expr)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -16,7 +16,7 @@ Data for a circular pattern on a 2D sketch. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `instances` |[`Uint`](/docs/kcl/types/Uint)| 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. | No | | | `instances` |`integer`| 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. | No | | ||||||
| | `center` |`[number, number]`| The center about which to make the pattern. This is a 2D vector. | No | | | `center` |`[number, number]`| The center about which to make the pattern. This is a 2D vector. | No | | ||||||
| | `arcDegrees` |`number`| The arc angle (in degrees) to place the repetitions. Must be greater than 0. | No | | | `arcDegrees` |`number`| The arc angle (in degrees) to place the repetitions. Must be greater than 0. | No | | ||||||
| | `rotateDuplicates` |`boolean`| Whether or not to rotate the duplicates as they are copied. | No | | | `rotateDuplicates` |`boolean`| Whether or not to rotate the duplicates as they are copied. | No | | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ Data for a circular pattern on a 3D model. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `instances` |[`Uint`](/docs/kcl/types/Uint)| 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. | No | | | `instances` |`integer`| 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. | No | | ||||||
| | `axis` |`[number, number, number]`| The axis around which to make the pattern. This is a 3D vector. | No | | | `axis` |`[number, number, number]`| The axis around which to make the pattern. This is a 3D vector. | No | | ||||||
| | `center` |`[number, number, number]`| The center about which to make the pattern. This is a 3D vector. | No | | | `center` |`[number, number, number]`| The center about which to make the pattern. This is a 3D vector. | No | | ||||||
| | `arcDegrees` |`number`| The arc angle (in degrees) to place the repetitions. Must be greater than 0. | No | | | `arcDegrees` |`number`| The arc angle (in degrees) to place the repetitions. Must be greater than 0. | No | | ||||||
|  | |||||||
| @ -1,41 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "CommentStyle" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **This schema accepts exactly one of the following:** |  | ||||||
|  |  | ||||||
| Like // foo |  | ||||||
|  |  | ||||||
| **enum:** `line` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| Like /* foo */ |  | ||||||
|  |  | ||||||
| **enum:** `block` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,24 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "ElseIf" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `cond` |[`Expr`](/docs/kcl/types/Expr)|  | No | |  | ||||||
| | `then_val` |[`Program`](/docs/kcl/types/Program)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,16 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "EnvironmentRef" |  | ||||||
| excerpt: "An index pointing to an environment." |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| An index pointing to an environment. |  | ||||||
|  |  | ||||||
| **Type:** `integer` (`uint`) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,318 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "Expr" |  | ||||||
| excerpt: "An expression can be evaluated to yield a single KCL value." |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| An expression can be evaluated to yield a single KCL value. |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **This schema accepts exactly one of the following:** |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `Literal`|  | No | |  | ||||||
| | `value` |[`LiteralValue`](/docs/kcl/types/LiteralValue)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `raw` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: [`Identifier`](/docs/kcl/types/Identifier)|  | No | |  | ||||||
| | `name` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: [`TagDeclarator`](/docs/kcl/types#tag-declaration)|  | No | |  | ||||||
| | `value` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `BinaryExpression`|  | No | |  | ||||||
| | `operator` |[`BinaryOperator`](/docs/kcl/types/BinaryOperator)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `left` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `right` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: [`FunctionExpression`](/docs/kcl/types/FunctionExpression)|  | No | |  | ||||||
| | `params` |`[` [`Parameter`](/docs/kcl/types/Parameter) `]`|  | No | |  | ||||||
| | `body` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `CallExpression`|  | No | |  | ||||||
| | `callee` |[`Identifier`](/docs/kcl/types/Identifier)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `arguments` |`[` [`Expr`](/docs/kcl/types/Expr) `]`|  | No | |  | ||||||
| | `optional` |`boolean`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `PipeExpression`|  | No | |  | ||||||
| | `body` |`[` [`Expr`](/docs/kcl/types/Expr) `]`|  | No | |  | ||||||
| | `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `PipeSubstitution`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ArrayExpression`|  | No | |  | ||||||
| | `elements` |`[` [`Expr`](/docs/kcl/types/Expr) `]`|  | No | |  | ||||||
| | `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ArrayRangeExpression`|  | No | |  | ||||||
| | `startElement` |[`Expr`](/docs/kcl/types/Expr)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `endElement` |[`Expr`](/docs/kcl/types/Expr)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `endInclusive` |`boolean`| Is the `end_element` included in the range? | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `ObjectExpression`|  | No | |  | ||||||
| | `properties` |`[` [`ObjectProperty`](/docs/kcl/types/ObjectProperty) `]`|  | No | |  | ||||||
| | `nonCodeMeta` |[`NonCodeMeta`](/docs/kcl/types/NonCodeMeta)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `MemberExpression`|  | No | |  | ||||||
| | `object` |[`MemberObject`](/docs/kcl/types/MemberObject)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `property` |[`LiteralIdentifier`](/docs/kcl/types/LiteralIdentifier)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `computed` |`boolean`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `UnaryExpression`|  | No | |  | ||||||
| | `operator` |[`UnaryOperator`](/docs/kcl/types/UnaryOperator)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `argument` |[`BinaryPart`](/docs/kcl/types/BinaryPart)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `IfExpression`|  | No | |  | ||||||
| | `cond` |[`Expr`](/docs/kcl/types/Expr)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `then_val` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `else_ifs` |`[` [`ElseIf`](/docs/kcl/types/ElseIf) `]`|  | No | |  | ||||||
| | `final_else` |[`Program`](/docs/kcl/types/Program)| An expression can be evaluated to yield a single KCL value. | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
| KCL value for an optional parameter which was not given an argument. (remember, parameters are in the function declaration, arguments are in the function call/application). |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `type` |enum: `None`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,24 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "FunctionExpression" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `params` |`[` [`Parameter`](/docs/kcl/types/Parameter) `]`|  | No | |  | ||||||
| | `body` |[`Program`](/docs/kcl/types/Program)|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "Identifier" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `name` |`string`|  | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -24,7 +24,7 @@ Autodesk Filmbox (FBX) format | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `fbx`|  | No | | | `format` |enum: `fbx`|  | No | | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- | ---- | ||||||
| @ -40,7 +40,7 @@ Binary glTF 2.0. We refer to this as glTF since that is how our customers refer | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `gltf`|  | No | | | `format` |enum: `gltf`|  | No | | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- | ---- | ||||||
| @ -56,7 +56,7 @@ Wavefront OBJ format. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `obj`|  | No | | | `format` |enum: `obj`|  | No | | ||||||
| | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | ||||||
| | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | ||||||
|  |  | ||||||
| @ -74,7 +74,7 @@ The PLY Polygon File Format. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `ply`|  | No | | | `format` |enum: `ply`|  | No | | ||||||
| | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | ||||||
| | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | ||||||
|  |  | ||||||
| @ -92,7 +92,7 @@ SolidWorks part (SLDPRT) format. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `sldprt`|  | No | | | `format` |enum: `sldprt`|  | No | | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- | ---- | ||||||
| @ -108,7 +108,7 @@ ISO 10303-21 (STEP) format. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `step`|  | No | | | `format` |enum: `step`|  | No | | ||||||
|  |  | ||||||
|  |  | ||||||
| ---- | ---- | ||||||
| @ -124,7 +124,7 @@ ST**ereo**L**ithography format. | |||||||
|  |  | ||||||
| | Property | Type | Description | Required | | | Property | Type | Description | Required | | ||||||
| |----------|------|-------------|----------| | |----------|------|-------------|----------| | ||||||
| | `type` |enum: `stl`|  | No | | | `format` |enum: `stl`|  | No | | ||||||
| | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | | `coords` |[`System`](/docs/kcl/types/System)| Co-ordinate system of input data. Defaults to the [KittyCAD co-ordinate system. | No | | ||||||
| | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | | `units` |[`UnitLength`](/docs/kcl/types/UnitLength)| The units of the input data. This is very important for correct scaling and when calculating physics properties like mass, etc. Defaults to millimeters. | No | | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,24 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "ImportItem" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **Type:** `object` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Properties |  | ||||||
|  |  | ||||||
| | Property | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `name` |[`Identifier`](/docs/kcl/types/Identifier)| Name of the item to import. | No | |  | ||||||
| | `alias` |[`Identifier`](/docs/kcl/types/Identifier)| Rename the item using an identifier after "as". | No | |  | ||||||
| | `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`|  | No | |  | ||||||
| | `start` |`integer`|  | No | |  | ||||||
| | `end` |`integer`|  | No | |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -1,16 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "ItemVisibility" |  | ||||||
| excerpt: "" |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
|  |  | ||||||
| **enum:** `default`, `export` |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	