Compare commits

..

28 Commits

Author SHA1 Message Date
cbca63c6e0 WIP: Start synchronizing the enableSketchMode call 2025-02-21 16:57:36 -06:00
b3cd5ef3ba Show visible error when updater call fails (#5455)
* Show visible error when updater call fails due to permissions issue
Fixes #3696

* Update comment for consistency
2025-02-21 21:34:19 +00:00
a094995730 KCL: Chamfer and fillet now use keyword arguments (#5389)
Previously:
`|> fillet({ radius = 5, tags = [seg01] }, %)`
Now:
`|> fillet(radius = 5, tags = [seg01])`

Also tweaks the formatter for keyword argument calls slightly.
2025-02-21 20:41:25 +00:00
46b4b01d23 [Refactor] decouple settingsMachine from React (#5142)
* Remove unnecessary console.log

* Create a global appMachine

* Strip authMachine of side-effects

* Replace react-bound authMachine use with XState actor use

* Fix import goof

* Register auth commands directly!

* Don't provide anything to settingsMachine from React

* Remove unecessary async

* Make it possible to load project settings via a sent event, without React

* Make settingsMachine ready to be an actor

* Remove settingsLoader use

* Replace all useSettingsAuthContext use with direct actor use

* Add logic to clear project settings, fmt

* fmt

* Clear and load project settings from routeLoaders, but using actor

* Remove useRefreshSettings

* Restore use of useToken() that wasn't working for some reason

* Migrate useFileSystemWatcher use to RouteProvider

* Surface wasm_bindgen unavailable error to console

* Remove unnecessary use of Jest settings wrappers

* Replace dynamic import with actor.getSnapshot

* Migrate system theme and theme color watching from useEffects to actors/actions

* Migrate cursor color effect

* Remove unused code that is now in RouteProvider

* Migrate route commands registration further down for now, out of SettingsAuthProvider

* Migrate settings command registration out of SettingsAuthProvider.tsx

* Delete SettingsAuthProvider.tsx!

* Remove unused settingsLoader!

* fmt and remove comments

* Use actor for routeLoader

* Fix project read error due to uninitialized WASM

* Fix user settings load error due to uninitialized WASM

* Move settingsActor into appActor as a spawned child

* Trying to fix unit tests

* Remove unused imports and demo window attachments

* fmt

* Fix testing issues caused by circular dependency

* Add `setThemeColor` to a few actions list it was missing from

* fmt

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Fix "Execute AST" action in browser, where currentProject is `undefined`

* Update commands list when currentProject changes

* Fix `clearProjectSettings`, which was passing along non-settings context

* Fix onboarding test that actually needed the onboarding initially dismissed

* Add scrollIntoView to make this test more reliable

* @lf94's feedback I missed

I got distracted by a million other things last week

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Revert "A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)"

This reverts commit 129226c6ef.

* fmt

* revert bad snapshot

* Fix up camera movement test locator

* Fix test that was flipping the user settings without waiting

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-02-21 13:47:36 -05:00
4d1eaf9381 Make Windows elevated perms prompt show app name not description (#5452)
* Change package description to equal title, disable universal installer

* Remove buildUniversalInstaller

* Force build release

* Remove test changes
2025-02-21 16:09:46 +00:00
df3668adc8 Add the runtime value of arguments to operations (#5206) 2025-02-21 10:24:12 -05:00
270781d5cd better testing for making sure we update the cache state on just settings changes (#5445) 2025-02-21 06:08:49 +00:00
96b93f8d51 Review folllow ups (#5444)
* Remove StandardPlane docs

Signed-off-by: Nick Cameron <nrc@ncameron.org>

* Add a struct for encapsualting an f64 and a type

Signed-off-by: Nick Cameron <nrc@ncameron.org>

---------

Signed-off-by: Nick Cameron <nrc@ncameron.org>
2025-02-21 12:36:21 +13:00
59b1c414f0 fix: E2E test assumes codemirror error is present when it is lazy loaded (#5446)
* fix: test is written incorrectly, assumes codemirror has DOM content when it does not

* fix: auto fmt fixes
2025-02-20 23:33:13 +00:00
fd07b8cff5 Fixes to docs (#5440)
* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* clenaup

Signed-off-by: Jess Frazelle <github@jessfraz.com>

---------

Signed-off-by: Jess Frazelle <github@jessfraz.com>
2025-02-20 20:49:27 +00:00
21efb2c0bd Support warning and non-fatal errors when executing (#5431)
* Support warning and non-fatal errors when executing

Signed-off-by: Nick Cameron <nrc@ncameron.org>

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

---------

Signed-off-by: Nick Cameron <nrc@ncameron.org>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-02-21 09:30:44 +13:00
30029a63a1 Fix kcl file opening on Windows (double click) on second instance (#5420)
* WIP: Double-clicking on .kcl file on Windows redirects to the home page if the app is already open
Fixes #5412

* Add deep link test case for linux

* Add mac tests

* Lint and win tests

* Fix e2e tests

* Logs everywhere

* windows weird? yup

* More logzzz maybe it's not windows

* Remove :/// replacement. Add catch log

* Fix and clean up

* FIx lint

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* More lint

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Clean up tests further

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-02-20 15:23:39 -05:00
9f5003cafc Make z-index relation between sketch scene items explicit and colocated (#5435)
* Set up start of semantic z-index layers in tailwind.config.js

* Use first two active semantic z-index layers to fix just this issue
2025-02-20 18:53:35 +00:00
5232e1d40a Bump kcl-samples manifest fallback (#5434)
I think this is going away very soon but I don't want it to annoy
anyone's work in the meantime.
2025-02-20 18:36:22 +00:00
23c25c2b50 Patch test with longer timeout (#5438)
Also adds a TODO with a link to
https://github.com/KittyCAD/modeling-app/issues/5437 to track the
underlying issue
2025-02-20 17:14:43 +00:00
50273c0edc Fix kcl-lib derive-docs version (#5436) 2025-02-20 12:05:36 -05:00
8a03bf50e3 make multiple sketches on same face individually editable (#5430)
make multipl sketches individuall editable
2025-02-20 10:14:35 -05:00
7500ef0065 Declare parts of std in KCL rather than Rust (#5147)
Declare std in KCL
2025-02-20 19:33:21 +13:00
099c48cd63 better docs on solids and sketches (#5428)
* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* fix docs;

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* updates

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* parens

Signed-off-by: Jess Frazelle <github@jessfraz.com>

* parens

Signed-off-by: Jess Frazelle <github@jessfraz.com>

---------

Signed-off-by: Jess Frazelle <github@jessfraz.com>
2025-02-20 03:48:27 +00:00
f35cd3ef26 Generalise and simplify offsetPlane (#5429)
* Generalise and simplify offsetPlane

Signed-off-by: Nick Cameron <nrc@ncameron.org>

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

---------

Signed-off-by: Nick Cameron <nrc@ncameron.org>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-02-20 15:55:29 +13:00
695c432d1e CM KCL: highlight property names, labeled args and annotations (#5386)
* CM KCL: highlight property names in objects

* CM KCL: highlight arg labels in fn calls

* CM KCL: highlight annotations

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

---------

Co-authored-by: Matt Mundell <matt@mundell.me>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-02-20 01:17:18 +00:00
2835665a6a KCL: Script for releasing (#5422) 2025-02-19 16:56:51 -06:00
45707d2974 More numeric types baby steps (#5388)
* Add units to Paths

Signed-off-by: Nick Cameron <nrc@ncameron.org>

* Add some NumericType combination functions

Signed-off-by: Nick Cameron <nrc@ncameron.org>

* Fix docs/json/snippets generation from schemas

Signed-off-by: Nick Cameron <nrc@ncameron.org>

---------

Signed-off-by: Nick Cameron <nrc@ncameron.org>
2025-02-20 10:12:37 +13:00
b2e1d21d45 Add Delete to right-click context menu of feature tree operations (#5302)
* Revert "Revert multi-profile (#4812)"

This reverts commit efe8089b08.

* fix poor 1000ms wait UX

* A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores)

* trigger CI

* Add Rust side artifacts for startSketchOn face or plane (#4834)

* Add Rust side artifacts for startSketchOn face or plane

* move ast digging

---------

Co-authored-by: Kurt Hutten Irev-Dev <k.hutten@protonmail.ch>

* lint

* lint

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-macos-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: windows-16-cores)

* trigger CI

* chore: disabled file watcher which prevents faster file write (#4835)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* partial fixes

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Trigger CI

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Trigger CI

* Fix up all the tests

* Fix partial execution

* wip

* WIP

* wip

* rust changes to make three point confrom to same as others since we're not ready with name params yet

* most of the fix for 3 point circle

* get overlays working for circle three point

* fmt

* fix types

* cargo fmt

* add face codef ref for walls and caps

* fix sketch on face after updates to rust side artifact graph

* some things needed for multi-profile tests

* bad attempts at fixing rust

* more

* more

* fix rust

* more rust fixes

* overlay fix

* remove duplicate test

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* lint and typing

* maybe fix a unit test

* small thing

* WIP: Add Delete right click menu item to Feature Tree
Copying code around
Fixes #5090

* I don't know why it works

* WIP

* fix circ dep

* fix unit test

* fix some tests

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Working deletion machine loo

* Working helix deletion

* Extend deletion to more things

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* fix sweep point-and-click test

* fix more tests and add a fix me

* fix more tests

* fix electron specific test

* tsc

* more test tweaks

* update docs

* commint snaps?

* is clippy happy now?

* clippy again

* test works now without me changing anything big-fixed-itself

* small bug

* make three point have cross hair to make it consistent with othe rtools

* fix up state diagram

* fmt

* add draft point for first click of three point circ

* 1 test for three point circle

* 2 test for three point circle

* clean up

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* remove bad doc comment

* remove test skip

* remove onboarding test changes

* Update src/lang/modifyAst.ts

Co-authored-by: Jonathan Tran <jonnytran@gmail.com>

* Update output from simulation tests

* Fix to use correct source ranges

This also reduces cloning.

* Change back to skipping face cap none and both

* Update output after changing back to skipping none and both

* Fix clippy warning

* fix profile start snap bug

* WIP: migrate to actor

* add path ids to cap

* fix going into edit sketch

* make other startSketchOn's work

* fix snapshot test

* explain function name

* Update src/lib/rectangleTool.ts

Co-authored-by: Frank Noirot <frank@zoo.dev>

* rename error

* remove file tree from diff

* Update src/clientSideScene/segments.ts

Co-authored-by: Frank Noirot <frank@zoo.dev>

* nit

* Continue actor migration

* Prevent double write to KCL code on revolve

* Clean up

* Update output after adding cap-to-path graph edge

* Clean up

* Update machine diag

* Update context menu hotkey class

* Fix edit/select sketch-on-cap via feature tree

* clean up for face codeRef

* fix changing tools part way through circle/rect tools

* fix delete of circle profile

* fix close profiles

* fix closing profile bug (tangentArcTo being ignored)

* remove stale comment

* Delete paths associated with sketch when the sketch plane is deleted

* Add support for deleting sketches on caps (not walls)

* get delet working for walls

* make delet of extrusions work for multi profile

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Delete the sketch statement too on the cap and wall cases

* Don't write to file in `split-sketch-pipe-if-needed` unless necessary

* Don't wait for file write to complete within `updateEditorWithAstAndWriteToFile`
It is already debounced internally. If we await it, we will have to wait for a debounced timeout

* Fix bad conflict resolution

* Fix a few things post merge

* Add guard back, fixing tests

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores)

* Add e2e test

* Working tests on ubuntu

* Another one

* Update src/machines/featureTreeMachine.ts

Co-authored-by: Kurt Hutten <k.hutten@protonmail.ch>

* Fix sketch test
@Irev-Dev's suggestion

---------

Co-authored-by: Kurt Hutten Irev-Dev <k.hutten@protonmail.ch>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: Jonathan Tran <jonnytran@gmail.com>
Co-authored-by: Kevin Nadro <nadr0@users.noreply.github.com>
Co-authored-by: 49lf <ircsurfer33@gmail.com>
Co-authored-by: Frank Noirot <frank@zoo.dev>
Co-authored-by: Frank Noirot <frankjohnson1993@gmail.com>
2025-02-19 18:43:27 +00:00
b98f5605b6 [bugfix] Fix user settings opening (#5414)
* Create .gitattributes

* Fix projectPath URI decoding

* Try to enforce UTF-8 encoding on all files except Windows-specific
scripts

* edit file encoding

* edit gitattributes

* Update kcl-samples

* fmt
2025-02-19 13:31:07 -05:00
c050e03df1 Fix sketch test (#5425)
@Irev-Dev's suggestion
2025-02-19 13:30:53 -05:00
b6fa4325f0 Bump modeling-cmds from 0.2.93 to 0.2.97 (#5327)
* Bump modeling-cmds from 0.2.93 to 0.2.96

Among other things, this switches the default units for imported file
formats to millimeters from meters.

* Fix wasm build error

* Upgrade to the latest modeling-cmds 0.2.97
2025-02-19 10:30:26 -08:00
0804aecc63 Fix typo in error msg (#5411)
Part of https://github.com/KittyCAD/modeling-app/issues/5355
2025-02-19 17:40:17 +00:00
490 changed files with 80032 additions and 31418 deletions

13
.gitattributes vendored Normal file
View File

@ -0,0 +1,13 @@
# Set default behavior to automatically normalize line endings.
* text=auto
# Force batch scripts to always use CRLF line endings so that if a repo is accessed
# in Windows via a file share from Linux, the scripts will work.
*.{cmd,[cC][mM][dD]} text working-tree-encoding=UTF-16LE eol=CRLF
*.{bat,[bB][aA][tT]} text working-tree-encoding=UTF-16LE eol=CRLF
*.{ics,[iI][cC][sS]} text working-tree-encoding=UTF-16LE eol=CRLF
*.{ps1,[iP][sS][1]} text working-tree-encoding=UTF-16LE eol=CRLF
# Force bash scripts to always use LF line endings so that if a repo is accessed
# in Unix via a file share from Windows, the scripts will work.
*.sh text eol=lfol=lf

3
.gitignore vendored
View File

@ -41,9 +41,12 @@ e2e/playwright/playwright-secrets.env
e2e/playwright/temp1.png e2e/playwright/temp1.png
e2e/playwright/temp2.png e2e/playwright/temp2.png
e2e/playwright/temp3.png e2e/playwright/temp3.png
# this will be overridden for specific directories
e2e/playwright/**/*.png
# exports from snapshot-tests.spec.ts "exports of each format should work" # exports from snapshot-tests.spec.ts "exports of each format should work"
e2e/playwright/export-snapshots/* e2e/playwright/export-snapshots/*
!e2e/playwright/export-snapshots/*.png !e2e/playwright/export-snapshots/*.png
!e2e/playwright/snapshot-tests.spec.ts-snapshots/*.png
/kcl-samples /kcl-samples
/test-results/ /test-results/

15
docs/kcl/HALF_TURN.md Normal file
View File

@ -0,0 +1,15 @@
---
title: "HALF_TURN"
excerpt: ""
layout: manual
---
```js
HALF_TURN: number(deg) = 180deg
```

15
docs/kcl/QUARTER_TURN.md Normal file
View File

@ -0,0 +1,15 @@
---
title: "QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
QUARTER_TURN: number(deg) = 90deg
```

View File

@ -0,0 +1,15 @@
---
title: "THREE_QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
THREE_QUARTER_TURN: number(deg) = 270deg
```

15
docs/kcl/ZERO.md Normal file
View File

@ -0,0 +1,15 @@
---
title: "ZERO"
excerpt: ""
layout: manual
---
```js
ZERO: number = 0
```

View File

@ -25,7 +25,7 @@ abs(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ acos(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ angleToMatchLengthX(tag: TagIdentifier, to: number, sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ angleToMatchLengthY(tag: TagIdentifier, to: number, sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ asin(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -22,7 +22,7 @@ assert(data: bool, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -24,7 +24,7 @@ assertEqual(left: number, right: number, epsilon: number, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ assertGreaterThan(left: number, right: number, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ assertGreaterThanOrEq(left: number, right: number, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ assertLessThan(left: number, right: number, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -23,7 +23,7 @@ assertLessThanOrEq(left: number, right: number, message: string) -> ()
### Returns ### Returns
`()` `()`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ atan(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ atan2(y: number, x: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ ceil(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

File diff suppressed because one or more lines are too long

View File

@ -26,7 +26,7 @@ cm() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

32
docs/kcl/const_E.md Normal file

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,15 @@
---
title: "HALF_TURN"
excerpt: ""
layout: manual
---
```js
HALF_TURN: number(deg) = 180deg
```

28
docs/kcl/const_PI.md Normal file

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,15 @@
---
title: "QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
QUARTER_TURN: number(deg) = 90deg
```

32
docs/kcl/const_TAU.md Normal file

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,15 @@
---
title: "THREE_QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
THREE_QUARTER_TURN: number(deg) = 270deg
```

15
docs/kcl/const_ZERO.md Normal file
View File

@ -0,0 +1,15 @@
---
title: "ZERO"
excerpt: ""
layout: manual
---
```js
ZERO: number = 0
```

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,15 @@
---
title: "std::prelude::HALF_TURN"
excerpt: ""
layout: manual
---
```js
std::prelude::HALF_TURN: number(deg) = 180deg
```

View File

@ -0,0 +1,15 @@
---
title: "std::prelude::QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
std::prelude::QUARTER_TURN: number(deg) = 90deg
```

View File

@ -0,0 +1,15 @@
---
title: "std::prelude::THREE_QUARTER_TURN"
excerpt: ""
layout: manual
---
```js
std::prelude::THREE_QUARTER_TURN: number(deg) = 270deg
```

View File

@ -0,0 +1,15 @@
---
title: "std::prelude::ZERO"
excerpt: ""
layout: manual
---
```js
std::prelude::ZERO: number = 0
```

File diff suppressed because one or more lines are too long

View File

@ -4,9 +4,11 @@ excerpt: "Return the value of Eulers number `e`."
layout: manual layout: manual
--- ---
**WARNING:** This function is deprecated.
Return the value of Eulers number `e`. Return the value of Eulers number `e`.
**DEPRECATED** use the constant E
```js ```js
e() -> number e() -> number
@ -20,7 +22,7 @@ e() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

File diff suppressed because one or more lines are too long

View File

@ -25,7 +25,7 @@ floor(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ ft() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

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

View File

@ -82,11 +82,11 @@ helixPath = helix(
length = 10, length = 10,
radius = 5, radius = 5,
axis = { axis = {
custom = { custom = {
axis = [0, 0, 1.0], axis = [0, 0, 1.0],
origin = [0, 0.25, 0] origin = [0, 0.25, 0]
} }
}, },
) )
// Create a spring by sweeping around the helix path. // Create a spring by sweeping around the helix path.

View File

@ -18,11 +18,11 @@ helixRevolutions(data: HelixRevolutionsData, solid: Solid) -> Solid
| Name | Type | Description | Required | | Name | Type | Description | Required |
|----------|------|-------------|----------| |----------|------|-------------|----------|
| `data` | [`HelixRevolutionsData`](/docs/kcl/types/HelixRevolutionsData) | Data for helix revolutions. | Yes | | `data` | [`HelixRevolutionsData`](/docs/kcl/types/HelixRevolutionsData) | Data for helix revolutions. | Yes |
| `solid` | [`Solid`](/docs/kcl/types/Solid) | An solid is a collection of extrude surfaces. | Yes | | `solid` | [`Solid`](/docs/kcl/types/Solid) | A solid is a collection of extrude surfaces. | Yes |
### Returns ### Returns
[`Solid`](/docs/kcl/types/Solid) - An solid is a collection of extrude surfaces. [`Solid`](/docs/kcl/types/Solid) - A solid is a collection of extrude surfaces.
### Examples ### Examples

View File

@ -18,11 +18,11 @@ hollow(thickness: number, solid: Solid) -> Solid
| Name | Type | Description | Required | | Name | Type | Description | Required |
|----------|------|-------------|----------| |----------|------|-------------|----------|
| `thickness` | `number` | | Yes | | `thickness` | `number` | | Yes |
| `solid` | [`Solid`](/docs/kcl/types/Solid) | An solid is a collection of extrude surfaces. | Yes | | `solid` | [`Solid`](/docs/kcl/types/Solid) | A solid is a collection of extrude surfaces. | Yes |
### Returns ### Returns
[`Solid`](/docs/kcl/types/Solid) - An solid is a collection of extrude surfaces. [`Solid`](/docs/kcl/types/Solid) - A solid is a collection of extrude surfaces.
### Examples ### Examples

View File

@ -26,7 +26,7 @@ inch() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -9,110 +9,117 @@ layout: manual
* [Types](kcl/types) * [Types](kcl/types)
* [Modules](kcl/modules) * [Modules](kcl/modules)
* [Known Issues](kcl/KNOWN-ISSUES) * [Known Issues](kcl/KNOWN-ISSUES)
* [`abs`](kcl/abs) * **`std`**
* [`acos`](kcl/acos) * [`abs`](kcl/abs)
* [`angleToMatchLengthX`](kcl/angleToMatchLengthX) * [`acos`](kcl/acos)
* [`angleToMatchLengthY`](kcl/angleToMatchLengthY) * [`angleToMatchLengthX`](kcl/angleToMatchLengthX)
* [`angledLine`](kcl/angledLine) * [`angleToMatchLengthY`](kcl/angleToMatchLengthY)
* [`angledLineOfXLength`](kcl/angledLineOfXLength) * [`angledLine`](kcl/angledLine)
* [`angledLineOfYLength`](kcl/angledLineOfYLength) * [`angledLineOfXLength`](kcl/angledLineOfXLength)
* [`angledLineThatIntersects`](kcl/angledLineThatIntersects) * [`angledLineOfYLength`](kcl/angledLineOfYLength)
* [`angledLineToX`](kcl/angledLineToX) * [`angledLineThatIntersects`](kcl/angledLineThatIntersects)
* [`angledLineToY`](kcl/angledLineToY) * [`angledLineToX`](kcl/angledLineToX)
* [`appearance`](kcl/appearance) * [`angledLineToY`](kcl/angledLineToY)
* [`arc`](kcl/arc) * [`appearance`](kcl/appearance)
* [`arcTo`](kcl/arcTo) * [`arc`](kcl/arc)
* [`asin`](kcl/asin) * [`arcTo`](kcl/arcTo)
* [`assert`](kcl/assert) * [`asin`](kcl/asin)
* [`assertEqual`](kcl/assertEqual) * [`assert`](kcl/assert)
* [`assertGreaterThan`](kcl/assertGreaterThan) * [`assertEqual`](kcl/assertEqual)
* [`assertGreaterThanOrEq`](kcl/assertGreaterThanOrEq) * [`assertGreaterThan`](kcl/assertGreaterThan)
* [`assertLessThan`](kcl/assertLessThan) * [`assertGreaterThanOrEq`](kcl/assertGreaterThanOrEq)
* [`assertLessThanOrEq`](kcl/assertLessThanOrEq) * [`assertLessThan`](kcl/assertLessThan)
* [`atan`](kcl/atan) * [`assertLessThanOrEq`](kcl/assertLessThanOrEq)
* [`atan2`](kcl/atan2) * [`atan`](kcl/atan)
* [`bezierCurve`](kcl/bezierCurve) * [`atan2`](kcl/atan2)
* [`ceil`](kcl/ceil) * [`bezierCurve`](kcl/bezierCurve)
* [`chamfer`](kcl/chamfer) * [`ceil`](kcl/ceil)
* [`circle`](kcl/circle) * [`chamfer`](kcl/chamfer)
* [`circleThreePoint`](kcl/circleThreePoint) * [`circle`](kcl/circle)
* [`close`](kcl/close) * [`circleThreePoint`](kcl/circleThreePoint)
* [`cm`](kcl/cm) * [`close`](kcl/close)
* [`cos`](kcl/cos) * [`cm`](kcl/cm)
* [`e`](kcl/e) * [`extrude`](kcl/extrude)
* [`extrude`](kcl/extrude) * [`fillet`](kcl/fillet)
* [`fillet`](kcl/fillet) * [`floor`](kcl/floor)
* [`floor`](kcl/floor) * [`ft`](kcl/ft)
* [`ft`](kcl/ft) * [`getNextAdjacentEdge`](kcl/getNextAdjacentEdge)
* [`getNextAdjacentEdge`](kcl/getNextAdjacentEdge) * [`getOppositeEdge`](kcl/getOppositeEdge)
* [`getOppositeEdge`](kcl/getOppositeEdge) * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge)
* [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) * [`helix`](kcl/helix)
* [`helix`](kcl/helix) * [`helixRevolutions`](kcl/helixRevolutions)
* [`helixRevolutions`](kcl/helixRevolutions) * [`hole`](kcl/hole)
* [`hole`](kcl/hole) * [`hollow`](kcl/hollow)
* [`hollow`](kcl/hollow) * [`inch`](kcl/inch)
* [`inch`](kcl/inch) * [`lastSegX`](kcl/lastSegX)
* [`lastSegX`](kcl/lastSegX) * [`lastSegY`](kcl/lastSegY)
* [`lastSegY`](kcl/lastSegY) * [`legAngX`](kcl/legAngX)
* [`legAngX`](kcl/legAngX) * [`legAngY`](kcl/legAngY)
* [`legAngY`](kcl/legAngY) * [`legLen`](kcl/legLen)
* [`legLen`](kcl/legLen) * [`line`](kcl/line)
* [`line`](kcl/line) * [`ln`](kcl/ln)
* [`ln`](kcl/ln) * [`loft`](kcl/loft)
* [`loft`](kcl/loft) * [`log`](kcl/log)
* [`log`](kcl/log) * [`log10`](kcl/log10)
* [`log10`](kcl/log10) * [`log2`](kcl/log2)
* [`log2`](kcl/log2) * [`m`](kcl/m)
* [`m`](kcl/m) * [`map`](kcl/map)
* [`map`](kcl/map) * [`max`](kcl/max)
* [`max`](kcl/max) * [`min`](kcl/min)
* [`min`](kcl/min) * [`mirror2d`](kcl/mirror2d)
* [`mirror2d`](kcl/mirror2d) * [`mm`](kcl/mm)
* [`mm`](kcl/mm) * [`offsetPlane`](kcl/offsetPlane)
* [`offsetPlane`](kcl/offsetPlane) * [`patternCircular2d`](kcl/patternCircular2d)
* [`patternCircular2d`](kcl/patternCircular2d) * [`patternCircular3d`](kcl/patternCircular3d)
* [`patternCircular3d`](kcl/patternCircular3d) * [`patternLinear2d`](kcl/patternLinear2d)
* [`patternLinear2d`](kcl/patternLinear2d) * [`patternLinear3d`](kcl/patternLinear3d)
* [`patternLinear3d`](kcl/patternLinear3d) * [`patternTransform`](kcl/patternTransform)
* [`patternTransform`](kcl/patternTransform) * [`patternTransform2d`](kcl/patternTransform2d)
* [`patternTransform2d`](kcl/patternTransform2d) * [`polar`](kcl/polar)
* [`pi`](kcl/pi) * [`polygon`](kcl/polygon)
* [`polar`](kcl/polar) * [`pop`](kcl/pop)
* [`polygon`](kcl/polygon) * [`pow`](kcl/pow)
* [`pop`](kcl/pop) * [`profileStart`](kcl/profileStart)
* [`pow`](kcl/pow) * [`profileStartX`](kcl/profileStartX)
* [`profileStart`](kcl/profileStart) * [`profileStartY`](kcl/profileStartY)
* [`profileStartX`](kcl/profileStartX) * [`push`](kcl/push)
* [`profileStartY`](kcl/profileStartY) * [`reduce`](kcl/reduce)
* [`push`](kcl/push) * [`rem`](kcl/rem)
* [`reduce`](kcl/reduce) * [`revolve`](kcl/revolve)
* [`rem`](kcl/rem) * [`round`](kcl/round)
* [`revolve`](kcl/revolve) * [`segAng`](kcl/segAng)
* [`round`](kcl/round) * [`segEnd`](kcl/segEnd)
* [`segAng`](kcl/segAng) * [`segEndX`](kcl/segEndX)
* [`segEnd`](kcl/segEnd) * [`segEndY`](kcl/segEndY)
* [`segEndX`](kcl/segEndX) * [`segLen`](kcl/segLen)
* [`segEndY`](kcl/segEndY) * [`segStart`](kcl/segStart)
* [`segLen`](kcl/segLen) * [`segStartX`](kcl/segStartX)
* [`segStart`](kcl/segStart) * [`segStartY`](kcl/segStartY)
* [`segStartX`](kcl/segStartX) * [`shell`](kcl/shell)
* [`segStartY`](kcl/segStartY) * [`sqrt`](kcl/sqrt)
* [`shell`](kcl/shell) * [`startProfileAt`](kcl/startProfileAt)
* [`sin`](kcl/sin) * [`startSketchOn`](kcl/startSketchOn)
* [`sqrt`](kcl/sqrt) * [`sweep`](kcl/sweep)
* [`startProfileAt`](kcl/startProfileAt) * [`tangentToEnd`](kcl/tangentToEnd)
* [`startSketchOn`](kcl/startSketchOn) * [`tangentialArc`](kcl/tangentialArc)
* [`sweep`](kcl/sweep) * [`tangentialArcTo`](kcl/tangentialArcTo)
* [`tan`](kcl/tan) * [`tangentialArcToRelative`](kcl/tangentialArcToRelative)
* [`tangentToEnd`](kcl/tangentToEnd) * [`toDegrees`](kcl/toDegrees)
* [`tangentialArc`](kcl/tangentialArc) * [`toRadians`](kcl/toRadians)
* [`tangentialArcTo`](kcl/tangentialArcTo) * [`xLine`](kcl/xLine)
* [`tangentialArcToRelative`](kcl/tangentialArcToRelative) * [`xLineTo`](kcl/xLineTo)
* [`tau`](kcl/tau) * [`yLine`](kcl/yLine)
* [`toDegrees`](kcl/toDegrees) * [`yLineTo`](kcl/yLineTo)
* [`toRadians`](kcl/toRadians) * [`yd`](kcl/yd)
* [`xLine`](kcl/xLine) * **`std::math`**
* [`xLineTo`](kcl/xLineTo) * [`E`](kcl/const_std-math-E)
* [`yLine`](kcl/yLine) * [`PI`](kcl/const_std-math-PI)
* [`yLineTo`](kcl/yLineTo) * [`TAU`](kcl/const_std-math-TAU)
* [`yd`](kcl/yd) * [`cos`](kcl/std-math-cos)
* [`sin`](kcl/std-math-sin)
* [`tan`](kcl/std-math-tan)
* **`std::prelude`**
* [`HALF_TURN`](kcl/const_std-prelude-HALF_TURN)
* [`QUARTER_TURN`](kcl/const_std-prelude-QUARTER_TURN)
* [`THREE_QUARTER_TURN`](kcl/const_std-prelude-THREE_QUARTER_TURN)
* [`ZERO`](kcl/const_std-prelude-ZERO)

File diff suppressed because one or more lines are too long

View File

@ -21,7 +21,7 @@ lastSegX(sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ lastSegY(sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ legAngX(hypotenuse: number, leg: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ legAngY(hypotenuse: number, leg: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ legLen(hypotenuse: number, leg: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ ln(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ loft(sketches: [Sketch], v_degree: NonZeroU32, bez_approximate_rational: bool, b
### Returns ### Returns
[`Solid`](/docs/kcl/types/Solid) - An solid is a collection of extrude surfaces. [`Solid`](/docs/kcl/types/Solid) - A solid is a collection of extrude surfaces.
### Examples ### Examples
@ -95,10 +95,10 @@ circleSketch1 = startSketchOn(offsetPlane('XY', offset = 150))
loft( loft(
[ [
squareSketch, squareSketch,
circleSketch0, circleSketch0,
circleSketch1 circleSketch1
], ],
baseCurveIndex = 0, baseCurveIndex = 0,
bezApproximateRational = false, bezApproximateRational = false,
tolerance = 0.000001, tolerance = 0.000001,

View File

@ -26,7 +26,7 @@ log(num: number, base: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ log10(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ log2(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ m() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -22,7 +22,7 @@ map(array: [KclValue], map_fn: FunctionParam) -> [KclValue]
### Returns ### Returns
[`[KclValue]`](/docs/kcl/types/KclValue) [`[KclValue]`](/docs/kcl/types/KclValue)
### Examples ### Examples

View File

@ -25,7 +25,7 @@ max(args: [number]) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -25,7 +25,7 @@ min(args: [number]) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -24,7 +24,7 @@ mirror2d(data: Mirror2dData, sketch_set: SketchSet) -> [Sketch]
### Returns ### Returns
[`[Sketch]`](/docs/kcl/types/Sketch) [`[Sketch]`](/docs/kcl/types/Sketch)
### Examples ### Examples

View File

@ -26,7 +26,7 @@ mm() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -9,7 +9,7 @@ Offset a plane by a distance along its normal.
For example, if you offset the 'XZ' plane by 10, the new plane will be parallel to the 'XZ' plane and 10 units away from it. For example, if you offset the 'XZ' plane by 10, the new plane will be parallel to the 'XZ' plane and 10 units away from it.
```js ```js
offsetPlane(std_plane: StandardPlane, offset: number) -> Plane offsetPlane(plane: PlaneData, offset: number) -> Plane
``` ```
@ -17,7 +17,7 @@ offsetPlane(std_plane: StandardPlane, offset: number) -> Plane
| Name | Type | Description | Required | | Name | Type | Description | Required |
|----------|------|-------------|----------| |----------|------|-------------|----------|
| `std_plane` | [`StandardPlane`](/docs/kcl/types/StandardPlane) | Which standard plane (e.g. XY) should this new plane be created from? | Yes | | `plane` | [`PlaneData`](/docs/kcl/types/PlaneData) | The plane (e.g. 'XY') which this new plane is created from. | Yes |
| `offset` | `number` | Distance from the standard plane this new plane will be created at. | Yes | | `offset` | `number` | Distance from the standard plane this new plane will be created at. | Yes |
### Returns ### Returns

View File

@ -26,7 +26,7 @@ patternCircular2d(sketch_set: SketchSet, instances: integer, center: [number], a
### Returns ### Returns
[`[Sketch]`](/docs/kcl/types/Sketch) [`[Sketch]`](/docs/kcl/types/Sketch)
### Examples ### Examples

View File

@ -27,7 +27,7 @@ patternCircular3d(solid_set: SolidSet, instances: integer, axis: [number], cente
### Returns ### Returns
[`[Solid]`](/docs/kcl/types/Solid) [`[Solid]`](/docs/kcl/types/Solid)
### Examples ### Examples

View File

@ -25,7 +25,7 @@ patternLinear2d(sketch_set: SketchSet, instances: integer, distance: number, axi
### Returns ### Returns
[`[Sketch]`](/docs/kcl/types/Sketch) [`[Sketch]`](/docs/kcl/types/Sketch)
### Examples ### Examples

View File

@ -25,7 +25,7 @@ patternLinear3d(solid_set: SolidSet, instances: integer, distance: number, axis:
### Returns ### Returns
[`[Solid]`](/docs/kcl/types/Solid) [`[Solid]`](/docs/kcl/types/Solid)
### Examples ### Examples

View File

@ -50,7 +50,7 @@ patternTransform(solid_set: SolidSet, instances: integer, transform: FunctionPar
### Returns ### Returns
[`[Solid]`](/docs/kcl/types/Solid) [`[Solid]`](/docs/kcl/types/Solid)
### Examples ### Examples

View File

@ -24,7 +24,7 @@ patternTransform2d(sketch_set: SketchSet, instances: integer, transform: Functio
### Returns ### Returns
[`[Sketch]`](/docs/kcl/types/Sketch) [`[Sketch]`](/docs/kcl/types/Sketch)
### Examples ### Examples

View File

@ -4,9 +4,11 @@ excerpt: "Return the value of `pi`. Archimedes constant (π)."
layout: manual layout: manual
--- ---
**WARNING:** This function is deprecated.
Return the value of `pi`. Archimedes constant (π). Return the value of `pi`. Archimedes constant (π).
**DEPRECATED** use the constant PI
```js ```js
pi() -> number pi() -> number
@ -20,7 +22,7 @@ pi() -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ polar(data: PolarCoordsData) -> [number]
### Returns ### Returns
`[number]` `[number]`
### Examples ### Examples

View File

@ -26,7 +26,7 @@ pow(num: number, pow: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ profileStart(sketch: Sketch) -> [number]
### Returns ### Returns
`[number]` `[number]`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ profileStartX(sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ profileStartY(sketch: Sketch) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -76,7 +76,7 @@ assertEqual(sum, 6, 0.00001, "1 + 2 + 3 summed is 6")
// Declare a function that sketches a decagon. // Declare a function that sketches a decagon.
fn decagon(radius) { fn decagon(radius) {
// Each side of the decagon is turned this many degrees from the previous angle. // Each side of the decagon is turned this many degrees from the previous angle.
stepAngle = 1 / 10 * tau() stepAngle = 1 / 10 * TAU
// Start the decagon sketch at this point. // Start the decagon sketch at this point.
startOfDecagonSketch = startSketchOn('XY') startOfDecagonSketch = startSketchOn('XY')
@ -97,7 +97,7 @@ fn decagon(radius) {
/* The `decagon` above is basically like this pseudo-code: /* The `decagon` above is basically like this pseudo-code:
fn decagon(radius): fn decagon(radius):
stepAngle = (1/10) * tau() stepAngle = (1/10) * TAU
plane = startSketchOn('XY') plane = startSketchOn('XY')
startOfDecagonSketch = startProfileAt([(cos(0)*radius), (sin(0) * radius)], plane) startOfDecagonSketch = startProfileAt([(cos(0)*radius), (sin(0) * radius)], plane)

View File

@ -26,7 +26,7 @@ rem(num: number, divisor: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -24,7 +24,7 @@ revolve(data: RevolveData, sketch: Sketch) -> Solid
### Returns ### Returns
[`Solid`](/docs/kcl/types/Solid) - An solid is a collection of extrude surfaces. [`Solid`](/docs/kcl/types/Solid) - A solid is a collection of extrude surfaces.
### Examples ### Examples

View File

@ -25,7 +25,7 @@ round(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segAng(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segEnd(tag: TagIdentifier) -> [number]
### Returns ### Returns
`[number]` `[number]`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segEndX(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segEndY(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segLen(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segStart(tag: TagIdentifier) -> [number]
### Returns ### Returns
`[number]` `[number]`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segStartX(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -21,7 +21,7 @@ segStartY(tag: TagIdentifier) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

File diff suppressed because one or more lines are too long

View File

@ -25,7 +25,7 @@ sqrt(num: number) -> number
### Returns ### Returns
`number` `number`
### Examples ### Examples

View File

@ -6,7 +6,15 @@ layout: manual
Start a new 2-dimensional sketch on a specific plane or face. Start a new 2-dimensional sketch on a specific plane or face.
### Sketch on Face Behavior
There are some important behaviors to understand when sketching on a face:
The resulting sketch will _include_ the face and thus Solid that was sketched on. So say you were to export the resulting Sketch / Solid from a sketch on a face, you would get both the artifact of the sketch on the face and the parent face / Solid itself.
This is important to understand because if you were to then sketch on the resulting Solid, it would again include the face and parent Solid that was sketched on. This could go on indefinitely.
The point is if you want to export the result of a sketch on a face, you only need to export the final Solid that was created from the sketch on the face, since it will include all the parent faces and Solids.
```js ```js
startSketchOn(data: SketchData, tag?: FaceTag) -> SketchSurface startSketchOn(data: SketchData, tag?: FaceTag) -> SketchSurface

44
docs/kcl/std-math-cos.md Normal file

File diff suppressed because one or more lines are too long

44
docs/kcl/std-math-sin.md Normal file

File diff suppressed because one or more lines are too long

44
docs/kcl/std-math-tan.md Normal file

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

View File

@ -24,7 +24,7 @@ sweep(sketch: Sketch, path: SweepPath, sectional?: bool, tolerance?: number) ->
### Returns ### Returns
[`Solid`](/docs/kcl/types/Solid) - An solid is a collection of extrude surfaces. [`Solid`](/docs/kcl/types/Solid) - A solid is a collection of extrude surfaces.
### Examples ### Examples

File diff suppressed because one or more lines are too long

Some files were not shown because too many files have changed in this diff Show More