Compare commits
	
		
			60 Commits
		
	
	
		
			pierremtb/
			...
			kcl-53
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 3464f93a30 | |||
| f6936f55d6 | |||
| eef1a28ebb | |||
| 5aed80e930 | |||
| 5654e9daaa | |||
| d443576c7c | |||
| e00317f316 | |||
| c2f1ff67f2 | |||
| 869126e436 | |||
| e8feb0309b | |||
| 06b35b76ff | |||
| 89d1f7f3d3 | |||
| 66b9b501ac | |||
| 9248b2e42d | |||
| 054bb5b500 | |||
| 12b546ea24 | |||
| bc6c40c1e8 | |||
| 1d550da40b | |||
| 9da8574103 | |||
| 2c6404f671 | |||
| 09c6f51141 | |||
| 755c7df59c | |||
| 73b38cd9e2 | |||
| 227cb70d72 | |||
| b36e416ab2 | |||
| 612d03bf73 | |||
| c8ec35cd4a | |||
| 83ca08b26c | |||
| ce98218bf0 | |||
| 2d43399703 | |||
| 461a2c3ab2 | |||
| 79be72c5f0 | |||
| 9ddb4e629f | |||
| 25e8e7081b | |||
| c5164cbee3 | |||
| 809b333248 | |||
| a933646667 | |||
| 98a68f5cd9 | |||
| 33dc254e43 | |||
| b54295f2f7 | |||
| a7e09a89ef | |||
| 4b6166dc4f | |||
| e7d00f148b | |||
| d19a7df7e8 | |||
| 45fae52afc | |||
| 270f173aad | |||
| ddcff1ba63 | |||
| cb1b08d6b6 | |||
| 533fa749b2 | |||
| af492d2cb6 | |||
| 26fba71abf | |||
| 859bfc7b28 | |||
| 3b1d1307c4 | |||
| f5a2c84ce2 | |||
| cccb71fd30 | |||
| 44be072d04 | |||
| 86beb6ebf1 | |||
| 6d72104faa | |||
| f2c5661710 | |||
| ecb2359bc5 | 
| @ -22,6 +22,13 @@ | ||||
|     "rules": { | ||||
|       "@typescript-eslint/no-floating-promises": "error", | ||||
|       "@typescript-eslint/no-misused-promises": "error", | ||||
|       "@typescript-eslint/no-unused-vars": ["error", { | ||||
|         "varsIgnorePattern": "^_", | ||||
|         "argsIgnorePattern": "^_", | ||||
|         "ignoreRestSiblings": true, | ||||
|         "vars": "all", | ||||
|         "args": "none" | ||||
|       }], | ||||
|       "jsx-a11y/click-events-have-key-events": "off", | ||||
|       "jsx-a11y/no-autofocus": "off", | ||||
|       "jsx-a11y/no-noninteractive-element-interactions": "off", | ||||
|  | ||||
							
								
								
									
										4
									
								
								.github/actions/github-release/package.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/actions/github-release/package.json
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,7 @@ | ||||
|   "main": "main.js", | ||||
|   "dependencies": { | ||||
|     "@actions/core": "^1.6", | ||||
|     "@actions/github": "^5.0", | ||||
|     "glob": "^7.1.5" | ||||
|     "@actions/github": "^6.0", | ||||
|     "glob": "^11.0.1" | ||||
|   } | ||||
| } | ||||
|  | ||||
							
								
								
									
										38
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							| @ -4,27 +4,27 @@ | ||||
| set -euo pipefail | ||||
|  | ||||
| if [[ ! -f "test-results/.last-run.json" ]]; then | ||||
|     # if no last run artifact, than run plawright normally | ||||
|     # If no last run artifact, than run Playwright normally | ||||
|     echo "run playwright normally" | ||||
|         if [[ "$3" == *ubuntu* ]]; then | ||||
|             xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --shard=$1/$2 || true | ||||
|         elif [[ "$3" == *windows* ]]; then | ||||
|             yarn test:playwright:electron:windows -- --shard=$1/$2 || true | ||||
|         elif [[ "$3" == *macos* ]]; then | ||||
|             yarn test:playwright:electron:macos  -- --shard=$1/$2 || true | ||||
|         else | ||||
|             echo "Do not run playwright. Unable to detect os runtime." | ||||
|             exit 1 | ||||
|         fi | ||||
|         # # send to axiom | ||||
|         node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|     if [[ "$3" == *ubuntu* ]]; then | ||||
|         xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --shard=$1/$2 || true | ||||
|     elif [[ "$3" == *windows* ]]; then | ||||
|         yarn test:playwright:electron:windows -- --shard=$1/$2 || true | ||||
|     elif [[ "$3" == *macos* ]]; then | ||||
|         yarn test:playwright:electron:macos  -- --shard=$1/$2 || true | ||||
|     else | ||||
|         echo "Do not run Playwright. Unable to detect os runtime." | ||||
|         exit 1 | ||||
|     fi | ||||
|     # Log failures for Axiom to pick up | ||||
|     node playwrightProcess.mjs > /tmp/github-actions.log | ||||
| fi | ||||
|  | ||||
| retry=1 | ||||
| max_retrys=1 | ||||
| max_retries=1 | ||||
|  | ||||
| # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||
| while [[ $retry -le $max_retrys ]]; do | ||||
| # Retry failed tests, doing our own retries because using inbuilt Playwright retries causes connection issues | ||||
| while [[ $retry -le $max_retries ]]; do | ||||
|     if [[ -f "test-results/.last-run.json" ]]; then | ||||
|         failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|         if [[ $failed_tests -gt 0 ]]; then | ||||
| @ -40,8 +40,8 @@ while [[ $retry -le $max_retrys ]]; do | ||||
|                 echo "Do not run playwright. Unable to detect os runtime." | ||||
|                 exit 1 | ||||
|             fi | ||||
|             # send to axiom | ||||
|             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||
|             # Log failures for Axiom to pick up | ||||
|             node playwrightProcess.mjs > /tmp/github-actions.log | ||||
|             retry=$((retry + 1)) | ||||
|         else | ||||
|             echo "retried=false" >>$GITHUB_OUTPUT | ||||
| @ -58,7 +58,7 @@ echo "retried=false" >>$GITHUB_OUTPUT | ||||
| if [[ -f "test-results/.last-run.json" ]]; then | ||||
|     failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||
|     if [[ $failed_tests -gt 0 ]]; then | ||||
|         # if it still fails after 3 retrys, then fail the job | ||||
|         # If it still fails after 3 retries, then fail the job | ||||
|         exit 1 | ||||
|     fi | ||||
| fi | ||||
|  | ||||
							
								
								
									
										33
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							| @ -230,39 +230,6 @@ updates: | ||||
|       update-types: | ||||
|       - minor | ||||
|       - patch | ||||
| - package-ecosystem: pip | ||||
|   directory: /public/kcl-samples | ||||
|   schedule: | ||||
|     interval: weekly | ||||
|     day: monday | ||||
|     time: '03:00' | ||||
|     timezone: America/Los_Angeles | ||||
|   open-pull-requests-limit: 5 | ||||
|   reviewers: | ||||
|   - adamchalmers | ||||
|   - franknoirot | ||||
|   - irev-dev | ||||
|   - jessfraz | ||||
|   groups: | ||||
|     security: | ||||
|       applies-to: security-updates | ||||
|       update-types: | ||||
|       - major | ||||
|       - minor | ||||
|       - patch | ||||
|     patch: | ||||
|       applies-to: version-updates | ||||
|       update-types: | ||||
|       - patch | ||||
|     major: | ||||
|       applies-to: version-updates | ||||
|       update-types: | ||||
|       - major | ||||
|     minor: | ||||
|       applies-to: version-updates | ||||
|       update-types: | ||||
|       - minor | ||||
|       - patch | ||||
| - package-ecosystem: pip | ||||
|   directory: /rust/kcl-python-bindings | ||||
|   schedule: | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/build-and-store-wasm.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-and-store-wasm.yml
									
									
									
									
										vendored
									
									
								
							| @ -24,7 +24,7 @@ jobs: | ||||
|         uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|       - name: Rust Cache | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-apps.yml
									
									
									
									
										vendored
									
									
								
							| @ -77,7 +77,7 @@ jobs: | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|  | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         if: ${{ steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|  | ||||
							
								
								
									
										9
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -100,9 +100,14 @@ jobs: | ||||
|         shell: bash | ||||
|         run: | | ||||
|           set -euo pipefail | ||||
|           cd rust | ||||
|           pushd rust | ||||
|           just overwrite-sim-test kcl_samples | ||||
|           git add kcl-lib/tests | ||||
|           popd | ||||
|           git add \ | ||||
|             rust/kcl-lib/tests \ | ||||
|             public/kcl-samples/manifest.json \ | ||||
|             public/kcl-samples/README.md \ | ||||
|             public/kcl-samples/screenshots | ||||
|           git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||||
|           git config --local user.name "github-actions[bot]" | ||||
|           git remote set-url origin https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git | ||||
|  | ||||
							
								
								
									
										76
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										76
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -75,7 +75,7 @@ jobs: | ||||
|  | ||||
|   prepare-wasm: | ||||
|     # seperate job on Ubuntu to build or fetch the wasm blob once on the fastest runner | ||||
|     runs-on: namespace-profile-ubuntu-8-cores | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     needs: conditions | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
| @ -137,7 +137,7 @@ jobs: | ||||
|         with: | ||||
|           cache: false # Configured below. | ||||
|  | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.wasm.outputs.should-build-wasm == 'true' }} | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
| @ -163,7 +163,7 @@ jobs: | ||||
|  | ||||
|   snapshots: | ||||
|     name: playwright:snapshots:ubuntu | ||||
|     runs-on: namespace-profile-ubuntu-8-cores | ||||
|     runs-on: runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64 | ||||
|     needs: [conditions, prepare-wasm] | ||||
|     steps: | ||||
|       - uses: actions/create-github-app-token@v1 | ||||
| @ -237,19 +237,14 @@ jobs: | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} | ||||
|         with: | ||||
|           name: playwright-report-snapshots-${{ matrix.os }}-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: playwright-report-ubuntu-snapshot-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|           overwrite: true | ||||
|  | ||||
|       - name: Clean up test-results | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} | ||||
|         continue-on-error: true | ||||
|         run: rm -r test-results | ||||
|  | ||||
|       - name: check for changes | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && matrix.os == 'namespace-profile-ubuntu-8-cores' && matrix.shardIndex == 1 && github.ref != 'refs/heads/main' }} | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && github.ref != 'refs/heads/main' }} | ||||
|         shell: bash | ||||
|         id: git-check | ||||
|         run: | | ||||
| @ -270,31 +265,26 @@ jobs: | ||||
|           git fetch origin | ||||
|           echo ${{ github.head_ref }} | ||||
|           git checkout ${{ github.head_ref }} | ||||
|           git commit -m "A snapshot a day keeps the bugs away! 📷🐛 (OS: ${{matrix.os}})" || true | ||||
|           git commit -m "A snapshot a day keeps the bugs away! 📷🐛" || true | ||||
|           git push | ||||
|           git push origin ${{ github.head_ref }} | ||||
|  | ||||
|       # only upload artifacts if there's actually changes | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && steps.git-check.outputs.modified == 'true' }} | ||||
|         with: | ||||
|           name: playwright-report-ubuntu-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|  | ||||
|  | ||||
|   electron: | ||||
|     needs: [conditions, prepare-wasm] | ||||
|     timeout-minutes: 60 | ||||
|     name: playwright:electron:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} | ||||
|     env: | ||||
|       OS_NAME: ${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }} | ||||
|     name: playwright:electron:${{ contains(matrix.os, 'ubuntu') && 'ubuntu' || (contains(matrix.os, 'windows') && 'windows' || 'macos') }}:${{ matrix.shardIndex }}:${{ matrix.shardTotal }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         # TODO: enable namespace-profile-windows-8-cores once available | ||||
|         os: [namespace-profile-ubuntu-8-cores, namespace-profile-macos-8-cores, windows-16-cores] | ||||
|         shardIndex: [1, 2, 3, 4, 5, 6, 7, 8] | ||||
|         shardTotal: [8] | ||||
|         # TODO: enable namespace-profile-windows-latest once available | ||||
|         os: | ||||
|           - "runs-on=${{ github.run_id }}/family=i7ie.2xlarge/image=ubuntu22-full-x64" | ||||
|           - namespace-profile-macos-8-cores | ||||
|           - windows-latest | ||||
|         shardIndex: [1, 2, 3, 4] | ||||
|         shardTotal: [4] | ||||
|         # Disable macos and windows tests on hourly e2e tests since we only care | ||||
|         # about server side changes. | ||||
|         # Technique from https://github.com/joaomcteixeira/python-project-skeleton/pull/31/files | ||||
| @ -303,7 +293,7 @@ jobs: | ||||
|         exclude: | ||||
|           - os: namespace-profile-macos-8-cores | ||||
|             isScheduled: true | ||||
|           - os: windows-16-cores | ||||
|           - os: windows-latest | ||||
|             isScheduled: true | ||||
|         # TODO: add ref here for main and latest release tag | ||||
|     runs-on: ${{ matrix.os }} | ||||
| @ -335,6 +325,7 @@ jobs: | ||||
|         run: yarn | ||||
|  | ||||
|       - name: Cache Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         uses: actions/cache@v4 | ||||
|         with: | ||||
|           path: | | ||||
| @ -342,26 +333,35 @@ jobs: | ||||
|           key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} | ||||
|  | ||||
|       - name: Install Playwright Browsers | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: yarn playwright install --with-deps | ||||
|  | ||||
|       - name: Build web | ||||
|         if: needs.conditions.outputs.should-run == 'true' | ||||
|         run: yarn tronb:vite:dev | ||||
|  | ||||
|       - name: Install good sed | ||||
|         if: startsWith(matrix.os, 'macos') | ||||
|       - name: Install vector | ||||
|         if: contains(matrix.os, 'ubuntu') | ||||
|         shell: bash | ||||
|         run: | | ||||
|           brew install gnu-sed | ||||
|           echo "/opt/homebrew/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH | ||||
|  | ||||
|         # TODO: Add back axiom logs | ||||
|           curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | ||||
|           chmod +x /tmp/vector.sh | ||||
|           /tmp/vector.sh -y -no-modify-path | ||||
|           mkdir -p /tmp/vector | ||||
|           cp .github/workflows/vector.toml /tmp/vector.toml | ||||
|           sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | ||||
|           sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | ||||
|           sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | ||||
|           sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | ||||
|           sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | ||||
|           cat /tmp/vector.toml | ||||
|           ${HOME}/.vector/bin/vector --config /tmp/vector.toml & | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && !cancelled() && (success() || failure()) }} | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: test-results/ | ||||
|  | ||||
|       - name: Run playwright/electron flow (with retries) | ||||
| @ -370,8 +370,8 @@ jobs: | ||||
|         uses: nick-fields/retry@v3.0.2 | ||||
|         with: | ||||
|           shell: bash | ||||
|           command: .github/ci-cd-scripts/playwright-electron.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{matrix.os}} | ||||
|           timeout_minutes: 30 | ||||
|           command: .github/ci-cd-scripts/playwright-electron.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{ env.OS_NAME }} | ||||
|           timeout_minutes: 45 | ||||
|           max_attempts: 15 | ||||
|         env: | ||||
|           CI: true | ||||
| @ -384,7 +384,7 @@ jobs: | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} | ||||
|         with: | ||||
|           name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: test-results-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: test-results/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
| @ -393,7 +393,7 @@ jobs: | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         if: ${{ needs.conditions.outputs.should-run == 'true' && always() }} | ||||
|         with: | ||||
|           name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           name: playwright-report-${{ env.OS_NAME }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||
|           path: playwright-report/ | ||||
|           include-hidden-files: true | ||||
|           retention-days: 30 | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/kcl-language-server.yml
									
									
									
									
										vendored
									
									
								
							| @ -376,7 +376,7 @@ jobs: | ||||
|         with: | ||||
|           credentials_json: "${{ secrets.GOOGLE_CLOUD_DL_SA }}" | ||||
|       - name: Set up Cloud SDK | ||||
|         uses: google-github-actions/setup-gcloud@v2.1.2 | ||||
|         uses: google-github-actions/setup-gcloud@v2.1.4 | ||||
|         with: | ||||
|           project_id: kittycadapi | ||||
|       - name: "upload files to gcp" | ||||
|  | ||||
							
								
								
									
										8
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -37,7 +37,7 @@ jobs: | ||||
|           node-version-file: '.nvmrc' | ||||
|           cache: 'yarn' | ||||
|       - run: yarn install | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|       - run: yarn build:wasm | ||||
| @ -57,7 +57,7 @@ jobs: | ||||
|         with: | ||||
|           workspaces: './rust' | ||||
|  | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|       - run: yarn build:wasm | ||||
| @ -100,7 +100,7 @@ jobs: | ||||
|           cache: 'yarn' | ||||
|  | ||||
|       - run: yarn install | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|       - run: yarn build:wasm | ||||
| @ -129,7 +129,7 @@ jobs: | ||||
|           cache: 'yarn' | ||||
|  | ||||
|       - run: yarn install | ||||
|       - uses: taiki-e/install-action@955a6ff1416eae278c9f833008a9beb4b7f9afe3 | ||||
|       - uses: taiki-e/install-action@37bdc826eaedac215f638a96472df572feab0f9b | ||||
|         with: | ||||
|           tool: wasm-pack | ||||
|       - run: yarn build:wasm | ||||
|  | ||||
							
								
								
									
										5
									
								
								.github/workflows/update-dev-branch.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/workflows/update-dev-branch.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,5 +1,8 @@ | ||||
| name: update-dev-branch | ||||
|  | ||||
| # This is used to sync the `dev` branch with the `main` branch to continuously | ||||
| # deploy a second instance of the app to Vercel: https://app.dev.zoo.dev | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
| @ -26,4 +29,4 @@ jobs: | ||||
|           # reset to main | ||||
|           git reset --hard origin/main | ||||
|           # force push it | ||||
|           git push -f origin dev | ||||
|           git push --force origin dev | ||||
|  | ||||
							
								
								
									
										29
									
								
								.github/workflows/update-e2e-branch.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								.github/workflows/update-e2e-branch.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| name: update-e2e-branch | ||||
|  | ||||
| # This is used to sync the `all-e2e` branch with the `main` branch for the | ||||
| # logic in the test utility `orRunWhenFullSuiteEnabled()` that allows all e2e | ||||
| # tests to run on a particular branch to analyze failures metrics in Axiom. | ||||
|  | ||||
| on: | ||||
|   schedule: | ||||
|     - cron: '0 * * * *' # runs every hour | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|  | ||||
| jobs: | ||||
|   update-branch: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - shell: bash | ||||
|         run: | | ||||
|           # checkout our branch | ||||
|           git checkout all-e2e || git checkout -b all-e2e | ||||
|           # fetch origin | ||||
|           git fetch origin | ||||
|           # reset to main | ||||
|           git reset --hard origin/main | ||||
|           # force push it | ||||
|           git push --force origin all-e2e | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -50,6 +50,7 @@ e2e/playwright/**/*.png | ||||
| e2e/playwright/export-snapshots/* | ||||
| !e2e/playwright/export-snapshots/*.png | ||||
| !e2e/playwright/snapshot-tests.spec.ts-snapshots/*.png | ||||
| trace.zip | ||||
|  | ||||
| /public/kcl-samples.zip | ||||
| /public/kcl-samples/.github | ||||
|  | ||||
							
								
								
									
										118
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								Makefile
									
									
									
									
									
								
							| @ -1,12 +1,111 @@ | ||||
| .PHONY: dev | ||||
| .PHONY: all | ||||
| all: install build check | ||||
|  | ||||
| KCL_WASM_LIB_FILES := $(wildcard rust/**/*.rs) | ||||
| TS_SRC := $(wildcard src/**/*.tsx) $(wildcard src/**/*.ts) | ||||
| XSTATE_TYPEGENS := $(wildcard src/machines/*.typegen.ts) | ||||
| ############################################################################### | ||||
| # INSTALL | ||||
|  | ||||
| dev: node_modules public/wasm_lib_bg.wasm $(XSTATE_TYPEGENS) | ||||
| WASM_PACK ?= ~/.cargo/bin/wasm-pack | ||||
|  | ||||
| .PHONY: install | ||||
| install: node_modules/.yarn-integrity $(WASM_PACK) ## Install dependencies | ||||
|  | ||||
| node_modules/.yarn-integrity: package.json yarn.lock | ||||
| 	yarn install | ||||
| 	@ touch $@ | ||||
|  | ||||
| $(WASM_PACK): | ||||
| 	yarn install:rust | ||||
| 	yarn install:wasm-pack:sh | ||||
|  | ||||
| ############################################################################### | ||||
| # BUILD | ||||
|  | ||||
| RUST_SOURCES := $(wildcard rust/*) $(wildcard rust/**/*) | ||||
| TYPESCRIPT_SOURCES := $(wildcard src/**/*.tsx) $(wildcard src/**/*.ts) | ||||
|  | ||||
| .PHONY: build | ||||
| build: build-web build-desktop | ||||
|  | ||||
| .PHONY: build-web | ||||
| build-web: public/kcl_wasm_lib_bg.wasm build/index.html | ||||
|  | ||||
| .PHONY: build-desktop | ||||
| build-desktop: public/kcl_wasm_lib_bg.wasm .vite/build/main.js | ||||
|  | ||||
| public/kcl_wasm_lib_bg.wasm: $(RUST_SOURCES) | ||||
| 	yarn build:wasm | ||||
|  | ||||
| build/index.html: $(TYPESCRIPT_SOURCES) | ||||
| 	yarn build:local | ||||
|  | ||||
| .vite/build/main.js: $(TYPESCRIPT_SOURCES) | ||||
| 	yarn tronb:vite:dev | ||||
|  | ||||
| ############################################################################### | ||||
| # CHECK | ||||
|  | ||||
| .PHONY: check | ||||
| check: format lint | ||||
|  | ||||
| .PHONY: format | ||||
| format: install ## Format the code | ||||
| 	yarn fmt | ||||
|  | ||||
| .PHONY: lint | ||||
| lint: install ## Lint the code | ||||
| 	yarn tsc | ||||
| 	yarn lint | ||||
|  | ||||
| ############################################################################### | ||||
| # RUN | ||||
|  | ||||
| .PHONY: run | ||||
| run: run-web | ||||
|  | ||||
| .PHONY: run-web | ||||
| run-web: install build-web ## Start the web app | ||||
| 	yarn start | ||||
|  | ||||
| .PHONY: run-desktop | ||||
| run-desktop: install build-desktop ## Start the desktop app | ||||
| 	yarn tron:start | ||||
|  | ||||
| ############################################################################### | ||||
| # TEST | ||||
|  | ||||
| GREP ?= "" | ||||
|  | ||||
| .PHONY: test | ||||
| test: test-unit test-e2e | ||||
|  | ||||
| .PHONY: test-unit | ||||
| test-unit: install ## Run the unit tests | ||||
| 	@ nc -z localhost 3000 || ( echo "Error: localhost:3000 not available, 'make run-web' first" && exit 1 ) | ||||
| 	yarn test:unit | ||||
|  | ||||
| .PHONY: test-e2e | ||||
| test-e2e: install build-desktop ## Run the e2e tests | ||||
| 	yarn test:playwright:electron --workers=1 --grep=$(GREP) | ||||
|  | ||||
| ############################################################################### | ||||
| # CLEAN | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: ## Delete all artifacts | ||||
| 	rm -rf .vite/ build/ | ||||
| 	rm -rf trace.zip playwright-report/ test-results/ | ||||
| 	rm -rf public/kcl_wasm_lib_bg.wasm | ||||
| 	rm -rf rust/*/bindings/ rust/*/pkg/ rust/target/ | ||||
| 	rm -rf node_modules/ rust/*/node_modules/ | ||||
|  | ||||
| .PHONY: help | ||||
| help: install | ||||
| 	@ grep -E '^[^[:space:]]+:.*## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}' | ||||
|  | ||||
| .DEFAULT_GOAL := help | ||||
|  | ||||
| ############################################################################### | ||||
|  | ||||
| # I'm sorry this is so specific to my setup you may as well ignore this. | ||||
| # This is so you don't have to deal with electron windows popping up constantly. | ||||
| # It should work for you other Linux users. | ||||
| @ -14,12 +113,3 @@ lee-electron-test: | ||||
| 	Xephyr -br -ac -noreset -screen 1200x500 :2 & | ||||
| 	DISPLAY=:2 NODE_ENV=development PW_TEST_CONNECT_WS_ENDPOINT=ws://127.0.0.1:4444/ yarn tron:test -g "when using the file tree" | ||||
| 	killall Xephyr | ||||
|  | ||||
| $(XSTATE_TYPEGENS): $(TS_SRC) | ||||
| 	yarn xstate typegen 'src/**/*.ts?(x)' | ||||
|  | ||||
| public/kcl_wasm_lib_bg.wasm: $(KCL_WASM_LIB_FILES) | ||||
| 	yarn build:wasm | ||||
|  | ||||
| node_modules: package.json yarn.lock | ||||
| 	yarn install | ||||
|  | ||||
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							| @ -105,7 +105,7 @@ Finally, to run the web app only, run: | ||||
| yarn start | ||||
| ``` | ||||
|  | ||||
| If you're not a Zoo employee you won't be able to access the dev environment, you should copy everything from `.env.production` to `.env.development` to make it point to production instead, then when you navigate to `localhost:3000` the easiest way to sign in is to paste `localStorage.setItem('TOKEN_PERSIST_KEY', "your-token-from-https://zoo.dev/account/api-tokens")` replacing the with a real token from https://zoo.dev/account/api-tokens of course, then navigate to localhost:3000 again. Note that navigating to `localhost:3000/signin` removes your token so you will need to set the token again. | ||||
| If you're not a Zoo employee you won't be able to access the dev environment, you should copy everything from `.env.production` to `.env.development.local` to make it point to production instead, then when you navigate to `localhost:3000` the easiest way to sign in is to paste `localStorage.setItem('TOKEN_PERSIST_KEY', "your-token-from-https://zoo.dev/account/api-tokens")` replacing the with a real token from https://zoo.dev/account/api-tokens of course, then navigate to `localhost:3000` again. Note that navigating to `localhost:3000/signin` removes your token so you will need to set the token again. | ||||
|  | ||||
| ### Development environment variables | ||||
|  | ||||
| @ -122,7 +122,7 @@ Third-Party Cookies". | ||||
|  | ||||
| ## Desktop | ||||
|  | ||||
| To spin up the desktop app, `yarn install` and `yarn build:wasm` need to have been done before hand then | ||||
| To spin up the desktop app, `yarn install` and `yarn build:wasm` need to have been done before hand then: | ||||
|  | ||||
| ``` | ||||
| yarn tron:start | ||||
| @ -130,13 +130,13 @@ yarn tron:start | ||||
|  | ||||
| This will start the application and hot-reload on changes. | ||||
|  | ||||
| Devtools can be opened with the usual Cmd-Opt-I (Mac) or Ctrl-Shift-I (Linux and Windows). | ||||
| Devtools can be opened with the usual Command-Option-I (macOS) or Ctrl-Shift-I (Linux and Windows). | ||||
|  | ||||
| To package the app for your platform with electron-builder, run `yarn tronb:package:dev` (or `yarn tronb:package:prod` to point to the .env.production variables) | ||||
| To package the app for your platform with electron-builder, run `yarn tronb:package:dev` (or `yarn tronb:package:prod` to point to the .env.production variables). | ||||
|  | ||||
| ## Checking out commits / Bisecting | ||||
|  | ||||
| Which commands from setup are one off vs need to be run every time? | ||||
| 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: | ||||
|  | ||||
|  | ||||
| @ -33,7 +33,7 @@ abs(num: number): number | ||||
| ```js | ||||
| myAngle = -120 | ||||
|  | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [8, 0]) | ||||
|   |> angledLine({ angle = abs(myAngle), length = 5 }, %) | ||||
|  | ||||
| @ -31,7 +31,7 @@ acos(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = toDegrees(acos(0.5)), | ||||
|  | ||||
| @ -33,7 +33,7 @@ angleToMatchLengthX( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [2, 5], tag = $seg01) | ||||
|   |> angledLineToX([-angleToMatchLengthX(seg01, 7, %), 10], %) | ||||
|  | ||||
| @ -33,7 +33,7 @@ angleToMatchLengthY( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [1, 2], tag = $seg01) | ||||
|   |> angledLine({ | ||||
|  | ||||
| @ -36,7 +36,7 @@ appearance( | ||||
|  | ||||
| ```js | ||||
| // Add color to an extruded solid. | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(endAbsolute = [10, 0]) | ||||
|   |> line(endAbsolute = [0, 10]) | ||||
| @ -52,9 +52,9 @@ example = extrude(exampleSketch, length = 5) | ||||
|  | ||||
| ```js | ||||
| // Add color to a revolved solid. | ||||
| sketch001 = startSketchOn('XY') | ||||
| sketch001 = startSketchOn(XY) | ||||
|   |> circle(center = [15, 0], radius = 5) | ||||
|   |> revolve({ angle = 360, axis = 'y' }, %) | ||||
|   |> revolve(angle = 360, axis = 'y') | ||||
|   |> appearance(color = '#ff0000', metalness = 90, roughness = 90) | ||||
| ``` | ||||
|  | ||||
| @ -63,7 +63,7 @@ sketch001 = startSketchOn('XY') | ||||
| ```js | ||||
| // Add color to different solids. | ||||
| fn cube(center) { | ||||
|   return startSketchOn('XY') | ||||
|   return startSketchOn(XY) | ||||
|     |> startProfileAt([center[0] - 10, center[1] - 10], %) | ||||
|     |> line(endAbsolute = [center[0] + 10, center[1] - 10]) | ||||
|     |> line(endAbsolute = [center[0] + 10, center[1] + 10]) | ||||
| @ -95,7 +95,7 @@ appearance( | ||||
| ```js | ||||
| // You can set the appearance before or after you shell it will yield the same result. | ||||
| // This example shows setting the appearance _after_ the shell. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -112,7 +112,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) | ||||
| ```js | ||||
| // You can set the appearance before or after you shell it will yield the same result. | ||||
| // This example shows setting the appearance _before_ the shell. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -129,7 +129,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) | ||||
| ```js | ||||
| // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. | ||||
| // This example shows _before_ the pattern. | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [0, 2]) | ||||
|   |> line(end = [3, 1]) | ||||
| @ -146,7 +146,7 @@ example = extrude(exampleSketch, length = 1) | ||||
| ```js | ||||
| // Setting the appearance of a 3D pattern can be done _before_ or _after_ the pattern. | ||||
| // This example shows _after_ the pattern. | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [0, 2]) | ||||
|   |> line(end = [3, 1]) | ||||
| @ -162,7 +162,7 @@ example = extrude(exampleSketch, length = 1) | ||||
|  | ||||
| ```js | ||||
| // Color the result of a 2D pattern that was extruded. | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([.5, 25], %) | ||||
|   |> line(end = [0, 5]) | ||||
|   |> line(end = [-1, 0]) | ||||
| @ -184,9 +184,8 @@ example = extrude(exampleSketch, length = 1) | ||||
| ```js | ||||
| // Color the result of a sweep. | ||||
|  | ||||
|  | ||||
| // Create a path for the sweep. | ||||
| sweepPath = startSketchOn('XZ') | ||||
| sweepPath = startSketchOn(XZ) | ||||
|   |> startProfileAt([0.05, 0.05], %) | ||||
|   |> line(end = [0, 7]) | ||||
|   |> tangentialArc({ offset = 90, radius = 5 }, %) | ||||
| @ -194,10 +193,10 @@ sweepPath = startSketchOn('XZ') | ||||
|   |> tangentialArc({ offset = -90, radius = 5 }, %) | ||||
|   |> line(end = [0, 7]) | ||||
|  | ||||
| pipeHole = startSketchOn('XY') | ||||
| pipeHole = startSketchOn(XY) | ||||
|   |> circle(center = [0, 0], radius = 1.5) | ||||
|  | ||||
| sweepSketch = startSketchOn('XY') | ||||
| sweepSketch = startSketchOn(XY) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> hole(pipeHole, %) | ||||
|   |> sweep(path = sweepPath) | ||||
|  | ||||
| @ -31,7 +31,7 @@ asin(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = toDegrees(asin(0.5)), | ||||
|  | ||||
| @ -31,7 +31,7 @@ atan(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = toDegrees(atan(1.25)), | ||||
|  | ||||
| @ -35,7 +35,7 @@ atan2( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = toDegrees(atan2(1.25, 2)), | ||||
|  | ||||
| @ -31,7 +31,7 @@ ceil(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(endAbsolute = [12, 10]) | ||||
|   |> line(end = [ceil(7.02986), 0]) | ||||
|  | ||||
| @ -41,7 +41,7 @@ length = 10 | ||||
| thickness = 1 | ||||
| chamferLength = 2 | ||||
|  | ||||
| mountingPlateSketch = startSketchOn("XY") | ||||
| mountingPlateSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-width / 2, -length / 2], %) | ||||
|   |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) | ||||
|   |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) | ||||
| @ -65,7 +65,7 @@ mountingPlate = extrude(mountingPlateSketch, length = thickness) | ||||
| ```js | ||||
| // Sketch on the face of a chamfer. | ||||
| fn cube(pos, scale) { | ||||
|   sg = startSketchOn('XY') | ||||
|   sg = startSketchOn(XY) | ||||
|     |> startProfileAt(pos, %) | ||||
|     |> line(end = [0, scale]) | ||||
|     |> line(end = [scale, 0]) | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -37,7 +37,7 @@ circleThreePoint( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XY") | ||||
| exampleSketch = startSketchOn(XY) | ||||
|   |> circleThreePoint(p1 = [10, 10], p2 = [20, 8], p3 = [15, 5]) | ||||
|   |> extrude(length = 5) | ||||
| ``` | ||||
|  | ||||
| @ -28,7 +28,7 @@ e(): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ angle = 30, length = 2 * e() ^ 2 }, %) | ||||
|   |> yLine(endAbsolute = 0) | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -42,7 +42,7 @@ length = 10 | ||||
| thickness = 1 | ||||
| filletRadius = 2 | ||||
|  | ||||
| mountingPlateSketch = startSketchOn("XY") | ||||
| mountingPlateSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-width / 2, -length / 2], %) | ||||
|   |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) | ||||
|   |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) | ||||
| @ -69,7 +69,7 @@ length = 10 | ||||
| thickness = 1 | ||||
| filletRadius = 1 | ||||
|  | ||||
| mountingPlateSketch = startSketchOn("XY") | ||||
| mountingPlateSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-width / 2, -length / 2], %) | ||||
|   |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) | ||||
|   |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) | ||||
|  | ||||
| @ -31,7 +31,7 @@ floor(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(endAbsolute = [12, 10]) | ||||
|   |> line(end = [floor(7.02986), 0]) | ||||
|  | ||||
							
								
								
									
										54
									
								
								docs/kcl/getCommonEdge.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								docs/kcl/getCommonEdge.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -27,7 +27,7 @@ getNextAdjacentEdge(tag: TagIdentifier): Uuid | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [10, 0]) | ||||
|   |> angledLine({ angle = 60, length = 10 }, %) | ||||
|  | ||||
| @ -27,7 +27,7 @@ getOppositeEdge(tag: TagIdentifier): Uuid | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [10, 0]) | ||||
|   |> angledLine({ angle = 60, length = 10 }, %) | ||||
|  | ||||
| @ -27,7 +27,7 @@ getPreviousAdjacentEdge(tag: TagIdentifier): Uuid | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [10, 0]) | ||||
|   |> angledLine({ angle = 60, length = 10 }, %) | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -32,7 +32,7 @@ hollow( | ||||
|  | ||||
| ```js | ||||
| // Hollow a basic sketch. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -46,7 +46,7 @@ firstSketch = startSketchOn('XY') | ||||
|  | ||||
| ```js | ||||
| // Hollow a basic sketch. | ||||
| firstSketch = startSketchOn('-XZ') | ||||
| firstSketch = startSketchOn(-XZ) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -61,7 +61,7 @@ firstSketch = startSketchOn('-XZ') | ||||
| ```js | ||||
| // Hollow a sketch on face object. | ||||
| size = 100 | ||||
| case = startSketchOn('-XZ') | ||||
| case = startSketchOn(-XZ) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
|  | ||||
| @ -69,7 +69,7 @@ model = import("tests/inputs/cube.step") | ||||
| ```js | ||||
| import height, buildSketch from "common.kcl" | ||||
|  | ||||
| plane = 'XZ' | ||||
| plane = XZ | ||||
| margin = 2 | ||||
| s1 = buildSketch(plane, [0, 0]) | ||||
| s2 = buildSketch(plane, [0, height() + margin]) | ||||
|  | ||||
| @ -22,8 +22,12 @@ layout: manual | ||||
|   * [`string`](kcl/types/string) | ||||
|   * [`tag`](kcl/types/tag) | ||||
| * **std** | ||||
|   * [`Face`](kcl/types/Face) | ||||
|   * [`HALF_TURN`](kcl/consts/std-HALF_TURN) | ||||
|   * [`Helix`](kcl/types/Helix) | ||||
|   * [`Plane`](kcl/types/Plane) | ||||
|   * [`Point2d`](kcl/types/Point2d) | ||||
|   * [`Point3d`](kcl/types/Point3d) | ||||
|   * [`QUARTER_TURN`](kcl/consts/std-QUARTER_TURN) | ||||
|   * [`Sketch`](kcl/types/Sketch) | ||||
|   * [`Solid`](kcl/types/Solid) | ||||
| @ -65,11 +69,11 @@ layout: manual | ||||
|   * [`fillet`](kcl/fillet) | ||||
|   * [`floor`](kcl/floor) | ||||
|   * [`ft`](kcl/ft) | ||||
|   * [`getCommonEdge`](kcl/getCommonEdge) | ||||
|   * [`getNextAdjacentEdge`](kcl/getNextAdjacentEdge) | ||||
|   * [`getOppositeEdge`](kcl/getOppositeEdge) | ||||
|   * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) | ||||
|   * [`helix`](kcl/helix) | ||||
|   * [`helixRevolutions`](kcl/helixRevolutions) | ||||
|   * [`hole`](kcl/hole) | ||||
|   * [`hollow`](kcl/hollow) | ||||
|   * [`inch`](kcl/inch) | ||||
|  | ||||
| @ -36,7 +36,7 @@ int(num: number): number | ||||
| n = int(ceil(5 / 2)) | ||||
| assertEqual(n, 3, 0.0001, "5/2 = 2.5, rounded up makes 3") | ||||
| // Draw n cylinders. | ||||
| startSketchOn('XZ') | ||||
| startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> extrude(length = 5) | ||||
|   |> patternTransform( | ||||
|  | ||||
							
								
								
									
										50
									
								
								docs/kcl/intersect.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								docs/kcl/intersect.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -27,7 +27,7 @@ lastSegX(sketch: Sketch): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [5, 0]) | ||||
|   |> line(end = [20, 5]) | ||||
|  | ||||
| @ -27,7 +27,7 @@ lastSegY(sketch: Sketch): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [5, 0]) | ||||
|   |> line(end = [20, 5]) | ||||
|  | ||||
| @ -31,7 +31,7 @@ ln(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [ln(100), 15]) | ||||
|   |> line(end = [5, -6]) | ||||
|  | ||||
| @ -15,6 +15,8 @@ loft( | ||||
|   bezApproximateRational: bool, | ||||
|   baseCurveIndex?: integer, | ||||
|   tolerance?: number, | ||||
|   tagStart?: TagDeclarator, | ||||
|   tagEnd?: TagDeclarator, | ||||
| ): Solid | ||||
| ``` | ||||
|  | ||||
| @ -28,6 +30,8 @@ loft( | ||||
| | `bezApproximateRational` | [`bool`](/docs/kcl/types/bool) | Attempt to approximate rational curves (such as arcs) using a bezier. 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. | Yes | | ||||
| | `baseCurveIndex` | `integer` | This can be set to override the automatically determined topological base curve, which is usually the first section encountered. | No | | ||||
| | `tolerance` | [`number`](/docs/kcl/types/number) | Tolerance for the loft operation. | No | | ||||
| | `tagStart` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the start of the loft, i.e. the original sketch | No | | ||||
| | `tagEnd` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the end of the loft, i.e. the last sketch | No | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| @ -38,7 +42,7 @@ loft( | ||||
|  | ||||
| ```js | ||||
| // Loft a square and a triangle. | ||||
| squareSketch = startSketchOn('XY') | ||||
| squareSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -46,7 +50,7 @@ squareSketch = startSketchOn('XY') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| triangleSketch = startSketchOn(offsetPlane('XY', offset = 75)) | ||||
| triangleSketch = startSketchOn(offsetPlane(XY, offset = 75)) | ||||
|   |> startProfileAt([0, 125], %) | ||||
|   |> line(end = [-15, -30]) | ||||
|   |> line(end = [30, 0]) | ||||
| @ -60,7 +64,7 @@ loft([squareSketch, triangleSketch]) | ||||
|  | ||||
| ```js | ||||
| // Loft a square, a circle, and another circle. | ||||
| squareSketch = startSketchOn('XY') | ||||
| squareSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -68,10 +72,10 @@ squareSketch = startSketchOn('XY') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch0 = startSketchOn(offsetPlane('XY', offset = 75)) | ||||
| circleSketch0 = startSketchOn(offsetPlane(XY, offset = 75)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| circleSketch1 = startSketchOn(offsetPlane('XY', offset = 150)) | ||||
| circleSketch1 = startSketchOn(offsetPlane(XY, offset = 150)) | ||||
|   |> circle(center = [0, 100], radius = 20) | ||||
|  | ||||
| loft([ | ||||
| @ -85,7 +89,7 @@ loft([ | ||||
|  | ||||
| ```js | ||||
| // Loft a square, a circle, and another circle with options. | ||||
| squareSketch = startSketchOn('XY') | ||||
| squareSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -93,10 +97,10 @@ squareSketch = startSketchOn('XY') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch0 = startSketchOn(offsetPlane('XY', offset = 75)) | ||||
| circleSketch0 = startSketchOn(offsetPlane(XY, offset = 75)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| circleSketch1 = startSketchOn(offsetPlane('XY', offset = 150)) | ||||
| circleSketch1 = startSketchOn(offsetPlane(XY, offset = 150)) | ||||
|   |> circle(center = [0, 100], radius = 20) | ||||
|  | ||||
| loft( | ||||
|  | ||||
| @ -35,7 +35,7 @@ log( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [log(100, 5), 0]) | ||||
|   |> line(end = [5, 8]) | ||||
|  | ||||
| @ -31,7 +31,7 @@ log10(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [log10(100), 0]) | ||||
|   |> line(end = [5, 8]) | ||||
|  | ||||
| @ -31,7 +31,7 @@ log2(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [log2(100), 0]) | ||||
|   |> line(end = [5, 8]) | ||||
|  | ||||
| @ -33,7 +33,7 @@ map( | ||||
| ```js | ||||
| r = 10 // radius | ||||
| fn drawCircle(id) { | ||||
|   return startSketchOn("XY") | ||||
|   return startSketchOn(XY) | ||||
|     |> circle(center = [id * 2 * r, 0], radius = r) | ||||
| } | ||||
|  | ||||
| @ -49,7 +49,7 @@ circles = map([1..3], drawCircle) | ||||
| r = 10 // radius | ||||
| // Call `map`, using an anonymous function instead of a named one. | ||||
| circles = map([1..3], fn(id) { | ||||
|   return startSketchOn("XY") | ||||
|   return startSketchOn(XY) | ||||
|     |> circle(center = [id * 2 * r, 0], radius = r) | ||||
| }) | ||||
| ``` | ||||
|  | ||||
| @ -31,7 +31,7 @@ max(args: [number]): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = 70, | ||||
|  | ||||
| @ -31,7 +31,7 @@ min(args: [number]): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = 70, | ||||
|  | ||||
| @ -34,7 +34,7 @@ mirror2d( | ||||
|  | ||||
| ```js | ||||
| // Mirror an un-closed sketch across the Y axis. | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 10], %) | ||||
|   |> line(end = [15, 0]) | ||||
|   |> line(end = [-7, -3]) | ||||
| @ -53,7 +53,7 @@ example = extrude(sketch001, length = 10) | ||||
|  | ||||
| ```js | ||||
| // Mirror a un-closed sketch across the Y axis. | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 8.5], %) | ||||
|   |> line(end = [20, -8.5]) | ||||
|   |> line(end = [-20, -8.5]) | ||||
| @ -66,11 +66,11 @@ example = extrude(sketch001, length = 10) | ||||
|  | ||||
| ```js | ||||
| // Mirror a un-closed sketch across an edge. | ||||
| helper001 = startSketchOn('XZ') | ||||
| helper001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [0, 10], tag = $edge001) | ||||
|  | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 8.5], %) | ||||
|   |> line(end = [20, -8.5]) | ||||
|   |> line(end = [-20, -8.5]) | ||||
| @ -83,7 +83,7 @@ sketch001 = startSketchOn('XZ') | ||||
|  | ||||
| ```js | ||||
| // Mirror an un-closed sketch across a custom axis. | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 8.5], %) | ||||
|   |> line(end = [20, -8.5]) | ||||
|   |> line(end = [-20, -8.5]) | ||||
|  | ||||
| @ -32,7 +32,7 @@ offsetPlane( | ||||
|  | ||||
| ```js | ||||
| // Loft a square and a circle on the `XY` plane using offset. | ||||
| squareSketch = startSketchOn('XY') | ||||
| squareSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -40,7 +40,7 @@ squareSketch = startSketchOn('XY') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch = startSketchOn(offsetPlane('XY', offset = 150)) | ||||
| circleSketch = startSketchOn(offsetPlane(XY, offset = 150)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| loft([squareSketch, circleSketch]) | ||||
| @ -50,7 +50,7 @@ loft([squareSketch, circleSketch]) | ||||
|  | ||||
| ```js | ||||
| // Loft a square and a circle on the `XZ` plane using offset. | ||||
| squareSketch = startSketchOn('XZ') | ||||
| squareSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -58,7 +58,7 @@ squareSketch = startSketchOn('XZ') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch = startSketchOn(offsetPlane('XZ', offset = 150)) | ||||
| circleSketch = startSketchOn(offsetPlane(XZ, offset = 150)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| loft([squareSketch, circleSketch]) | ||||
| @ -68,7 +68,7 @@ loft([squareSketch, circleSketch]) | ||||
|  | ||||
| ```js | ||||
| // Loft a square and a circle on the `YZ` plane using offset. | ||||
| squareSketch = startSketchOn('YZ') | ||||
| squareSketch = startSketchOn(YZ) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -76,7 +76,7 @@ squareSketch = startSketchOn('YZ') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch = startSketchOn(offsetPlane('YZ', offset = 150)) | ||||
| circleSketch = startSketchOn(offsetPlane(YZ, offset = 150)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| loft([squareSketch, circleSketch]) | ||||
| @ -86,7 +86,7 @@ loft([squareSketch, circleSketch]) | ||||
|  | ||||
| ```js | ||||
| // Loft a square and a circle on the `-XZ` plane using offset. | ||||
| squareSketch = startSketchOn('-XZ') | ||||
| squareSketch = startSketchOn(-XZ) | ||||
|   |> startProfileAt([-100, 200], %) | ||||
|   |> line(end = [200, 0]) | ||||
|   |> line(end = [0, -200]) | ||||
| @ -94,7 +94,7 @@ squareSketch = startSketchOn('-XZ') | ||||
|   |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) | ||||
|   |> close() | ||||
|  | ||||
| circleSketch = startSketchOn(offsetPlane('-XZ', offset = -150)) | ||||
| circleSketch = startSketchOn(offsetPlane(-XZ, offset = -150)) | ||||
|   |> circle(center = [0, 100], radius = 50) | ||||
|  | ||||
| loft([squareSketch, circleSketch]) | ||||
| @ -104,12 +104,12 @@ loft([squareSketch, circleSketch]) | ||||
|  | ||||
| ```js | ||||
| // A circle on the XY plane | ||||
| startSketchOn("XY") | ||||
| startSketchOn(XY) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> circle(radius = 10, center = [0, 0]) | ||||
|  | ||||
| // Triangle on the plane 4 units above | ||||
| startSketchOn(offsetPlane("XY", offset = 4)) | ||||
| startSketchOn(offsetPlane(XY, offset = 4)) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [10, 0]) | ||||
|   |> line(end = [0, 10]) | ||||
|  | ||||
| @ -39,7 +39,7 @@ patternCircular2d( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([.5, 25], %) | ||||
|   |> line(end = [0, 5]) | ||||
|   |> line(end = [-1, 0]) | ||||
|  | ||||
| @ -41,7 +41,7 @@ patternCircular3d( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 1) | ||||
|  | ||||
| example = extrude(exampleSketch, length = -5) | ||||
|  | ||||
| @ -37,7 +37,7 @@ patternLinear2d( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 1) | ||||
|   |> patternLinear2d(axis = [1, 0], instances = 7, distance = 4) | ||||
|  | ||||
|  | ||||
| @ -37,7 +37,7 @@ patternLinear3d( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [0, 2]) | ||||
|   |> line(end = [3, 1]) | ||||
| @ -53,7 +53,7 @@ example = extrude(exampleSketch, length = 1) | ||||
| ```js | ||||
| // Pattern a whole sketch on face. | ||||
| size = 100 | ||||
| case = startSketchOn('XY') | ||||
| case = startSketchOn(XY) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
| @ -84,7 +84,7 @@ patternLinear3d( | ||||
| ```js | ||||
| // Pattern an object on a face. | ||||
| size = 100 | ||||
| case = startSketchOn('XY') | ||||
| case = startSketchOn(XY) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
|  | ||||
| @ -67,7 +67,7 @@ fn transform(id) { | ||||
| } | ||||
|  | ||||
| // Sketch 4 cylinders. | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> extrude(length = 5) | ||||
|   |> patternTransform(instances = 4, transform = transform) | ||||
| @ -83,7 +83,7 @@ fn transform(id) { | ||||
|   return { translate = [4 * (1 + id), 0, 0] } | ||||
| } | ||||
|  | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> extrude(length = 5) | ||||
|   |> patternTransform(instances = 4, transform = transform) | ||||
| @ -101,7 +101,7 @@ fn cube(length, center) { | ||||
|   p2 = [l + x, l + y] | ||||
|   p3 = [l + x, -l + y] | ||||
|  | ||||
|   return startSketchOn('XY') | ||||
|   return startSketchOn(XY) | ||||
|     |> startProfileAt(p0, %) | ||||
|     |> line(endAbsolute = p1) | ||||
|     |> line(endAbsolute = p2) | ||||
| @ -139,7 +139,7 @@ fn cube(length, center) { | ||||
|   p2 = [l + x, l + y] | ||||
|   p3 = [l + x, -l + y] | ||||
|  | ||||
|   return startSketchOn('XY') | ||||
|   return startSketchOn(XY) | ||||
|     |> startProfileAt(p0, %) | ||||
|     |> line(endAbsolute = p1) | ||||
|     |> line(endAbsolute = p2) | ||||
| @ -182,7 +182,7 @@ fn transform(replicaId) { | ||||
| } | ||||
| // Each layer is just a pretty thin cylinder. | ||||
| fn layer() { | ||||
|   return startSketchOn("XY") | ||||
|   return startSketchOn(XY) | ||||
|     // or some other plane idk | ||||
|     |> circle(center = [0, 0], radius = 1, tag = $tag1) | ||||
|     |> extrude(length = h) | ||||
| @ -203,7 +203,7 @@ fn transform(i) { | ||||
|     { rotation = { angle = 45 * i } } | ||||
|   ] | ||||
| } | ||||
| startSketchOn('XY') | ||||
| startSketchOn(XY) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> polygon({ | ||||
|        radius = 10, | ||||
|  | ||||
| @ -41,7 +41,7 @@ fn transform(id) { | ||||
| } | ||||
|  | ||||
| // Sketch 4 circles. | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> patternTransform2d(instances = 4, transform = transform) | ||||
| ``` | ||||
|  | ||||
| @ -30,7 +30,7 @@ pi(): number | ||||
| ```js | ||||
| circumference = 70 | ||||
|  | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> circle(center = [0, 0], radius = circumference / (2 * pi())) | ||||
|  | ||||
| example = extrude(exampleSketch, length = 5) | ||||
|  | ||||
| @ -27,7 +27,7 @@ polar(data: PolarCoordsData): [number] | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = polar({ angle = 30, length = 5 }), tag = $thing) | ||||
|   |> line(end = [0, 5]) | ||||
|  | ||||
| @ -34,7 +34,7 @@ polygon( | ||||
|  | ||||
| ```js | ||||
| // Create a regular hexagon inscribed in a circle of radius 10 | ||||
| hex = startSketchOn('XY') | ||||
| hex = startSketchOn(XY) | ||||
|   |> polygon({ | ||||
|        radius = 10, | ||||
|        numSides = 6, | ||||
| @ -49,7 +49,7 @@ example = extrude(hex, length = 5) | ||||
|  | ||||
| ```js | ||||
| // Create a square circumscribed around a circle of radius 5 | ||||
| square = startSketchOn('XY') | ||||
| square = startSketchOn(XY) | ||||
|   |> polygon({ | ||||
|        radius = 5.0, | ||||
|        numSides = 4, | ||||
|  | ||||
| @ -35,7 +35,7 @@ pow( | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ angle = 50, length = pow(5, 2) }, %) | ||||
|   |> yLine(endAbsolute = 0) | ||||
|  | ||||
| @ -52,7 +52,6 @@ fn sum(arr): | ||||
|         sumSoFar = add(sumSoFar, i) | ||||
|     return sumSoFar */ | ||||
|  | ||||
|  | ||||
| // We use `assertEqual` to check that our `sum` function gives the | ||||
| // expected result. It's good to check your work! | ||||
| assertEqual(sum([1, 2, 3]), 6, 0.00001, "1 + 2 + 3 summed is 6") | ||||
| @ -83,7 +82,7 @@ fn decagon(radius) { | ||||
|   stepAngle = 1 / 10 * TAU | ||||
|  | ||||
|   // Start the decagon sketch at this point. | ||||
|   startOfDecagonSketch = startSketchOn('XY') | ||||
|   startOfDecagonSketch = startSketchOn(XY) | ||||
|     |> startProfileAt([cos(0) * radius, sin(0) * radius], %) | ||||
|  | ||||
|     // Use a `reduce` to draw the remaining decagon sides. | ||||
| @ -114,7 +113,6 @@ fn decagon(radius): | ||||
|     fullDecagon = partialDecagon // it's now full | ||||
|     return fullDecagon */ | ||||
|  | ||||
|  | ||||
| // Use the `decagon` function declared above, to sketch a decagon with radius 5. | ||||
| decagon(5.0) | ||||
|   |> close() | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -31,7 +31,7 @@ round(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| sketch001 = startSketchOn('XZ') | ||||
| sketch001 = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(endAbsolute = [12, 10]) | ||||
|   |> line(end = [round(7.02986), 0]) | ||||
|  | ||||
| @ -1,10 +1,10 @@ | ||||
| --- | ||||
| title: "scale" | ||||
| excerpt: "Scale a solid." | ||||
| excerpt: "Scale a solid or a sketch." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Scale a solid. | ||||
| Scale a solid or a sketch. | ||||
|  | ||||
| By default the transform is applied in local sketch axis, therefore the origin will not move. | ||||
|  | ||||
| @ -12,10 +12,10 @@ If you want to apply the transform in global space, set `global` to `true`. The | ||||
|  | ||||
| ```js | ||||
| scale( | ||||
|   solids: SolidOrImportedGeometry, | ||||
|   objects: SolidOrSketchOrImportedGeometry, | ||||
|   scale: [number], | ||||
|   global?: bool, | ||||
| ): SolidOrImportedGeometry | ||||
| ): SolidOrSketchOrImportedGeometry | ||||
| ``` | ||||
|  | ||||
|  | ||||
| @ -23,13 +23,13 @@ scale( | ||||
|  | ||||
| | Name | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `solids` | [`SolidOrImportedGeometry`](/docs/kcl/types/SolidOrImportedGeometry) | The solid or set of solids to scale. | Yes | | ||||
| | `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to scale. | Yes | | ||||
| | `scale` | [`[number]`](/docs/kcl/types/number) | The scale factor for the x, y, and z axes. | Yes | | ||||
| | `global` | [`bool`](/docs/kcl/types/bool) | If true, the transform is applied in global space. The origin of the model will move. By default, the transform is applied in local sketch axis, therefore the origin will not move. | No | | ||||
|  | ||||
| ### Returns | ||||
|  | ||||
| [`SolidOrImportedGeometry`](/docs/kcl/types/SolidOrImportedGeometry) - Data for a solid or an imported geometry. | ||||
| [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) - Data for a solid or an imported geometry. | ||||
|  | ||||
|  | ||||
| ### Examples | ||||
| @ -37,9 +37,8 @@ scale( | ||||
| ```js | ||||
| // Scale a pipe. | ||||
|  | ||||
|  | ||||
| // Create a path for the sweep. | ||||
| sweepPath = startSketchOn('XZ') | ||||
| sweepPath = startSketchOn(XZ) | ||||
|   |> startProfileAt([0.05, 0.05], %) | ||||
|   |> line(end = [0, 7]) | ||||
|   |> tangentialArc({ offset = 90, radius = 5 }, %) | ||||
| @ -48,10 +47,10 @@ sweepPath = startSketchOn('XZ') | ||||
|   |> line(end = [0, 7]) | ||||
|  | ||||
| // Create a hole for the pipe. | ||||
| pipeHole = startSketchOn('XY') | ||||
| pipeHole = startSketchOn(XY) | ||||
|   |> circle(center = [0, 0], radius = 1.5) | ||||
|  | ||||
| sweepSketch = startSketchOn('XY') | ||||
| sweepSketch = startSketchOn(XY) | ||||
|   |> circle(center = [0, 0], radius = 2) | ||||
|   |> hole(pipeHole, %) | ||||
|   |> sweep(path = sweepPath) | ||||
| @ -76,7 +75,7 @@ cube | ||||
| // Sweep two sketches along the same path. | ||||
|  | ||||
|  | ||||
| sketch001 = startSketchOn('XY') | ||||
| sketch001 = startSketchOn(XY) | ||||
| rectangleSketch = startProfileAt([-200, 23.86], sketch001) | ||||
|   |> angledLine([0, 73.47], %, $rectangleSegmentA001) | ||||
|   |> angledLine([ | ||||
| @ -92,7 +91,7 @@ rectangleSketch = startProfileAt([-200, 23.86], sketch001) | ||||
|  | ||||
| circleSketch = circle(sketch001, center = [200, -30.29], radius = 32.63) | ||||
|  | ||||
| sketch002 = startSketchOn('YZ') | ||||
| sketch002 = startSketchOn(YZ) | ||||
| sweepPath = startProfileAt([0, 0], sketch002) | ||||
|   |> yLine(length = 231.81) | ||||
|   |> tangentialArc({ radius = 80, offset = -90 }, %) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segAng(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [10, 0]) | ||||
|   |> line(end = [5, 10], tag = $seg01) | ||||
|  | ||||
| @ -28,7 +28,7 @@ segEnd(tag: TagIdentifier): [number] | ||||
|  | ||||
| ```js | ||||
| w = 15 | ||||
| cube = startSketchOn('XY') | ||||
| cube = startSketchOn(XY) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [w, 0], tag = $line1) | ||||
|   |> line(end = [0, w], tag = $line2) | ||||
| @ -38,7 +38,7 @@ cube = startSketchOn('XY') | ||||
|   |> extrude(length = 5) | ||||
|  | ||||
| fn cylinder(radius, tag) { | ||||
|   return startSketchOn('XY') | ||||
|   return startSketchOn(XY) | ||||
|     |> startProfileAt([0, 0], %) | ||||
|     |> circle(radius = radius, center = segEnd(tag)) | ||||
|     |> extrude(length = radius) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segEndX(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [20, 0], tag = $thing) | ||||
|   |> line(end = [0, 5]) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segEndY(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [20, 0]) | ||||
|   |> line(end = [0, 3], tag = $thing) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segLen(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ angle = 60, length = 10 }, %, $thing) | ||||
|   |> tangentialArc({ offset = -120, radius = 5 }, %) | ||||
|  | ||||
| @ -28,7 +28,7 @@ segStart(tag: TagIdentifier): [number] | ||||
|  | ||||
| ```js | ||||
| w = 15 | ||||
| cube = startSketchOn('XY') | ||||
| cube = startSketchOn(XY) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [w, 0], tag = $line1) | ||||
|   |> line(end = [0, w], tag = $line2) | ||||
| @ -38,7 +38,7 @@ cube = startSketchOn('XY') | ||||
|   |> extrude(length = 5) | ||||
|  | ||||
| fn cylinder(radius, tag) { | ||||
|   return startSketchOn('XY') | ||||
|   return startSketchOn(XY) | ||||
|     |> startProfileAt([0, 0], %) | ||||
|     |> circle(radius = radius, center = segStart(tag)) | ||||
|     |> extrude(length = radius) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segStartX(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [20, 0], tag = $thing) | ||||
|   |> line(end = [0, 5]) | ||||
|  | ||||
| @ -27,7 +27,7 @@ segStartY(tag: TagIdentifier): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn('XZ') | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> line(end = [20, 0]) | ||||
|   |> line(end = [0, 3], tag = $thing) | ||||
|  | ||||
| @ -34,7 +34,7 @@ shell( | ||||
|  | ||||
| ```js | ||||
| // Remove the end face for the extrusion. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -50,7 +50,7 @@ shell(firstSketch, faces = ['end'], thickness = 0.25) | ||||
|  | ||||
| ```js | ||||
| // Remove the start face for the extrusion. | ||||
| firstSketch = startSketchOn('-XZ') | ||||
| firstSketch = startSketchOn(-XZ) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -66,7 +66,7 @@ shell(firstSketch, faces = ['start'], thickness = 0.25) | ||||
|  | ||||
| ```js | ||||
| // Remove a tagged face and the end face for the extrusion. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -82,7 +82,7 @@ shell(firstSketch, faces = [myTag], thickness = 0.25) | ||||
|  | ||||
| ```js | ||||
| // Remove multiple faces at once. | ||||
| firstSketch = startSketchOn('XY') | ||||
| firstSketch = startSketchOn(XY) | ||||
|   |> startProfileAt([-12, 12], %) | ||||
|   |> line(end = [24, 0]) | ||||
|   |> line(end = [0, -24]) | ||||
| @ -99,7 +99,7 @@ shell(firstSketch, faces = [myTag, 'end'], thickness = 0.25) | ||||
| ```js | ||||
| // Shell a sketch on face. | ||||
| size = 100 | ||||
| case = startSketchOn('-XZ') | ||||
| case = startSketchOn(-XZ) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
| @ -124,7 +124,7 @@ shell(case, faces = ['start'], thickness = 5) | ||||
| ```js | ||||
| // Shell a sketch on face object on the end face. | ||||
| size = 100 | ||||
| case = startSketchOn('XY') | ||||
| case = startSketchOn(XY) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
| @ -152,7 +152,7 @@ shell(thing1, faces = ['end'], thickness = 5) | ||||
|  | ||||
|  | ||||
| size = 100 | ||||
| case = startSketchOn('XY') | ||||
| case = startSketchOn(XY) | ||||
|   |> startProfileAt([-size, -size], %) | ||||
|   |> line(end = [2 * size, 0]) | ||||
|   |> line(end = [0, 2 * size]) | ||||
|  | ||||
| @ -31,7 +31,7 @@ sqrt(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ angle = 50, length = sqrt(2500) }, %) | ||||
|   |> yLine(endAbsolute = 0) | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										32512
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
							
						
						
									
										32512
									
								
								docs/kcl/std.json
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										56
									
								
								docs/kcl/subtract.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								docs/kcl/subtract.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -28,7 +28,7 @@ tau(): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ angle = 50, length = 10 * tau() }, %) | ||||
|   |> yLine(endAbsolute = 0) | ||||
|  | ||||
| @ -31,7 +31,7 @@ toDegrees(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = 50, | ||||
|  | ||||
| @ -31,7 +31,7 @@ toRadians(num: number): number | ||||
| ### Examples | ||||
|  | ||||
| ```js | ||||
| exampleSketch = startSketchOn("XZ") | ||||
| exampleSketch = startSketchOn(XZ) | ||||
|   |> startProfileAt([0, 0], %) | ||||
|   |> angledLine({ | ||||
|        angle = 50, | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,28 +1,12 @@ | ||||
| --- | ||||
| title: "Face" | ||||
| title: "std::Face" | ||||
| excerpt: "A face." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A face. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `id` |[`string`](/docs/kcl/types/string)| The id of the face. | No | | ||||
| | `artifactId` |[`ArtifactId`](/docs/kcl/types/ArtifactId)| The artifact ID. | No | | ||||
| | `value` |[`string`](/docs/kcl/types/string)| The tag of the face. | No | | ||||
| | `xAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the face's X axis be? | No | | ||||
| | `yAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the face's Y axis be? | No | | ||||
| | `zAxis` |[`Point3d`](/docs/kcl/types/Point3d)| The z-axis (normal). | No | | ||||
| | `solid` |[`Solid`](/docs/kcl/types/Solid)| The solid the face is on. | No | | ||||
| | `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,26 +1,12 @@ | ||||
| --- | ||||
| title: "Helix" | ||||
| title: "std::Helix" | ||||
| excerpt: "A helix." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A helix. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `value` |[`string`](/docs/kcl/types/string)| The id of the helix. | No | | ||||
| | `artifactId` |[`ArtifactId`](/docs/kcl/types/ArtifactId)| The artifact ID. | No | | ||||
| | `revolutions` |[`number`](/docs/kcl/types/number)| Number of revolutions. | No | | ||||
| | `angleStart` |[`number`](/docs/kcl/types/number)| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? | No | | ||||
| | `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -21,6 +21,7 @@ A helix. | ||||
| | `revolutions` |[`number`](/docs/kcl/types/number)| Number of revolutions. | No | | ||||
| | `angleStart` |[`number`](/docs/kcl/types/number)| Start angle (in degrees). | No | | ||||
| | `ccw` |`boolean`| Is the helix rotation counter clockwise? | No | | ||||
| | `cylinderId` |[`string`](/docs/kcl/types/string)| The cylinder the helix was created on. | No | | ||||
| | `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -188,7 +188,7 @@ Any KCL value. | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: [`Face`](/docs/kcl/types/Face)|  | No | | ||||
| | `value` |[`Face`](/docs/kcl/types/Face)| A face. | No | | ||||
| | `value` |[`Face`](/docs/kcl/types/Face)|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
| @ -236,7 +236,7 @@ Any KCL value. | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: [`Helix`](/docs/kcl/types/Helix)|  | No | | ||||
| | `value` |[`Helix`](/docs/kcl/types/Helix)| A helix. | No | | ||||
| | `value` |[`Helix`](/docs/kcl/types/Helix)|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
							
								
								
									
										17
									
								
								docs/kcl/types/Point2d.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								docs/kcl/types/Point2d.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| --- | ||||
| title: "std::Point2d" | ||||
| excerpt: "A point in two dimensional space." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A point in two dimensional space. | ||||
|  | ||||
| ```kcl | ||||
| type Point2d = [number; 2] | ||||
| ``` | ||||
|  | ||||
| `Point2d` is an alias for a two-element array of [number](/docs/kcl/types/number)s. To write a value | ||||
| with type `Point2d`, use an array, e.g., `[0, 0]` or `[5.0, 3.14]`. | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -1,22 +1,17 @@ | ||||
| --- | ||||
| title: "Point3d" | ||||
| excerpt: "" | ||||
| title: "std::Point3d" | ||||
| excerpt: "A point in three dimensional space." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| A point in three dimensional space. | ||||
|  | ||||
| **Type:** `object` | ||||
| ```kcl | ||||
| type Point3d = [number; 3] | ||||
| ``` | ||||
|  | ||||
| `Point3d` is an alias for a three-element array of [number](/docs/kcl/types/number)s. To write a value | ||||
| with type `Point3d`, use an array, e.g., `[0, 0, 0]` or `[5.0, 3.14, 6.8]`. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `x` |[`number`](/docs/kcl/types/number)|  | No | | ||||
| | `y` |[`number`](/docs/kcl/types/number)|  | No | | ||||
| | `z` |[`number`](/docs/kcl/types/number)|  | No | | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										66
									
								
								docs/kcl/types/SolidOrSketchOrImportedGeometry.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								docs/kcl/types/SolidOrSketchOrImportedGeometry.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | ||||
| --- | ||||
| title: "SolidOrSketchOrImportedGeometry" | ||||
| excerpt: "Data for a solid or an imported geometry." | ||||
| layout: manual | ||||
| --- | ||||
|  | ||||
| Data for a solid or an imported geometry. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| **This schema accepts exactly one of the following:** | ||||
|  | ||||
| Data for an imported geometry. | ||||
|  | ||||
| **Type:** `object` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: `importedGeometry`|  | No | | ||||
| | `id` |[`string`](/docs/kcl/types/string)| The ID of the imported geometry. | No | | ||||
| | `value` |`[` [`string`](/docs/kcl/types/string) `]`| The original file paths. | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
| **Type:** `[object, array]` | ||||
|  | ||||
| `[` [`Solid`](/docs/kcl/types/Solid) `]` | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: `solidSet`|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
| **Type:** `[object, array]` | ||||
|  | ||||
| `[` [`Sketch`](/docs/kcl/types/Sketch) `]` | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Properties | ||||
|  | ||||
| | Property | Type | Description | Required | | ||||
| |----------|------|-------------|----------| | ||||
| | `type` |enum: `sketchSet`|  | No | | ||||
|  | ||||
|  | ||||
| ---- | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -22,7 +22,6 @@ A path to sweep along. | ||||
|  | ||||
|  | ||||
| ---- | ||||
| A helix. | ||||
|  | ||||
| [`Helix`](/docs/kcl/types/Helix) | ||||
|  | ||||
|  | ||||
							
								
								
									
										50
									
								
								docs/kcl/union.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								docs/kcl/union.md
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -5,6 +5,7 @@ import { | ||||
|   TEST_COLORS, | ||||
|   commonPoints, | ||||
|   PERSIST_MODELING_CONTEXT, | ||||
|   orRunWhenFullSuiteEnabled, | ||||
| } from './test-utils' | ||||
| import { HomePageFixture } from './fixtures/homePageFixture' | ||||
|  | ||||
| @ -46,7 +47,7 @@ async function doBasicSketch( | ||||
|   await page.mouse.click(700, 200) | ||||
|  | ||||
|   if (openPanes.includes('code')) { | ||||
|     await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')`) | ||||
|     await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn(XZ)`) | ||||
|   } | ||||
|   await u.closeDebugPanel() | ||||
|  | ||||
| @ -56,7 +57,7 @@ async function doBasicSketch( | ||||
|   await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10) | ||||
|   if (openPanes.includes('code')) { | ||||
|     await expect(u.codeLocator).toContainText( | ||||
|       `sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` | ||||
|       `sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001)` | ||||
|     ) | ||||
|   } | ||||
|   await page.waitForTimeout(500) | ||||
| @ -65,14 +66,14 @@ async function doBasicSketch( | ||||
|  | ||||
|   if (openPanes.includes('code')) { | ||||
|     await expect(u.codeLocator) | ||||
|       .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${commonPoints.startAt}, sketch001) | ||||
|       .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${commonPoints.startAt}, sketch001) | ||||
|   |> xLine(length = ${commonPoints.num1})`) | ||||
|   } | ||||
|   await page.waitForTimeout(500) | ||||
|   await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20) | ||||
|   if (openPanes.includes('code')) { | ||||
|     await expect(u.codeLocator) | ||||
|       .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ | ||||
|       .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ | ||||
|       commonPoints.startAt | ||||
|     }, sketch001) | ||||
|   |> xLine(length = ${commonPoints.num1}) | ||||
| @ -84,7 +85,7 @@ async function doBasicSketch( | ||||
|   await page.mouse.click(startXPx, 500 - PUR * 20) | ||||
|   if (openPanes.includes('code')) { | ||||
|     await expect(u.codeLocator) | ||||
|       .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ | ||||
|       .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ | ||||
|       commonPoints.startAt | ||||
|     }, sketch001) | ||||
|   |> xLine(length = ${commonPoints.num1}) | ||||
| @ -144,7 +145,7 @@ async function doBasicSketch( | ||||
|   // Open the code pane. | ||||
|   await u.openKclCodePanel() | ||||
|   await expect(u.codeLocator) | ||||
|     .toHaveText(`sketch001 = startSketchOn('XZ')profile001 = startProfileAt(${ | ||||
|     .toHaveText(`sketch001 = startSketchOn(XZ)profile001 = startProfileAt(${ | ||||
|     commonPoints.startAt | ||||
|   }, sketch001) | ||||
|   |> xLine(length = ${commonPoints.num1}, tag = $seg01) | ||||
| @ -153,7 +154,8 @@ async function doBasicSketch( | ||||
| } | ||||
|  | ||||
| test.describe('Basic sketch', { tag: ['@skipWin'] }, () => { | ||||
|   test.fixme('code pane open at start', async ({ page, homePage }) => { | ||||
|   test('code pane open at start', async ({ page, homePage }) => { | ||||
|     test.fixme(orRunWhenFullSuiteEnabled()) | ||||
|     await doBasicSketch(page, homePage, ['code']) | ||||
|   }) | ||||
|  | ||||
|  | ||||
| @ -46,7 +46,7 @@ test.describe( | ||||
|         }, | ||||
|       } | ||||
|  | ||||
|       const code = `sketch001 = startSketchOn('${plane}')profile001 = startProfileAt([0.91, -1.22], sketch001)` | ||||
|       const code = `sketch001 = startSketchOn(${plane})profile001 = startProfileAt([0.91, -1.22], sketch001)` | ||||
|  | ||||
|       await u.openDebugPanel() | ||||
|  | ||||
|  | ||||
| @ -1,6 +1,9 @@ | ||||
| import { test, expect } from './zoo-test' | ||||
|  | ||||
| import { getUtils, executorInputPath } from './test-utils' | ||||
| import { | ||||
|   orRunWhenFullSuiteEnabled, | ||||
|   getUtils, | ||||
|   executorInputPath, | ||||
| } from './test-utils' | ||||
| import { join } from 'path' | ||||
| import { bracket } from 'lib/exampleKcl' | ||||
| import { TEST_CODE_LONG_WITH_ERROR_OUT_OF_VIEW } from './storageStates' | ||||
| @ -19,7 +22,7 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { | ||||
|       localStorage.setItem( | ||||
|         'persistCode', | ||||
|         `// Extruded Triangle | ||||
|   sketch001 = startSketchOn('XZ') | ||||
|   sketch001 = startSketchOn(XZ) | ||||
|     |> startProfileAt([0, 0], %) | ||||
|     |> line(end = [10, 0]) | ||||
|     |> line(end = [-5, 10]) | ||||
| @ -46,11 +49,12 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { | ||||
|     await expect(codePaneButtonHolder).toContainText('notification') | ||||
|   }) | ||||
|  | ||||
|   test.skip('Opening and closing the code pane will consistently show error diagnostics', async ({ | ||||
|   test('Opening and closing the code pane will consistently show error diagnostics', async ({ | ||||
|     page, | ||||
|     homePage, | ||||
|     editor, | ||||
|   }) => { | ||||
|     test.fixme(orRunWhenFullSuiteEnabled()) | ||||
|     const u = await getUtils(page) | ||||
|  | ||||
|     // Load the app with the working starter code | ||||
| @ -119,45 +123,47 @@ test.describe('Code pane and errors', { tag: ['@skipWin'] }, () => { | ||||
|     await expect(page.locator('.cm-tooltip').first()).toBeVisible() | ||||
|   }) | ||||
|  | ||||
|   test.fixme( | ||||
|     'When error is not in view you can click the badge to scroll to it', | ||||
|     async ({ page, homePage, context }) => { | ||||
|       // Load the app with the working starter code | ||||
|       await context.addInitScript((code) => { | ||||
|         localStorage.setItem('persistCode', code) | ||||
|       }, TEST_CODE_LONG_WITH_ERROR_OUT_OF_VIEW) | ||||
|   test('When error is not in view you can click the badge to scroll to it', async ({ | ||||
|     page, | ||||
|     homePage, | ||||
|     context, | ||||
|   }) => { | ||||
|     test.fixme(orRunWhenFullSuiteEnabled()) | ||||
|     // Load the app with the working starter code | ||||
|     await context.addInitScript((code) => { | ||||
|       localStorage.setItem('persistCode', code) | ||||
|     }, TEST_CODE_LONG_WITH_ERROR_OUT_OF_VIEW) | ||||
|  | ||||
|       await page.setBodyDimensions({ width: 1200, height: 500 }) | ||||
|       await homePage.goToModelingScene() | ||||
|     await page.setBodyDimensions({ width: 1200, height: 500 }) | ||||
|     await homePage.goToModelingScene() | ||||
|  | ||||
|       await page.waitForTimeout(1000) | ||||
|     await page.waitForTimeout(1000) | ||||
|  | ||||
|       // Ensure badge is present | ||||
|       const codePaneButtonHolder = page.locator('#code-button-holder') | ||||
|       await expect(codePaneButtonHolder).toContainText('notification') | ||||
|     // Ensure badge is present | ||||
|     const codePaneButtonHolder = page.locator('#code-button-holder') | ||||
|     await expect(codePaneButtonHolder).toContainText('notification') | ||||
|  | ||||
|       // Ensure we have no errors in the gutter, since error out of view. | ||||
|       await expect(page.locator('.cm-lint-marker-error')).not.toBeVisible() | ||||
|     // Ensure we have no errors in the gutter, since error out of view. | ||||
|     await expect(page.locator('.cm-lint-marker-error')).not.toBeVisible() | ||||
|  | ||||
|       // Click the badge. | ||||
|       const badge = page.locator('#code-badge') | ||||
|       await expect(badge).toBeVisible() | ||||
|       await badge.click() | ||||
|     // Click the badge. | ||||
|     const badge = page.locator('#code-badge') | ||||
|     await expect(badge).toBeVisible() | ||||
|     await badge.click() | ||||
|  | ||||
|       // Ensure we have an error diagnostic. | ||||
|       await expect(page.locator('.cm-lint-marker-error').first()).toBeVisible() | ||||
|     // Ensure we have an error diagnostic. | ||||
|     await expect(page.locator('.cm-lint-marker-error').first()).toBeVisible() | ||||
|  | ||||
|       // Hover over the error to see the error message | ||||
|       await page.hover('.cm-lint-marker-error') | ||||
|       await expect( | ||||
|         page | ||||
|           .getByText( | ||||
|             'Modeling command failed: [ApiError { error_code: InternalEngine, message: "Solid3D revolve failed:  sketch profile must lie entirely on one side of the revolution axis" }]' | ||||
|           ) | ||||
|           .first() | ||||
|       ).toBeVisible() | ||||
|     } | ||||
|   ) | ||||
|     // Hover over the error to see the error message | ||||
|     await page.hover('.cm-lint-marker-error') | ||||
|     await expect( | ||||
|       page | ||||
|         .getByText( | ||||
|           'Modeling command failed: [ApiError { error_code: InternalEngine, message: "Solid3D revolve failed:  sketch profile must lie entirely on one side of the revolution axis" }]' | ||||
|         ) | ||||
|         .first() | ||||
|     ).toBeVisible() | ||||
|   }) | ||||
|  | ||||
|   test('When error is not in view WITH LINTS you can click the badge to scroll to it', async ({ | ||||
|     context, | ||||
|  | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	