diff --git a/docs/kcl-src/known-issues.md b/docs/kcl-src/known-issues.md new file mode 100644 index 000000000..eb3025d07 --- /dev/null +++ b/docs/kcl-src/known-issues.md @@ -0,0 +1,26 @@ +--- +title: "KCL Known Issues" +excerpt: "Known issues with the KCL standard library for the Zoo Design Studio." +layout: manual +--- + +The following are bugs that are not in modeling-app or kcl itself. These bugs +once fixed in engine will just start working here with no language changes. + +- **Sketch on Face**: If your sketch is outside the edges of the face (on which you + are sketching) you will get multiple models returned instead of one single + model for that sketch and its underlying 3D object. + If you see a red line around your model, it means this is happening. + +- **Import**: Right now you can import a file, even if that file has brep data + you cannot edit it, after v1, the engine will account for this. + +- **Fillets**: Fillets cannot intersect, you will get an error. Only simple fillet + cases work currently. + +- **Chamfers**: Chamfers cannot intersect, you will get an error. Only simple + chamfer cases work currently. + +- **Appearance**: Changing the appearance on a loft does not work. + +- **CSG Booleans**: Coplanar (bodies that share a plane) unions, subtractions, and intersections are not currently supported. diff --git a/docs/kcl-src/modules.md b/docs/kcl-src/modules.md new file mode 100644 index 000000000..262780c51 --- /dev/null +++ b/docs/kcl-src/modules.md @@ -0,0 +1,365 @@ +--- +title: "KCL Modules" +excerpt: "Documentation of modules for the KCL language for the Zoo Design Studio." +layout: manual +--- + +`KCL` allows splitting code up into multiple files. Each file is somewhat +isolated from other files as a separate module. + +When you define a function, you can use `export` before it to make it available +to other modules. + +```kcl +// util.kcl +export fn increment(x) { + return x + 1 +} +``` + +Other files in the project can now import functions that have been exported. +This makes them available to use in another file. + +```norun +// main.kcl +import increment from "util.kcl" + +answer = increment(41) +``` + +Imported files _must_ be in the same project so that units are uniform across +modules. This means that it must be in the same directory. + +Import statements must be at the top-level of a file. It is not allowed to have +an `import` statement inside a function or in the body of an if‑else. + +Multiple functions can be exported in a file. + +```kcl +// util.kcl +export fn increment(x) { + return x + 1 +} + +export fn decrement(x) { + return x - 1 +} +``` + +When importing, you can import multiple functions at once. + +```norun +import increment, decrement from "util.kcl" +``` + +Imported symbols can be renamed for convenience or to avoid name collisions. + +```norun +import increment as inc, decrement as dec from "util.kcl" +``` + +--- + +## Functions vs `clone` + +There are two common patterns for re‑using geometry: + +1. **Wrap the construction in a function** – flexible and fully parametric. +2. **Duplicate an existing object with `clone`** – lightning‑fast, but an exact + duplicate. + +### Parametric function example + +```kcl +fn cube(center) { + return startSketchOn(XY) + |> startProfile(at = [center[0] - 10, center[1] - 10]) + |> line(endAbsolute = [center[0] + 10, center[1] - 10]) + |> line(endAbsolute = [center[0] + 10, center[1] + 10]) + |> line(endAbsolute = [center[0] - 10, center[1] + 10]) + |> close() + |> extrude(length = 10) +} + +myCube = cube([0, 0]) +``` + +*Pros* +- Any argument can be a parameter – size, position, appearance, etc. +- Works great inside loops, arrays, or optimisation sweeps. + +*Cons* +- Every invocation rebuilds the entire feature tree. +- **Slower** than a straight duplicate – each call is its own render job. + +### `clone` example + +```kcl +sketch001 = startSketchOn(-XZ) + |> circle(center = [0, 0], radius = 10) + |> extrude(length = 5) + |> appearance(color = "#ff0000", metalness = 90, roughness = 90) + +sketch002 = clone(sketch001) // ✓ instant copy +``` + +*Pros* +- Roughly an O(1) operation – we just duplicate the underlying engine handle. +- Perfect when you need ten identical bolts or two copies of the same imported STEP file. + +*Cons* +- **Not parametric** – the clone is exactly the same shape as the source. +- If you need to tweak dimensions per‑instance, you’re back to a function. + +> **Rule of thumb** – Reach for `clone` when the geometry is already what you want. Reach for a function when you need customisation. + +--- + +## Module‑level parallelism + +Under the hood, the Design Studio runs **every module in parallel** where it can. This means: + +- The top‑level code of `foo.kcl`, `bar.kcl`, and `baz.kcl` all start executing immediately and concurrently. +- Imports that read foreign files (STEP/OBJ/…) overlap their I/O and background render. +- CPU‑bound calculations in separate modules get their own worker threads. + +### Why modules beat one‑big‑file + +If you shoe‑horn everything into `main.kcl`, each statement runs sequentially: + +```norun +import "big.step" as gizmo // blocks main while reading + +gizmo |> translate(x=50) // blocks again while waiting for render +``` + +Split `gizmo` into its own file and the read/render can overlap whatever else `main.kcl` is doing. + +```norun +// gizmo.kcl (worker A) +import "big.step" + +// main.kcl (worker B) +import "gizmo.kcl" as gizmo // non‑blocking + +// ... other setup ... + +gizmo |> translate(x=50) // only blocks here +``` + +### Gotcha: defining but **not** calling functions + +Defining a function inside a module is instantaneous – we just record the byte‑code. The heavy lifting happens when the function is **called**. So: + +```norun +// util.kcl +export fn makeBolt(size) { /* … expensive CAD … */ } +``` + +If `main.kcl` waits until the very end to call `makeBolt`, *none* of that work was parallelised – you’ve pushed the cost back onto the serial tail of your script. + +**Better:** call it early or move the invocation into another module. + +```norun +// bolt_instance.kcl +import makeBolt from "util.kcl" +bolt = makeBolt(5) // executed in parallel +bolt +``` + +Now `main.kcl` can `import "bolt_instance.kcl" as bolt` and get the result that was rendered while it was busy doing other things. + +--- + +## Whole module import + +You can also import the whole module. This is useful if you want to use the +result of a module as a variable, like a part. + +```norun +import "tests/inputs/cube.kcl" as cube +cube + |> translate(x=10) +``` + +This imports the whole module and makes it available as `cube`. You can then +use it like any other object. The `cube` variable is now a reference to the +result of the module. This means that if you change the module, the `cube` +variable will change as well. + +In `cube.kcl`, you cannot have multiple objects. It has to be a single part. If +you have multiple objects, you will get an error. This is because the module is +expected to return a single object that can be used as a variable. + +The last expression or variable definition becomes the module's return value. +The module is expected to return a single object that can be used as a variable +by whatever imports it. + +So for example, this is allowed: + +```norun +... a bunch of code to create cube and cube2 ... + +myUnion = union([cube, cube2]) +``` + +You can also do this: + +```norun +... a bunch of code to create cube and cube2 ... + +union([cube, cube2]) +``` + +Either way, the last line will return the union of the two objects. + +Or what you could do instead is: + +```norun +... a bunch of code to create cube and cube2 ... + +myUnion = union([cube, cube2]) +myUnion +``` + +This will assign the union of the two objects to a variable, and then return it +on the last statement. It's simply another way of doing the same thing. + +The final statement is what's important because it's the return value of the +entire module. The module is expected to return a single object that can be used +as a variable by the file that imports it. + +--- + +## Multiple instances of the same import + +Whether you are importing a file from another CAD system or a KCL file, that +file represents object(s) in memory. If you import the same file multiple times, +it will only be rendered once. + +If you want to have multiple instances of the same object, you can use the +[`clone`](/docs/kcl/clone) function. This will render a new instance of the object in memory. + +```norun +import cube from "tests/inputs/cube.kcl" + +cube + |> translate(x=10) +clone(cube) + |> translate(x=20) +``` + +In the sample above, the `cube` object is imported from a KCL file. The first +instance is translated 10 units in the x direction. The second instance is +cloned and translated 20 units in the x direction. The two instances are now +separate objects in memory, and can be manipulated independently. + +Here is an example with a file from another CAD system: + +```kcl +import "tests/inputs/cube.step" as cube + +cube + |> translate(x=10) +clone(cube) + |> translate(x=20) +``` + +--- + +## Importing files from other CAD systems + +`import` can also be used to import files from other CAD systems. The format of the statement is the +same as for KCL files. You can only import the whole file, not items from it. E.g., + +```norun +import "tests/inputs/cube.obj" + +// Use `cube` just like a KCL object. +``` + +```kcl +import "tests/inputs/cube.sldprt" as cube + +// Use `cube` just like a KCL object. +``` + +For formats lacking unit data (such as STL, OBJ, or PLY files), the default +unit of measurement is millimeters. Alternatively you may specify the unit +by using an attribute. Likewise, you can also specify a coordinate system. E.g., + +```kcl +@(lengthUnit = ft, coords = opengl) +import "tests/inputs/cube.obj" +``` + +When importing a GLTF file, the bin file will be imported as well. + +Import paths are relative to the current project directory. Imports currently only work when +using the native Design Studio, not in the browser. + +### Supported values + +File formats: `fbx`, `gltf`/`glb`, `obj`+, `ply`+, `sldprt`, `step`/`stp`, `stl`+. (Those marked with a +'+' support customising the length unit and coordinate system). + +Length units: `mm` (the default), `cm`, `m`, `inch`, `ft`, `yd`. + +Coordinate systems: + +- `zoo` (the default), forward: -Y, up: +Z, handedness: right +- `opengl`, forward: +Z, up: +Y, handedness: right +- `vulkan`, forward: +Z, up: -Y, handedness: left + +--- + +## Performance deep‑dive for foreign‑file imports + +Parallelized foreign‑file imports now let you overlap file reads, initialization, +and rendering. To maximize throughput, you need to understand the three distinct +stages—reading, initializing (background render start), and invocation (blocking) +—and structure your code to defer blocking operations until the end. + +### Foreign import execution stages + +1. **Import (Read / Initialization) Stage** + ```kcl + import "tests/inputs/cube.step" as cube + ``` + - Reads the file from disk and makes its API available. + - Starts engine rendering but **does not block** your script. + - This kick‑starts the render pipeline while you keep executing other code. + +2. **Invocation (Blocking) Stage** + ```kcl + import "tests/inputs/cube.step" as cube + + cube + |> translate(z=10) // ← blocks here only + ``` + - Any method call (e.g., `translate`, `scale`, `rotate`) waits for the background render to finish before applying transformations. + +### Best practices + +#### 1. Defer blocking calls + +```kcl +import "tests/inputs/cube.step" as cube // 1) Read / Background render starts + + +// --- perform other operations and calculations here --- + + +cube + |> translate(z=10) // 2) Blocks only here +``` + +#### 2. Split heavy work into separate modules + +Place computationally expensive or IO‑heavy work into its own module so it can render in parallel while `main.kcl` continues. + +#### Future improvements + +Upcoming releases will auto‑analyse dependencies and only block when truly necessary. Until then, explicit deferral will give you the best performance. + + diff --git a/docs/kcl-src/settings.md b/docs/kcl-src/settings.md new file mode 100644 index 000000000..fef877621 --- /dev/null +++ b/docs/kcl-src/settings.md @@ -0,0 +1,45 @@ +--- +title: "KCL Settings" +excerpt: "Documentation of settings for the KCL language and Zoo Design Studio." +layout: manual +--- + +# KCL Settings + +There are three levels of settings available in Zoo Design Studio: + +1. [User Settings](/docs/kcl/settings-user): Global settings that apply to all projects, stored in `user.toml` +2. [Project Settings](/docs/kcl/settings-project): Settings specific to a project, stored in `project.toml` +3. Per-file Settings: Settings that apply to a single KCL file, specified using the `@settings` attribute + +## Configuration Files + +Zoo Design Studio uses TOML files for configuration: + +* **User Settings**: `user.toml` - See [complete documentation](/docs/kcl/settings-user) +* **Project Settings**: `project.toml` - See [complete documentation](/docs/kcl/settings-project) + +## Per-file settings + +Settings which affect a single file are configured using the settings attribute. +This must be at the top of the KCL file (comments before the attribute are permitted). +For example: + +```kcl +// The settings attribute. +@settings(defaultLengthUnit = in) + +// The rest of your KCL code goes below... + +x = 42 // Represents 42 inches. +``` + +The settings attribute may contain multiple properties separated by commas. +Valid properties are: + +- `defaultLengthUnit`: the default length unit to use for numbers declared in this file. + - Accepted values: `mm`, `cm`, `m`, `in` (inches), `ft` (feet), `yd` (yards). +- `defaultAngleUnit`: the default angle unit to use for numbers declared in this file. + - Accepted values: `deg` (degrees), `rad` (radians). + +These settings override any project-wide settings (configured in project.toml or via the UI). diff --git a/docs/kcl-src/types.md b/docs/kcl-src/types.md new file mode 100644 index 000000000..c1c4ef22f --- /dev/null +++ b/docs/kcl-src/types.md @@ -0,0 +1,299 @@ +--- +title: "KCL Types" +excerpt: "Documentation of types for the KCL standard library for the Zoo Design Studio." +layout: manual +--- + +`KCL` defines the following types and keywords the language. + +All these types can be nested in various forms where nesting applies. Like +arrays can hold objects and vice versa. + +## Constant declaration + +Constants are defined with a name and a value, like so: + +``` +myBool = false +``` + +Currently you cannot redeclare a constant. + +## Arrays + +An array is defined with `[]` braces. What is inside the brackets can +be of any type. For example, the following is completely valid: + +``` +myArray = ["thing", 2, false] +``` + +If you want to get a value from an array you can use the index like so: +`myArray[0]`. + + +## Objects + +An object is defined with `{}` braces. Here is an example object: + +``` +myObj = { a = 0, b = "thing" } +``` + +We support two different ways of getting properties from objects, you can call +`myObj.a` or `myObj["a"]` both work. + +## `ImportedGeometry` + +Using `import` you can import geometry defined using other CAD software. In KCL, +these objects have type `ImportedGeometry` and can mostly be treated like any +other solid (they can be rotated, scaled, etc.), although there is no access to +their internal components. See the [modules and imports docs](modules) for more +detail on importing geometry. + + +## Binary expressions + +You can also do math! Let's show an example below: + +``` +myMathExpression = 3 + 1 * 2 / 3 - 7 +``` + +You can nest expressions in parenthesis as well: + +``` +myMathExpression = 3 + (1 * 2 / (3 - 7)) +``` + +## Functions + +We also have support for defining your own functions. Functions can take in any +type of argument. Below is an example of the syntax: + +``` +fn myFn(x) { + return x +} +``` + +As you can see above `myFn` just returns whatever it is given. + +KCL's early drafts used positional arguments, but we now use keyword arguments: + +``` +// If you declare a function like this +fn add(left, right) { + return left + right +} + +// You can call it like this: +total = add(left = 1, right = 2) +``` + +Functions can also declare one *unlabeled* arg. If you do want to declare an unlabeled arg, it must +be the first arg declared. + +``` +// The @ indicates an argument can be used without a label. +// Note that only the first argument can use @. +fn increment(@x) { + return x + 1 +} + +fn add(@x, delta) { + return x + delta +} + +two = increment(1) +three = add(1, delta = 2) +``` + +## Pipelines + +It can be hard to read repeated function calls, because of all the nested brackets. + +```norun +i = 1 +x = h(g(f(i))) +``` + +You can make this easier to read by breaking it into many declarations, but that is a bit annoying. + +```norun +i = 1 +x0 = f(i) +x1 = g(x0) +x = h(x1) +``` + +Instead, you can use the pipeline operator (`|>`) to simplify this. + +Basically, `x |> f(%)` is a shorthand for `f(x)`. The left-hand side of the `|>` gets put into +the `%` in the right-hand side. + +So, this means `x |> f(%) |> g(%)` is shorthand for `g(f(x))`. The code example above, with its +somewhat-clunky `x0` and `x1` constants could be rewritten as + +```norun +i = 1 +x = i + |> f(%) + |> g(%) + |> h(%) +``` + +This helps keep your code neat and avoid unnecessary declarations. + +## Pipelines and keyword arguments + +Say you have a long pipeline of sketch functions, like this: + +```norun +startSketchOn(XZ) + |> line(%, end = [3, 4]) + |> line(%, end = [10, 10]) + |> line(%, end = [-13, -14]) + |> close(%) +``` + +In this example, each function call outputs a sketch, and it gets put into the next function call via +the `%`, into the first (unlabeled) argument. + +If a function call uses an unlabeled first parameter, it will default to `%` if it's not given. This +means that `|> line(%, end = [3, 4])` and `|> line(end = [3, 4])` are equivalent! So the above +could be rewritten as + +```norun +startSketchOn(XZ) + |> line(end = [3, 4]) + |> line(end = [10, 10]) + |> line(end = [-13, -14]) + |> close() +``` + +Note that we are still in the process of migrating KCL's standard library to use keyword arguments. So some +functions are still unfortunately using positional arguments. We're moving them over, so keep checking back. +Some functions are still using the old positional argument syntax. +Check the docs page for each function and look at its examples to see. + +## Tags + +Tags are used to give a name (tag) to a specific path. + +### `TagDeclarator` + +The syntax for declaring a tag is `$myTag` you would use it in the following +way: + +```norun +startSketchOn(XZ) + |> startProfile(at = origin) + |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) + |> angledLine( + angle = segAng(rectangleSegmentA001) - 90, + length = 196.99, + tag = $rectangleSegmentB001, + ) + |> angledLine( + angle = segAng(rectangleSegmentA001), + length = -segLen(rectangleSegmentA001), + tag = $rectangleSegmentC001, + ) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() +``` + +### `TagIdentifier` + +As per the example above you can use the tag identifier to get a reference to the +tagged object. The syntax for this is `myTag`. + +In the example above we use the tag identifier to get the angle of the segment +`segAng(rectangleSegmentA001, %)`. + +### `Start` + +There is a special tag, `START` (with type `Start`, although under the cover, it's a string) +for identifying the face of a solid which was the start of an extrusion (i.e., the surface which +is extruded). + +### `End` + +There is a special tag, `END` (with type `End`, although under the cover, it's a string) +for identifying the face of a solid which was finishes an extrusion. + +### Tag Scope + +Tags are scoped globally if in the root context meaning in this example you can +use the tag `rectangleSegmentA001` in any function or expression in the file. + +However if the code was written like this: + +```norun +fn rect(origin) { + return startSketchOn(XZ) + |> startProfile(at = origin) + |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) + |> angledLine( + angle = segAng(rectangleSegmentA001) - 90, + length = 196.99, + tag = $rectangleSegmentB001, + ) + |> angledLine( + angle = segAng(rectangleSegmentA001), + length = -segLen(rectangleSegmentA001), + tag = $rectangleSegmentC001, + ) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() +} + +rect([0, 0]) +rect([20, 0]) +``` + +Those tags would only be available in the `rect` function and not globally. + +However you likely want to use those tags somewhere outside the `rect` function. + +Tags are accessible through the sketch group they are declared in. +For example the following code works. + +```norun +fn rect(origin) { + return startSketchOn(XZ) + |> startProfile(at = origin) + |> angledLine(angle = 0, length = 191.26, tag = $rectangleSegmentA001) + |> angledLine( + angle = segAng(rectangleSegmentA001) - 90, + length = 196.99, + tag = $rectangleSegmentB001, + ) + |> angledLine( + angle = segAng(rectangleSegmentA001), + length = -segLen(rectangleSegmentA001), + tag = $rectangleSegmentC001, + ) + |> line(endAbsolute = [profileStartX(%), profileStartY(%)]) + |> close() +} + +rect([0, 0]) +myRect = rect([20, 0]) + +myRect + |> extrude(length = 10) + |> fillet(radius = 0.5, tags = [myRect.tags.rectangleSegmentA001]) +``` + +See how we use the tag `rectangleSegmentA001` in the `fillet` function outside +the `rect` function. This is because the `rect` function is returning the +sketch group that contains the tags. + + +--- + +If you find any issues using any of the above expressions or syntax, +please file an issue with the `ast` label on the [modeling-app +repo](https://github.com/KittyCAD/modeling-app/issues/new). diff --git a/docs/kcl/README.md b/docs/kcl/README.md new file mode 100644 index 000000000..f1dff1f1b --- /dev/null +++ b/docs/kcl/README.md @@ -0,0 +1,5 @@ +# Autogenerated docs + +Everything in this directory and its subdirectories (except this file) is automatically generated. Do not edit anything in this directory directly, your changes will be lost. + +The directory contents are generated by running the `test_generate_stdlib_markdown_docs` test in `/rust/kcl-lib/src/docs/gen_std_tests.rs`. Files are generated from the standard library declared in KCL (`/rust/kcl-lib/std`) and in Rust (`/rust/kcl-lib/src/std`), and by copying files from `../kcl-src`. \ No newline at end of file diff --git a/docs/kcl/angledLine.md b/docs/kcl/angledLine.md index 94177f263..bf270eb6c 100644 --- a/docs/kcl/angledLine.md +++ b/docs/kcl/angledLine.md @@ -10,15 +10,15 @@ Draw a line segment relative to the current origin using the polar measure of so ```kcl angledLine( - sketch: [Sketch](/docs/kcl/types/Sketch), - angle: [number](/docs/kcl/types/number), - length?: [number](/docs/kcl/types/number), - lengthX?: [number](/docs/kcl/types/number), - lengthY?: [number](/docs/kcl/types/number), - endAbsoluteX?: [number](/docs/kcl/types/number), - endAbsoluteY?: [number](/docs/kcl/types/number), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + angle: [number](/docs/kcl/types/std-types-number), + length?: [number](/docs/kcl/types/std-types-number), + lengthX?: [number](/docs/kcl/types/std-types-number), + lengthY?: [number](/docs/kcl/types/std-types-number), + endAbsoluteX?: [number](/docs/kcl/types/std-types-number), + endAbsoluteY?: [number](/docs/kcl/types/std-types-number), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -26,18 +26,18 @@ angledLine( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `angle` | [`number`](/docs/kcl/types/number) | Which angle should the line be drawn at? | Yes | -| `length` | [`number`](/docs/kcl/types/number) | Draw the line this distance along the given angle. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | -| `lengthX` | [`number`](/docs/kcl/types/number) | Draw the line this distance along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | -| `lengthY` | [`number`](/docs/kcl/types/number) | Draw the line this distance along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | -| `endAbsoluteX` | [`number`](/docs/kcl/types/number) | Draw the line along the given angle until it reaches this point along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | -| `endAbsoluteY` | [`number`](/docs/kcl/types/number) | Draw the line along the given angle until it reaches this point along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `angle` | [`number`](/docs/kcl/types/std-types-number) | Which angle should the line be drawn at? | Yes | +| `length` | [`number`](/docs/kcl/types/std-types-number) | Draw the line this distance along the given angle. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | +| `lengthX` | [`number`](/docs/kcl/types/std-types-number) | Draw the line this distance along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | +| `lengthY` | [`number`](/docs/kcl/types/std-types-number) | Draw the line this distance along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | +| `endAbsoluteX` | [`number`](/docs/kcl/types/std-types-number) | Draw the line along the given angle until it reaches this point along the X axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | +| `endAbsoluteY` | [`number`](/docs/kcl/types/std-types-number) | Draw the line along the given angle until it reaches this point along the Y axis. Only one of `length`, `lengthX`, `lengthY`, `endAbsoluteX`, `endAbsoluteY` can be given. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/angledLineThatIntersects.md b/docs/kcl/angledLineThatIntersects.md index ea0dbc699..88b55a929 100644 --- a/docs/kcl/angledLineThatIntersects.md +++ b/docs/kcl/angledLineThatIntersects.md @@ -10,12 +10,12 @@ Draw an angled line from the current origin, constructing a line segment such th ```kcl angledLineThatIntersects( - sketch: [Sketch](/docs/kcl/types/Sketch), - angle: [number](/docs/kcl/types/number), - intersectTag: [TagIdentifier](/docs/kcl/types#tag-identifier), - offset?: [number](/docs/kcl/types/number), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + angle: [number](/docs/kcl/types/std-types-number), + intersectTag: [TagIdentifier](/docs/kcl/types#TagIdentifier), + offset?: [number](/docs/kcl/types/std-types-number), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -23,15 +23,15 @@ angledLineThatIntersects( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `angle` | [`number`](/docs/kcl/types/number) | Which angle should the line be drawn at? | Yes | -| `intersectTag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The tag of the line to intersect with | Yes | -| `offset` | [`number`](/docs/kcl/types/number) | The offset from the intersecting line. Defaults to 0. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `angle` | [`number`](/docs/kcl/types/std-types-number) | Which angle should the line be drawn at? | Yes | +| `intersectTag` | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The tag of the line to intersect with | Yes | +| `offset` | [`number`](/docs/kcl/types/std-types-number) | The offset from the intersecting line. Defaults to 0. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/appearance.md b/docs/kcl/appearance.md index 28bea674a..ef1b38f93 100644 --- a/docs/kcl/appearance.md +++ b/docs/kcl/appearance.md @@ -10,11 +10,11 @@ This will work on any solid, including extruded solids, revolved solids, and she ```kcl appearance( - solids: [[Solid](/docs/kcl/types/Solid)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)OrImportedGeometry), - color: String, - metalness?: [number](/docs/kcl/types/number), - roughness?: [number](/docs/kcl/types/number), -): [[Solid](/docs/kcl/types/Solid)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)OrImportedGeometry) + solids: [[Solid]](/docs/kcl/types/std-types-Solid) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry), + color: [string](/docs/kcl/types/std-types-string), + metalness?: [number](/docs/kcl/types/std-types-number), + roughness?: [number](/docs/kcl/types/std-types-number), +): [[Solid]](/docs/kcl/types/std-types-Solid) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry) ``` @@ -22,14 +22,14 @@ appearance( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`SolidOrImportedGeometry`](/docs/kcl/types/SolidOrImportedGeometry) | The solid(s) whose appearance is being set | Yes | -| `color` | `String` | Color of the new material, a hex string like '#ff0000' | Yes | -| `metalness` | [`number`](/docs/kcl/types/number) | Metalness of the new material, a percentage like 95.7. | No | -| `roughness` | [`number`](/docs/kcl/types/number) | Roughness of the new material, a percentage like 95.7. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) | The solid(s) whose appearance is being set | Yes | +| `color` | [`string`](/docs/kcl/types/std-types-string) | Color of the new material, a hex string like '#ff0000' | Yes | +| `metalness` | [`number`](/docs/kcl/types/std-types-number) | Metalness of the new material, a percentage like 95.7. | No | +| `roughness` | [`number`](/docs/kcl/types/std-types-number) | Roughness of the new material, a percentage like 95.7. | No | ### Returns -[`SolidOrImportedGeometry`](/docs/kcl/types/SolidOrImportedGeometry) - Data for a solid or an imported geometry. +[`[Solid]`](/docs/kcl/types/std-types-Solid) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) - Data for a solid or an imported geometry. ### Examples diff --git a/docs/kcl/arc.md b/docs/kcl/arc.md index 9b1328922..9ee6f3857 100644 --- a/docs/kcl/arc.md +++ b/docs/kcl/arc.md @@ -12,14 +12,14 @@ Unless this makes a lot of sense and feels like what you're looking for to const ```kcl arc( - sketch: [Sketch](/docs/kcl/types/Sketch), - angleStart?: [number](/docs/kcl/types/number), - angleEnd?: [number](/docs/kcl/types/number), - radius?: [number](/docs/kcl/types/number), - interiorAbsolute?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - endAbsolute?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + angleStart?: [number](/docs/kcl/types/std-types-number), + angleEnd?: [number](/docs/kcl/types/std-types-number), + radius?: [number](/docs/kcl/types/std-types-number), + interiorAbsolute?: [Point2d](/docs/kcl/types/std-types-Point2d), + endAbsolute?: [Point2d](/docs/kcl/types/std-types-Point2d), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -27,17 +27,17 @@ arc( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `angleStart` | [`number`](/docs/kcl/types/number) | Where along the circle should this arc start? | No | -| `angleEnd` | [`number`](/docs/kcl/types/number) | Where along the circle should this arc end? | No | -| `radius` | [`number`](/docs/kcl/types/number) | How large should the circle be? | No | -| `interiorAbsolute` | [`[number]`](/docs/kcl/types/number) | Any point between the arc's start and end? Requires `endAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | -| `endAbsolute` | [`[number]`](/docs/kcl/types/number) | Where should this arc end? Requires `interiorAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `angleStart` | [`number`](/docs/kcl/types/std-types-number) | Where along the circle should this arc start? | No | +| `angleEnd` | [`number`](/docs/kcl/types/std-types-number) | Where along the circle should this arc end? | No | +| `radius` | [`number`](/docs/kcl/types/std-types-number) | How large should the circle be? | No | +| `interiorAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Any point between the arc's start and end? Requires `endAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | +| `endAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Where should this arc end? Requires `interiorAbsolute`. Incompatible with `angleStart` or `angleEnd` | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/assert.md b/docs/kcl/assert.md index edd4b1371..854e04f77 100644 --- a/docs/kcl/assert.md +++ b/docs/kcl/assert.md @@ -10,14 +10,14 @@ Check a value meets some expected conditions at runtime. Program terminates with ```kcl assert( - actual: [number](/docs/kcl/types/number), - isGreaterThan?: [number](/docs/kcl/types/number), - isLessThan?: [number](/docs/kcl/types/number), - isGreaterThanOrEqual?: [number](/docs/kcl/types/number), - isLessThanOrEqual?: [number](/docs/kcl/types/number), - isEqualTo?: [number](/docs/kcl/types/number), - tolerance?: [number](/docs/kcl/types/number), - error?: String, + actual: [number](/docs/kcl/types/std-types-number), + isGreaterThan?: [number](/docs/kcl/types/std-types-number), + isLessThan?: [number](/docs/kcl/types/std-types-number), + isGreaterThanOrEqual?: [number](/docs/kcl/types/std-types-number), + isLessThanOrEqual?: [number](/docs/kcl/types/std-types-number), + isEqualTo?: [number](/docs/kcl/types/std-types-number), + tolerance?: [number](/docs/kcl/types/std-types-number), + error?: [string](/docs/kcl/types/std-types-string), ): () ``` @@ -26,14 +26,14 @@ assert( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `actual` | [`number`](/docs/kcl/types/number) | Value to check. It will be compared with one of the comparison arguments. | Yes | -| `isGreaterThan` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is greater than this. | No | -| `isLessThan` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than this. | No | -| `isGreaterThanOrEqual` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is greater than or equal to this. | No | -| `isLessThanOrEqual` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | -| `isEqualTo` | [`number`](/docs/kcl/types/number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | -| `tolerance` | [`number`](/docs/kcl/types/number) | If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places. | No | -| `error` | `String` | If the value was false, the program will terminate with this error message | No | +| `actual` | [`number`](/docs/kcl/types/std-types-number) | Value to check. It will be compared with one of the comparison arguments. | Yes | +| `isGreaterThan` | [`number`](/docs/kcl/types/std-types-number) | Comparison argument. If given, checks the `actual` value is greater than this. | No | +| `isLessThan` | [`number`](/docs/kcl/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than this. | No | +| `isGreaterThanOrEqual` | [`number`](/docs/kcl/types/std-types-number) | Comparison argument. If given, checks the `actual` value is greater than or equal to this. | No | +| `isLessThanOrEqual` | [`number`](/docs/kcl/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | +| `isEqualTo` | [`number`](/docs/kcl/types/std-types-number) | Comparison argument. If given, checks the `actual` value is less than or equal to this. | No | +| `tolerance` | [`number`](/docs/kcl/types/std-types-number) | If `isEqualTo` is used, this is the tolerance to allow for the comparison. This tolerance is used because KCL's number system has some floating-point imprecision when used with very large decimal places. | No | +| `error` | [`string`](/docs/kcl/types/std-types-string) | If the value was false, the program will terminate with this error message | No | ### Returns diff --git a/docs/kcl/assertIs.md b/docs/kcl/assertIs.md index 0b7b6e5b3..d91db499f 100644 --- a/docs/kcl/assertIs.md +++ b/docs/kcl/assertIs.md @@ -10,8 +10,8 @@ Asserts that a value is the boolean value true. ```kcl assertIs( - actual: [bool](/docs/kcl/types/bool), - error?: String, + actual: [bool](/docs/kcl/types/std-types-bool), + error?: [string](/docs/kcl/types/std-types-string), ): () ``` @@ -20,8 +20,8 @@ assertIs( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `actual` | [`bool`](/docs/kcl/types/bool) | Value to check. If this is the boolean value true, assert passes. Otherwise it fails. | Yes | -| `error` | `String` | If the value was false, the program will terminate with this error message | No | +| `actual` | [`bool`](/docs/kcl/types/std-types-bool) | Value to check. If this is the boolean value true, assert passes. Otherwise it fails. | Yes | +| `error` | [`string`](/docs/kcl/types/std-types-string) | If the value was false, the program will terminate with this error message | No | ### Returns diff --git a/docs/kcl/bezierCurve.md b/docs/kcl/bezierCurve.md index 787c29c77..4f566944c 100644 --- a/docs/kcl/bezierCurve.md +++ b/docs/kcl/bezierCurve.md @@ -10,12 +10,12 @@ Draw a smooth, continuous, curved line segment from the current origin to the de ```kcl bezierCurve( - sketch: [Sketch](/docs/kcl/types/Sketch), - control1: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - control2: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - end: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + control1: [Point2d](/docs/kcl/types/std-types-Point2d), + control2: [Point2d](/docs/kcl/types/std-types-Point2d), + end: [Point2d](/docs/kcl/types/std-types-Point2d), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -23,15 +23,15 @@ bezierCurve( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `control1` | [`[number]`](/docs/kcl/types/number) | First control point for the cubic | Yes | -| `control2` | [`[number]`](/docs/kcl/types/number) | Second control point for the cubic | Yes | -| `end` | [`[number]`](/docs/kcl/types/number) | How far away (along the X and Y axes) should this line go? | Yes | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `control1` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | First control point for the cubic | Yes | +| `control2` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Second control point for the cubic | Yes | +| `end` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | How far away (along the X and Y axes) should this line go? | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/circleThreePoint.md b/docs/kcl/circleThreePoint.md index 0c7e7247d..d4983c628 100644 --- a/docs/kcl/circleThreePoint.md +++ b/docs/kcl/circleThreePoint.md @@ -10,12 +10,12 @@ Construct a circle derived from 3 points. ```kcl circleThreePoint( - sketchSurfaceOrGroup: [[Sketch](/docs/kcl/types/Sketch)OrSurface](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)OrSurface), - p1: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - p2: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - p3: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketchSurfaceOrGroup: [Sketch](/docs/kcl/types/std-types-Sketch) | [Plane](/docs/kcl/types/std-types-Plane) | [Face](/docs/kcl/types/std-types-Face), + p1: [Point2d](/docs/kcl/types/std-types-Point2d), + p2: [Point2d](/docs/kcl/types/std-types-Point2d), + p3: [Point2d](/docs/kcl/types/std-types-Point2d), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -23,15 +23,15 @@ circleThreePoint( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketchSurfaceOrGroup` | [`SketchOrSurface`](/docs/kcl/types/SketchOrSurface) | Plane or surface to sketch on. | Yes | -| `p1` | [`[number]`](/docs/kcl/types/number) | 1st point to derive the circle. | Yes | -| `p2` | [`[number]`](/docs/kcl/types/number) | 2nd point to derive the circle. | Yes | -| `p3` | [`[number]`](/docs/kcl/types/number) | 3rd point to derive the circle. | Yes | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Identifier for the circle to reference elsewhere. | No | +| `sketchSurfaceOrGroup` | [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`Plane`](/docs/kcl/types/std-types-Plane) or [`Face`](/docs/kcl/types/std-types-Face) | Plane or surface to sketch on. | Yes | +| `p1` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | 1st point to derive the circle. | Yes | +| `p2` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | 2nd point to derive the circle. | Yes | +| `p3` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | 3rd point to derive the circle. | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Identifier for the circle to reference elsewhere. | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/clone.md b/docs/kcl/clone.md index 62c88791f..aa6f1f338 100644 --- a/docs/kcl/clone.md +++ b/docs/kcl/clone.md @@ -13,7 +13,7 @@ This doesn't really have much utility unless you need the equivalent of a double Really only use this function if YOU ARE SURE you need it. In most cases you do not need clone and using a pattern with `instance = 2` is more appropriate. ```kcl -clone(geometry: [GeometryWithImportedGeometry](/docs/kcl/types/GeometryWithImportedGeometry)): [GeometryWithImportedGeometry](/docs/kcl/types/GeometryWithImportedGeometry) +clone(geometry: [Solid](/docs/kcl/types/std-types-Solid) | [Sketch](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry)): [Solid](/docs/kcl/types/std-types-Solid) | [Sketch](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry) ``` @@ -21,11 +21,11 @@ clone(geometry: [GeometryWithImportedGeometry](/docs/kcl/types/GeometryWithImpor | Name | Type | Description | Required | |----------|------|-------------|----------| -| `geometry` | [`GeometryWithImportedGeometry`](/docs/kcl/types/GeometryWithImportedGeometry) | The sketch, solid, or imported geometry to be cloned | Yes | +| `geometry` | [`Solid`](/docs/kcl/types/std-types-Solid) or [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) | The sketch, solid, or imported geometry to be cloned | Yes | ### Returns -[`GeometryWithImportedGeometry`](/docs/kcl/types/GeometryWithImportedGeometry) - A geometry including an imported geometry. +[`Solid`](/docs/kcl/types/std-types-Solid) or [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) - A geometry including an imported geometry. ### Examples diff --git a/docs/kcl/close.md b/docs/kcl/close.md index 72d74fbae..57fd602e1 100644 --- a/docs/kcl/close.md +++ b/docs/kcl/close.md @@ -10,9 +10,9 @@ Construct a line segment from the current origin back to the profile's origin, e ```kcl close( - sketch: [Sketch](/docs/kcl/types/Sketch), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -20,12 +20,12 @@ close( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | The sketch you want to close | Yes | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | The sketch you want to close | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/e.md b/docs/kcl/e.md deleted file mode 100644 index 7ae401b60..000000000 --- a/docs/kcl/e.md +++ /dev/null @@ -1,42 +0,0 @@ ---- -title: "e" -excerpt: "Return the value of Euler’s number `e`." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Return the value of Euler’s number `e`. - -**DEPRECATED** use the constant E - -```js -e(): number -``` - -### Tags - -* `math` - - - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -exampleSketch = startSketchOn(XZ) - |> startProfile(at = [0, 0]) - |> angledLine(angle = 30, length = 2 * e() ^ 2) - |> yLine(endAbsolute = 0) - |> close() - -example = extrude(exampleSketch, length = 10) -``` - -![Rendered example of e 0]() - - diff --git a/docs/kcl/extrude.md b/docs/kcl/extrude.md index 7a0d18735..996056e94 100644 --- a/docs/kcl/extrude.md +++ b/docs/kcl/extrude.md @@ -10,13 +10,13 @@ You can provide more than one sketch to extrude, and they will all be extruded i ```kcl extrude( - sketches: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - length: [number](/docs/kcl/types/number), - symmetric?: [bool](/docs/kcl/types/bool), - bidirectionalLength?: [number](/docs/kcl/types/number), - tagStart?: [TagDeclarator](/docs/kcl/types#tag-declaration), - tagEnd?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + sketches: [[Sketch]](/docs/kcl/types/std-types-Sketch), + length: [number](/docs/kcl/types/std-types-number), + symmetric?: [bool](/docs/kcl/types/std-types-bool), + bidirectionalLength?: [number](/docs/kcl/types/std-types-number), + tagStart?: [TagDeclarator](/docs/kcl/types#TagDeclarator), + tagEnd?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -24,16 +24,16 @@ extrude( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | [`[Sketch]`](/docs/kcl/types/Sketch) | Which sketch or sketches should be extruded | Yes | -| `length` | [`number`](/docs/kcl/types/number) | How far to extrude the given sketches | Yes | -| `symmetric` | [`bool`](/docs/kcl/types/bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the | No | -| `bidirectionalLength` | [`number`](/docs/kcl/types/number) | If specified, will also extrude in the opposite direction to 'distance' to the specified distance. If 'symmetric' is true, this value is ignored. | No | -| `tagStart` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the start of the extrusion, i.e. the original sketch | No | -| `tagEnd` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the end of the extrusion, i.e. the new face created by extruding the original sketch | No | +| `sketches` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | Which sketch or sketches should be extruded | Yes | +| `length` | [`number`](/docs/kcl/types/std-types-number) | How far to extrude the given sketches | Yes | +| `symmetric` | [`bool`](/docs/kcl/types/std-types-bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the | No | +| `bidirectionalLength` | [`number`](/docs/kcl/types/std-types-number) | If specified, will also extrude in the opposite direction to 'distance' to the specified distance. If 'symmetric' is true, this value is ignored. | No | +| `tagStart` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the start of the extrusion, i.e. the original sketch | No | +| `tagEnd` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the end of the extrusion, i.e. the new face created by extruding the original sketch | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/fromCm.md b/docs/kcl/fromCm.md deleted file mode 100644 index 152a4e6c7..000000000 --- a/docs/kcl/fromCm.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromCm" -excerpt: "Converts a number from centimeters to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from centimeters to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42cm`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in centimeters. - -For example, if the current file uses inches, `fromCm(1)` will return `0.393701`. If the current file uses millimeters, `fromCm(1)` will return `10`. If the current file uses centimeters, `fromCm(1)` will return `1`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromCm(10)` is more readable that your intent is "I want 10 centimeters" than `10 * 10`, if the file settings are in millimeters. - -```js -fromCm(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = fromCm(10) -``` - -![Rendered example of fromCm 0]() - - diff --git a/docs/kcl/fromFt.md b/docs/kcl/fromFt.md deleted file mode 100644 index 945e6ada3..000000000 --- a/docs/kcl/fromFt.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromFt" -excerpt: "Converts a number from feet to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from feet to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42ft`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in feet. - -For example, if the current file uses inches, `fromFt(1)` will return `12`. If the current file uses millimeters, `fromFt(1)` will return `304.8`. If the current file uses feet, `fromFt(1)` will return `1`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromFt(10)` is more readable that your intent is "I want 10 feet" than `10 * 304.8`, if the file settings are in millimeters. - -```js -fromFt(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = fromFt(10) -``` - -![Rendered example of fromFt 0]() - - diff --git a/docs/kcl/fromInches.md b/docs/kcl/fromInches.md deleted file mode 100644 index d64a2477b..000000000 --- a/docs/kcl/fromInches.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromInches" -excerpt: "Converts a number from inches to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from inches to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42inch`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in inches. - -For example, if the current file uses inches, `fromInches(1)` will return `1`. If the current file uses millimeters, `fromInches(1)` will return `25.4`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromInches(10)` is more readable that your intent is "I want 10 inches" than `10 * 25.4`, if the file settings are in millimeters. - -```js -fromInches(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = fromInches(10) -``` - -![Rendered example of fromInches 0]() - - diff --git a/docs/kcl/fromM.md b/docs/kcl/fromM.md deleted file mode 100644 index 3fe12845f..000000000 --- a/docs/kcl/fromM.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromM" -excerpt: "Converts a number from meters to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from meters to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42m`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in meters. - -For example, if the current file uses inches, `fromM(1)` will return `39.3701`. If the current file uses millimeters, `fromM(1)` will return `1000`. If the current file uses meters, `fromM(1)` will return `1`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromM(10)` is more readable that your intent is "I want 10 meters" than `10 * 1000`, if the file settings are in millimeters. - -```js -fromM(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = 10 * fromM(10) -``` - -![Rendered example of fromM 0]() - - diff --git a/docs/kcl/fromMm.md b/docs/kcl/fromMm.md deleted file mode 100644 index 40fc7b45e..000000000 --- a/docs/kcl/fromMm.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromMm" -excerpt: "Converts a number from mm to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from mm to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42mm`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in millimeters. - -For example, if the current file uses inches, `fromMm(1)` will return `1/25.4`. If the current file uses millimeters, `fromMm(1)` will return `1`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromMm(10)` is more readable that your intent is "I want 10 millimeters" than `10 * (1/25.4)`, if the file settings are in inches. - -```js -fromMm(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = fromMm(10) -``` - -![Rendered example of fromMm 0]() - - diff --git a/docs/kcl/fromYd.md b/docs/kcl/fromYd.md deleted file mode 100644 index 01c4707d5..000000000 --- a/docs/kcl/fromYd.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -title: "fromYd" -excerpt: "Converts a number from yards to the current default unit." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Converts a number from yards to the current default unit. - -*DEPRECATED* prefer using explicit numeric suffixes (e.g., `42yd`) or the `to...` conversion functions. - -No matter what units the current file uses, this function will always return a number equivalent to the input in yards. - -For example, if the current file uses inches, `fromYd(1)` will return `36`. If the current file uses millimeters, `fromYd(1)` will return `914.4`. If the current file uses yards, `fromYd(1)` will return `1`. - -**Caution**: This function is only intended to be used when you absolutely MUST have different units in your code than the file settings. Otherwise, it is a bad pattern to use this function. - -We merely provide these functions for convenience and readability, as `fromYd(10)` is more readable that your intent is "I want 10 yards" than `10 * 914.4`, if the file settings are in millimeters. - -```js -fromYd(input: number): number -``` - -### Tags - -* `units` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -totalWidth = fromYd(10) -``` - -![Rendered example of fromYd 0]() - - diff --git a/docs/kcl/std-helix.md b/docs/kcl/functions/std-helix.md similarity index 99% rename from docs/kcl/std-helix.md rename to docs/kcl/functions/std-helix.md index d1a89818b..999f0c916 100644 --- a/docs/kcl/std-helix.md +++ b/docs/kcl/functions/std-helix.md @@ -10,14 +10,14 @@ Create a helix. ```kcl helix( - revolutions: [number](/docs/kcl/types/number)(_), - angleStart: [number](/docs/kcl/types/number)(Angle), - ccw?: [bool](/docs/kcl/types/bool), - radius?: [number](/docs/kcl/types/number)(Length), - axis?: [Axis3d](/docs/kcl/types/Axis3d) | [Edge](/docs/kcl/types/Edge), - length?: [number](/docs/kcl/types/number)(Length), - cylinder?: [Solid](/docs/kcl/types/Solid), -): [Helix](/docs/kcl/types/Helix) + revolutions: number(_), + angleStart: number(Angle), + ccw?: [bool](/docs/kcl/types/std-types-bool), + radius?: number(Length), + axis?: [Axis3d](/docs/kcl/types/std-types-Axis3d) | [Edge](/docs/kcl/types/std-types-Edge), + length?: number(Length), + cylinder?: [Solid](/docs/kcl/types/std-types-Solid), +): [Helix](/docs/kcl/types/std-types-Helix) ``` @@ -27,15 +27,15 @@ helix( |----------|------|-------------|----------| | `revolutions` | `number(_)` | Number of revolutions. | Yes | | `angleStart` | `number(Angle)` | Start angle. | Yes | -| `ccw` | [`bool`](/docs/kcl/types/bool) | Is the helix rotation counter clockwise? The default is `false`. | No | +| `ccw` | [`bool`](/docs/kcl/types/std-types-bool) | Is the helix rotation counter clockwise? The default is `false`. | No | | `radius` | `number(Length)` | Radius of the helix. | No | -| `axis` | [`Axis3d`](/docs/kcl/types/Axis3d) or [`Edge`](/docs/kcl/types/Edge) | Axis to use for the helix. | No | +| `axis` | [`Axis3d`](/docs/kcl/types/std-types-Axis3d) or [`Edge`](/docs/kcl/types/std-types-Edge) | Axis to use for the helix. | No | | `length` | `number(Length)` | Length of the helix. This is not necessary if the helix is created around an edge. If not given the length of the edge is used. | No | -| `cylinder` | [`Solid`](/docs/kcl/types/Solid) | Cylinder to create the helix on. | No | +| `cylinder` | [`Solid`](/docs/kcl/types/std-types-Solid) | Cylinder to create the helix on. | No | ### Returns -[`Helix`](/docs/kcl/types/Helix) +[`Helix`](/docs/kcl/types/std-types-Helix) ### Examples diff --git a/docs/kcl/std-math-abs.md b/docs/kcl/functions/std-math-abs.md similarity index 99% rename from docs/kcl/std-math-abs.md rename to docs/kcl/functions/std-math-abs.md index 775bf770d..6d775e3c3 100644 --- a/docs/kcl/std-math-abs.md +++ b/docs/kcl/functions/std-math-abs.md @@ -9,7 +9,7 @@ Compute the absolute value of a number. ```kcl -abs(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +abs(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ abs(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-acos.md b/docs/kcl/functions/std-math-acos.md similarity index 99% rename from docs/kcl/std-math-acos.md rename to docs/kcl/functions/std-math-acos.md index 6ca5b68fb..a7751c2a4 100644 --- a/docs/kcl/std-math-acos.md +++ b/docs/kcl/functions/std-math-acos.md @@ -9,7 +9,7 @@ Compute the arccosine of a number. ```kcl -acos(@num: [number](/docs/kcl/types/number)(_)): [number](/docs/kcl/types/number)(rad) +acos(@num: number(_)): number(rad) ``` diff --git a/docs/kcl/std-math-asin.md b/docs/kcl/functions/std-math-asin.md similarity index 99% rename from docs/kcl/std-math-asin.md rename to docs/kcl/functions/std-math-asin.md index c475f99a9..50d982300 100644 --- a/docs/kcl/std-math-asin.md +++ b/docs/kcl/functions/std-math-asin.md @@ -9,7 +9,7 @@ Compute the arcsine of a number. ```kcl -asin(@num: [number](/docs/kcl/types/number)(_)): [number](/docs/kcl/types/number)(rad) +asin(@num: number(_)): number(rad) ``` diff --git a/docs/kcl/std-math-atan.md b/docs/kcl/functions/std-math-atan.md similarity index 87% rename from docs/kcl/std-math-atan.md rename to docs/kcl/functions/std-math-atan.md index b3a873324..63d6a7bea 100644 --- a/docs/kcl/std-math-atan.md +++ b/docs/kcl/functions/std-math-atan.md @@ -9,7 +9,7 @@ Compute the arctangent of a number. Consider using `atan2()` instead for the true inverse of tangent. ```kcl -atan(@num: [number](/docs/kcl/types/number)(_)): [number](/docs/kcl/types/number)(rad) +atan(@num: number(_)): number(rad) ``` diff --git a/docs/kcl/std-math-atan2.md b/docs/kcl/functions/std-math-atan2.md similarity index 99% rename from docs/kcl/std-math-atan2.md rename to docs/kcl/functions/std-math-atan2.md index 8df61ef69..30432058d 100644 --- a/docs/kcl/std-math-atan2.md +++ b/docs/kcl/functions/std-math-atan2.md @@ -10,9 +10,9 @@ Compute the four quadrant arctangent of Y and X. ```kcl atan2( - y: [number](/docs/kcl/types/number)(Length), - x: [number](/docs/kcl/types/number)(Length), -): [number](/docs/kcl/types/number)(rad) + y: number(Length), + x: number(Length), +): number(rad) ``` diff --git a/docs/kcl/std-math-ceil.md b/docs/kcl/functions/std-math-ceil.md similarity index 99% rename from docs/kcl/std-math-ceil.md rename to docs/kcl/functions/std-math-ceil.md index 376b22b96..43b4ef4ac 100644 --- a/docs/kcl/std-math-ceil.md +++ b/docs/kcl/functions/std-math-ceil.md @@ -9,7 +9,7 @@ Compute the smallest integer greater than or equal to a number. ```kcl -ceil(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +ceil(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ ceil(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-cos.md b/docs/kcl/functions/std-math-cos.md similarity index 99% rename from docs/kcl/std-math-cos.md rename to docs/kcl/functions/std-math-cos.md index d5d447067..92b39e469 100644 --- a/docs/kcl/std-math-cos.md +++ b/docs/kcl/functions/std-math-cos.md @@ -9,7 +9,7 @@ Compute the cosine of a number. ```kcl -cos(@num: [number](/docs/kcl/types/number)(Angle)): [number](/docs/kcl/types/number)(_) +cos(@num: number(Angle)): number(_) ``` diff --git a/docs/kcl/std-math-floor.md b/docs/kcl/functions/std-math-floor.md similarity index 99% rename from docs/kcl/std-math-floor.md rename to docs/kcl/functions/std-math-floor.md index 9c410ab66..ecdfc4c21 100644 --- a/docs/kcl/std-math-floor.md +++ b/docs/kcl/functions/std-math-floor.md @@ -9,7 +9,7 @@ Compute the largest integer less than or equal to a number. ```kcl -floor(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +floor(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ floor(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-ln.md b/docs/kcl/functions/std-math-ln.md similarity index 99% rename from docs/kcl/std-math-ln.md rename to docs/kcl/functions/std-math-ln.md index a958f9cb6..46d3e2439 100644 --- a/docs/kcl/std-math-ln.md +++ b/docs/kcl/functions/std-math-ln.md @@ -9,7 +9,7 @@ Compute the natural logarithm of the number. ```kcl -ln(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +ln(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ ln(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-log.md b/docs/kcl/functions/std-math-log.md similarity index 99% rename from docs/kcl/std-math-log.md rename to docs/kcl/functions/std-math-log.md index c4492573c..74c992843 100644 --- a/docs/kcl/std-math-log.md +++ b/docs/kcl/functions/std-math-log.md @@ -12,9 +12,9 @@ and `log10` can produce more accurate results for base 10. ```kcl log( - @input: [number](/docs/kcl/types/number), - base: [number](/docs/kcl/types/number)(_), -): [number](/docs/kcl/types/number) + @input: [number](/docs/kcl/types/std-types-number), + base: number(_), +): [number](/docs/kcl/types/std-types-number) ``` @@ -22,12 +22,12 @@ log( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | The number to compute the logarithm of. | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | The number to compute the logarithm of. | Yes | | `base` | `number(_)` | The base of the logarithm. | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-log10.md b/docs/kcl/functions/std-math-log10.md similarity index 99% rename from docs/kcl/std-math-log10.md rename to docs/kcl/functions/std-math-log10.md index dba8b68c9..e2826574c 100644 --- a/docs/kcl/std-math-log10.md +++ b/docs/kcl/functions/std-math-log10.md @@ -9,7 +9,7 @@ Compute the base 10 logarithm of the number. ```kcl -log10(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +log10(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ log10(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-log2.md b/docs/kcl/functions/std-math-log2.md similarity index 99% rename from docs/kcl/std-math-log2.md rename to docs/kcl/functions/std-math-log2.md index 474f3dd0f..2f179350d 100644 --- a/docs/kcl/std-math-log2.md +++ b/docs/kcl/functions/std-math-log2.md @@ -9,7 +9,7 @@ Compute the base 2 logarithm of the number. ```kcl -log2(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +log2(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ log2(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-max.md b/docs/kcl/functions/std-math-max.md similarity index 99% rename from docs/kcl/std-math-max.md rename to docs/kcl/functions/std-math-max.md index 4ce618be6..76e069a29 100644 --- a/docs/kcl/std-math-max.md +++ b/docs/kcl/functions/std-math-max.md @@ -9,7 +9,7 @@ Compute the maximum of the given arguments. ```kcl -max(@input: [[number](/docs/kcl/types/number); 1+]): [number](/docs/kcl/types/number) +max(@input: [[number; 1+]](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ max(@input: [[number](/docs/kcl/types/number); 1+]): [number](/docs/kcl/types/nu | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | `[number; 1+]` | An array of numbers to compute the maximum of. | Yes | +| `input` | [`[number; 1+]`](/docs/kcl/types/std-types-number) | An array of numbers to compute the maximum of. | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-min.md b/docs/kcl/functions/std-math-min.md similarity index 99% rename from docs/kcl/std-math-min.md rename to docs/kcl/functions/std-math-min.md index ecac801d0..ce93f428a 100644 --- a/docs/kcl/std-math-min.md +++ b/docs/kcl/functions/std-math-min.md @@ -9,7 +9,7 @@ Compute the minimum of the given arguments. ```kcl -min(@input: [[number](/docs/kcl/types/number); 1+]): [number](/docs/kcl/types/number) +min(@input: [[number; 1+]](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ min(@input: [[number](/docs/kcl/types/number); 1+]): [number](/docs/kcl/types/nu | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | `[number; 1+]` | An array of numbers to compute the minimum of. | Yes | +| `input` | [`[number; 1+]`](/docs/kcl/types/std-types-number) | An array of numbers to compute the minimum of. | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-polar.md b/docs/kcl/functions/std-math-polar.md similarity index 99% rename from docs/kcl/std-math-polar.md rename to docs/kcl/functions/std-math-polar.md index 8873e2b5f..35e157e41 100644 --- a/docs/kcl/std-math-polar.md +++ b/docs/kcl/functions/std-math-polar.md @@ -11,9 +11,9 @@ cartesian (x/y/z grid) coordinates. ```kcl polar( - angle: [number](/docs/kcl/types/number)(rad), - length: [number](/docs/kcl/types/number)(Length), -): [Point2d](/docs/kcl/types/Point2d) + angle: number(rad), + length: number(Length), +): [Point2d](/docs/kcl/types/std-types-Point2d) ``` @@ -26,7 +26,7 @@ polar( ### Returns -[`Point2d`](/docs/kcl/types/Point2d) +[`Point2d`](/docs/kcl/types/std-types-Point2d) ### Examples diff --git a/docs/kcl/std-math-pow.md b/docs/kcl/functions/std-math-pow.md similarity index 99% rename from docs/kcl/std-math-pow.md rename to docs/kcl/functions/std-math-pow.md index 5a06e0bca..994bdbc93 100644 --- a/docs/kcl/std-math-pow.md +++ b/docs/kcl/functions/std-math-pow.md @@ -10,9 +10,9 @@ Compute the number to a power. ```kcl pow( - @input: [number](/docs/kcl/types/number), - exp: [number](/docs/kcl/types/number)(_), -): [number](/docs/kcl/types/number) + @input: [number](/docs/kcl/types/std-types-number), + exp: number(_), +): [number](/docs/kcl/types/std-types-number) ``` @@ -20,12 +20,12 @@ pow( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | The number to raise. | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | The number to raise. | Yes | | `exp` | `number(_)` | The power to raise to. | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-rem.md b/docs/kcl/functions/std-math-rem.md similarity index 98% rename from docs/kcl/std-math-rem.md rename to docs/kcl/functions/std-math-rem.md index 95667f036..ecb8b78d9 100644 --- a/docs/kcl/std-math-rem.md +++ b/docs/kcl/functions/std-math-rem.md @@ -11,9 +11,9 @@ If `num` is negative, the result will be too. ```kcl rem( - @num: [number](/docs/kcl/types/number), - divisor: [number](/docs/kcl/types/number), -): [number](/docs/kcl/types/number) + @num: [number](/docs/kcl/types/std-types-number), + divisor: [number](/docs/kcl/types/std-types-number), +): [number](/docs/kcl/types/std-types-number) ``` @@ -21,12 +21,12 @@ rem( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `num` | [`number`](/docs/kcl/types/number) | The number which will be divided by `divisor`. | Yes | -| `divisor` | [`number`](/docs/kcl/types/number) | The number which will divide `num`. | Yes | +| `num` | [`number`](/docs/kcl/types/std-types-number) | The number which will be divided by `divisor`. | Yes | +| `divisor` | [`number`](/docs/kcl/types/std-types-number) | The number which will divide `num`. | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-round.md b/docs/kcl/functions/std-math-round.md similarity index 99% rename from docs/kcl/std-math-round.md rename to docs/kcl/functions/std-math-round.md index 0bb9ed4de..0ede67710 100644 --- a/docs/kcl/std-math-round.md +++ b/docs/kcl/functions/std-math-round.md @@ -9,7 +9,7 @@ Round a number to the nearest integer. ```kcl -round(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +round(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ round(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-sin.md b/docs/kcl/functions/std-math-sin.md similarity index 99% rename from docs/kcl/std-math-sin.md rename to docs/kcl/functions/std-math-sin.md index 965ff8ebd..b325aedd8 100644 --- a/docs/kcl/std-math-sin.md +++ b/docs/kcl/functions/std-math-sin.md @@ -9,7 +9,7 @@ Compute the sine of a number. ```kcl -sin(@num: [number](/docs/kcl/types/number)(Angle)): [number](/docs/kcl/types/number)(_) +sin(@num: number(Angle)): number(_) ``` diff --git a/docs/kcl/std-math-sqrt.md b/docs/kcl/functions/std-math-sqrt.md similarity index 99% rename from docs/kcl/std-math-sqrt.md rename to docs/kcl/functions/std-math-sqrt.md index 2b07cc97a..dfef051e8 100644 --- a/docs/kcl/std-math-sqrt.md +++ b/docs/kcl/functions/std-math-sqrt.md @@ -9,7 +9,7 @@ Compute the square root of a number. ```kcl -sqrt(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) +sqrt(@input: [number](/docs/kcl/types/std-types-number)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ sqrt(@input: [number](/docs/kcl/types/number)): [number](/docs/kcl/types/number) | Name | Type | Description | Required | |----------|------|-------------|----------| -| `input` | [`number`](/docs/kcl/types/number) | | Yes | +| `input` | [`number`](/docs/kcl/types/std-types-number) | | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/std-math-tan.md b/docs/kcl/functions/std-math-tan.md similarity index 99% rename from docs/kcl/std-math-tan.md rename to docs/kcl/functions/std-math-tan.md index 22ceb195b..034c58c0f 100644 --- a/docs/kcl/std-math-tan.md +++ b/docs/kcl/functions/std-math-tan.md @@ -9,7 +9,7 @@ Compute the tangent of a number. ```kcl -tan(@num: [number](/docs/kcl/types/number)(Angle)): [number](/docs/kcl/types/number)(_) +tan(@num: number(Angle)): number(_) ``` diff --git a/docs/kcl/std-offsetPlane.md b/docs/kcl/functions/std-offsetPlane.md similarity index 99% rename from docs/kcl/std-offsetPlane.md rename to docs/kcl/functions/std-offsetPlane.md index 5d26f6d3f..9d25a9212 100644 --- a/docs/kcl/std-offsetPlane.md +++ b/docs/kcl/functions/std-offsetPlane.md @@ -10,10 +10,10 @@ For example, if you offset the `XZ` plane by 10, the new plane will be parallel plane and 10 units away from it. ```kcl -offset[Plane](/docs/kcl/types/Plane)( - @plane: [Plane](/docs/kcl/types/Plane), - offset: [number](/docs/kcl/types/number)(Length), -): [Plane](/docs/kcl/types/Plane) +offsetPlane( + @plane: [Plane](/docs/kcl/types/std-types-Plane), + offset: number(Length), +): [Plane](/docs/kcl/types/std-types-Plane) ``` @@ -21,12 +21,12 @@ offset[Plane](/docs/kcl/types/Plane)( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `plane` | [`Plane`](/docs/kcl/types/Plane) | The plane (e.g. `XY`) which this new plane is created from. | Yes | +| `plane` | [`Plane`](/docs/kcl/types/std-types-Plane) | The plane (e.g. `XY`) which this new plane is created from. | Yes | | `offset` | `number(Length)` | Distance from the standard plane this new plane will be created at. | Yes | ### Returns -[`Plane`](/docs/kcl/types/Plane) +[`Plane`](/docs/kcl/types/std-types-Plane) ### Examples diff --git a/docs/kcl/std-revolve.md b/docs/kcl/functions/std-revolve.md similarity index 99% rename from docs/kcl/std-revolve.md rename to docs/kcl/functions/std-revolve.md index f59bf77c1..6b6c4aef9 100644 --- a/docs/kcl/std-revolve.md +++ b/docs/kcl/functions/std-revolve.md @@ -19,15 +19,15 @@ revolved around the same axis. ```kcl revolve( - @sketches: [[Sketch](/docs/kcl/types/Sketch); 1+], - axis: [Axis2d](/docs/kcl/types/Axis2d) | [Edge](/docs/kcl/types/Edge), - angle?: [number](/docs/kcl/types/number)(Angle), - tolerance?: [number](/docs/kcl/types/number)(Length), - symmetric?: [bool](/docs/kcl/types/bool), - bidirectionalAngle?: [number](/docs/kcl/types/number)(Angle), - tagStart?: tag, - tagEnd?: tag, -): [Solid](/docs/kcl/types/Solid) + @sketches: [[Sketch; 1+]](/docs/kcl/types/std-types-Sketch), + axis: [Axis2d](/docs/kcl/types/std-types-Axis2d) | [Edge](/docs/kcl/types/std-types-Edge), + angle?: number(Angle), + tolerance?: number(Length), + symmetric?: [bool](/docs/kcl/types/std-types-bool), + bidirectionalAngle?: number(Angle), + tagStart?: [tag](/docs/kcl/types/std-types-tag), + tagEnd?: [tag](/docs/kcl/types/std-types-tag), +): [Solid](/docs/kcl/types/std-types-Solid) ``` @@ -35,18 +35,18 @@ revolve( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | `[Sketch; 1+]` | The sketch or set of sketches that should be revolved | Yes | -| `axis` | [`Axis2d`](/docs/kcl/types/Axis2d) or [`Edge`](/docs/kcl/types/Edge) | Axis of revolution. | Yes | +| `sketches` | [`[Sketch; 1+]`](/docs/kcl/types/std-types-Sketch) | The sketch or set of sketches that should be revolved | Yes | +| `axis` | [`Axis2d`](/docs/kcl/types/std-types-Axis2d) or [`Edge`](/docs/kcl/types/std-types-Edge) | Axis of revolution. | Yes | | `angle` | `number(Angle)` | Angle to revolve (in degrees). Default is 360. | No | | `tolerance` | `number(Length)` | Tolerance for the revolve operation. | No | -| `symmetric` | [`bool`](/docs/kcl/types/bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the extrusion will happen on only one side of the sketch. | No | +| `symmetric` | [`bool`](/docs/kcl/types/std-types-bool) | If true, the extrusion will happen symmetrically around the sketch. Otherwise, the extrusion will happen on only one side of the sketch. | No | | `bidirectionalAngle` | `number(Angle)` | If specified, will also revolve in the opposite direction to 'angle' to the specified angle. If 'symmetric' is true, this value is ignored. | No | -| `tagStart` | `tag` | A named tag for the face at the start of the revolve, i.e. the original sketch. | No | -| `tagEnd` | `tag` | A named tag for the face at the end of the revolve. | No | +| `tagStart` | [`tag`](/docs/kcl/types/std-types-tag) | A named tag for the face at the start of the revolve, i.e. the original sketch. | No | +| `tagEnd` | [`tag`](/docs/kcl/types/std-types-tag) | A named tag for the face at the end of the revolve. | No | ### Returns -[`Solid`](/docs/kcl/types/Solid) +[`Solid`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/std-sketch-circle.md b/docs/kcl/functions/std-sketch-circle.md similarity index 99% rename from docs/kcl/std-sketch-circle.md rename to docs/kcl/functions/std-sketch-circle.md index 288158cc9..00166321a 100644 --- a/docs/kcl/std-sketch-circle.md +++ b/docs/kcl/functions/std-sketch-circle.md @@ -11,11 +11,11 @@ the provided (x, y) origin point. ```kcl circle( - @sketch_or_surface: [Sketch](/docs/kcl/types/Sketch) | [Plane](/docs/kcl/types/Plane) | [Face](/docs/kcl/types/Face), - center: [Point2d](/docs/kcl/types/Point2d), - radius: [number](/docs/kcl/types/number)(Length), - tag?: tag, -): [Sketch](/docs/kcl/types/Sketch) + @sketch_or_surface: [Sketch](/docs/kcl/types/std-types-Sketch) | [Plane](/docs/kcl/types/std-types-Plane) | [Face](/docs/kcl/types/std-types-Face), + center: [Point2d](/docs/kcl/types/std-types-Point2d), + radius: number(Length), + tag?: [tag](/docs/kcl/types/std-types-tag), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -23,14 +23,14 @@ circle( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch_or_surface` | [`Sketch`](/docs/kcl/types/Sketch) or [`Plane`](/docs/kcl/types/Plane) or [`Face`](/docs/kcl/types/Face) | Sketch to extend, or plane or surface to sketch on. | Yes | -| `center` | [`Point2d`](/docs/kcl/types/Point2d) | The center of the circle. | Yes | +| `sketch_or_surface` | [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`Plane`](/docs/kcl/types/std-types-Plane) or [`Face`](/docs/kcl/types/std-types-Face) | Sketch to extend, or plane or surface to sketch on. | Yes | +| `center` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | The center of the circle. | Yes | | `radius` | `number(Length)` | The radius of the circle. | Yes | -| `tag` | `tag` | Create a new tag which refers to this circle. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`tag`](/docs/kcl/types/std-types-tag) | Create a new tag which refers to this circle. | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/std-sketch-mirror2d.md b/docs/kcl/functions/std-sketch-mirror2d.md similarity index 99% rename from docs/kcl/std-sketch-mirror2d.md rename to docs/kcl/functions/std-sketch-mirror2d.md index 53ea5ed58..905570586 100644 --- a/docs/kcl/std-sketch-mirror2d.md +++ b/docs/kcl/functions/std-sketch-mirror2d.md @@ -12,9 +12,9 @@ Mirror occurs around a local sketch axis rather than a global axis. ```kcl mirror2d( - @sketches: [[Sketch](/docs/kcl/types/Sketch); 1+], - axis: [Axis2d](/docs/kcl/types/Axis2d) | [Edge](/docs/kcl/types/Edge), -): [Sketch](/docs/kcl/types/Sketch) + @sketches: [[Sketch; 1+]](/docs/kcl/types/std-types-Sketch), + axis: [Axis2d](/docs/kcl/types/std-types-Axis2d) | [Edge](/docs/kcl/types/std-types-Edge), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -22,12 +22,12 @@ mirror2d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | `[Sketch; 1+]` | The sketch or sketches to be reflected. | Yes | -| `axis` | [`Axis2d`](/docs/kcl/types/Axis2d) or [`Edge`](/docs/kcl/types/Edge) | The axis to reflect around. | Yes | +| `sketches` | [`[Sketch; 1+]`](/docs/kcl/types/std-types-Sketch) | The sketch or sketches to be reflected. | Yes | +| `axis` | [`Axis2d`](/docs/kcl/types/std-types-Axis2d) or [`Edge`](/docs/kcl/types/std-types-Edge) | The axis to reflect around. | Yes | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/std-solid-chamfer.md b/docs/kcl/functions/std-solid-chamfer.md similarity index 99% rename from docs/kcl/std-solid-chamfer.md rename to docs/kcl/functions/std-solid-chamfer.md index 2c9fbf23f..14800cf37 100644 --- a/docs/kcl/std-solid-chamfer.md +++ b/docs/kcl/functions/std-solid-chamfer.md @@ -12,11 +12,11 @@ a sharp, straight transitional edge. ```kcl chamfer( - @solid: [Solid](/docs/kcl/types/Solid), - length: [number](/docs/kcl/types/number)(Length), - tags: [[Edge](/docs/kcl/types/Edge); 1+], - tag?: tag, -): [Solid](/docs/kcl/types/Solid) + @solid: [Solid](/docs/kcl/types/std-types-Solid), + length: number(Length), + tags: [[Edge; 1+]](/docs/kcl/types/std-types-Edge), + tag?: [tag](/docs/kcl/types/std-types-tag), +): [Solid](/docs/kcl/types/std-types-Solid) ``` @@ -24,14 +24,14 @@ chamfer( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solid` | [`Solid`](/docs/kcl/types/Solid) | The solid whose edges should be chamfered | Yes | +| `solid` | [`Solid`](/docs/kcl/types/std-types-Solid) | The solid whose edges should be chamfered | Yes | | `length` | `number(Length)` | The length of the chamfer | Yes | -| `tags` | `[Edge; 1+]` | The paths you want to chamfer | Yes | -| `tag` | `tag` | Create a new tag which refers to this chamfer | No | +| `tags` | [`[Edge; 1+]`](/docs/kcl/types/std-types-Edge) | The paths you want to chamfer | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`tag`](/docs/kcl/types/std-types-tag) | Create a new tag which refers to this chamfer | No | ### Returns -[`Solid`](/docs/kcl/types/Solid) +[`Solid`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/std-solid-fillet.md b/docs/kcl/functions/std-solid-fillet.md similarity index 99% rename from docs/kcl/std-solid-fillet.md rename to docs/kcl/functions/std-solid-fillet.md index c7c67a103..fea89b8d3 100644 --- a/docs/kcl/std-solid-fillet.md +++ b/docs/kcl/functions/std-solid-fillet.md @@ -12,12 +12,12 @@ will smoothly blend the transition. ```kcl fillet( - @solid: [Solid](/docs/kcl/types/Solid), - radius: [number](/docs/kcl/types/number)(Length), - tags: [[Edge](/docs/kcl/types/Edge); 1+], - tolerance?: [number](/docs/kcl/types/number)(Length), - tag?: tag, -): [Solid](/docs/kcl/types/Solid) + @solid: [Solid](/docs/kcl/types/std-types-Solid), + radius: number(Length), + tags: [[Edge; 1+]](/docs/kcl/types/std-types-Edge), + tolerance?: number(Length), + tag?: [tag](/docs/kcl/types/std-types-tag), +): [Solid](/docs/kcl/types/std-types-Solid) ``` @@ -25,15 +25,15 @@ fillet( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solid` | [`Solid`](/docs/kcl/types/Solid) | The solid whose edges should be filletted | Yes | +| `solid` | [`Solid`](/docs/kcl/types/std-types-Solid) | The solid whose edges should be filletted | Yes | | `radius` | `number(Length)` | The radius of the fillet | Yes | -| `tags` | `[Edge; 1+]` | The paths you want to fillet | Yes | +| `tags` | [`[Edge; 1+]`](/docs/kcl/types/std-types-Edge) | The paths you want to fillet | Yes | | `tolerance` | `number(Length)` | The tolerance for this fillet | No | -| `tag` | `tag` | Create a new tag which refers to this fillet | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`tag`](/docs/kcl/types/std-types-tag) | Create a new tag which refers to this fillet | No | ### Returns -[`Solid`](/docs/kcl/types/Solid) +[`Solid`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/std-solid-hollow.md b/docs/kcl/functions/std-solid-hollow.md similarity index 99% rename from docs/kcl/std-solid-hollow.md rename to docs/kcl/functions/std-solid-hollow.md index dfc41a983..7f6f954e4 100644 --- a/docs/kcl/std-solid-hollow.md +++ b/docs/kcl/functions/std-solid-hollow.md @@ -11,9 +11,9 @@ provided thickness remains around the exterior of the shape. ```kcl hollow( - @solid: [Solid](/docs/kcl/types/Solid), - thickness: [number](/docs/kcl/types/number)(Length), -): [Solid](/docs/kcl/types/Solid) + @solid: [Solid](/docs/kcl/types/std-types-Solid), + thickness: number(Length), +): [Solid](/docs/kcl/types/std-types-Solid) ``` @@ -21,12 +21,12 @@ hollow( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solid` | [`Solid`](/docs/kcl/types/Solid) | Which solid to hollow out | Yes | +| `solid` | [`Solid`](/docs/kcl/types/std-types-Solid) | Which solid to hollow out | Yes | | `thickness` | `number(Length)` | The thickness of the remaining shell | Yes | ### Returns -[`Solid`](/docs/kcl/types/Solid) +[`Solid`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/std-solid-shell.md b/docs/kcl/functions/std-solid-shell.md similarity index 99% rename from docs/kcl/std-solid-shell.md rename to docs/kcl/functions/std-solid-shell.md index 38a28970a..f27c9dadf 100644 --- a/docs/kcl/std-solid-shell.md +++ b/docs/kcl/functions/std-solid-shell.md @@ -11,10 +11,10 @@ provided thickness remains, taking volume starting at the providedface, leaving ```kcl shell( - @solids: [[Solid](/docs/kcl/types/Solid); 1+], - thickness: [number](/docs/kcl/types/number)(Length), - faces: [tag; 1+], -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + @solids: [[Solid; 1+]](/docs/kcl/types/std-types-Solid), + thickness: number(Length), + faces: [[tag; 1+]](/docs/kcl/types/std-types-tag), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -22,13 +22,13 @@ shell( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | `[Solid; 1+]` | Which solid (or solids) to shell out | Yes | +| `solids` | [`[Solid; 1+]`](/docs/kcl/types/std-types-Solid) | Which solid (or solids) to shell out | Yes | | `thickness` | `number(Length)` | The thickness of the shell | Yes | -| `faces` | `[tag; 1+]` | The faces you want removed | Yes | +| `faces` | [`[tag; 1+]`](/docs/kcl/types/std-types-tag) | The faces you want removed | Yes | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/std-units-toCentimeters.md b/docs/kcl/functions/std-units-toCentimeters.md similarity index 77% rename from docs/kcl/std-units-toCentimeters.md rename to docs/kcl/functions/std-units-toCentimeters.md index ace5545d1..91b4ee4bd 100644 --- a/docs/kcl/std-units-toCentimeters.md +++ b/docs/kcl/functions/std-units-toCentimeters.md @@ -9,7 +9,7 @@ Convert a number to centimeters from its current units. ```kcl -units::toCentimeters(@num: [number](/docs/kcl/types/number)(cm)): [number](/docs/kcl/types/number)(cm) +units::toCentimeters(@num: number(cm)): number(cm) ``` diff --git a/docs/kcl/std-units-toDegrees.md b/docs/kcl/functions/std-units-toDegrees.md similarity index 99% rename from docs/kcl/std-units-toDegrees.md rename to docs/kcl/functions/std-units-toDegrees.md index f933d817f..269f2ee83 100644 --- a/docs/kcl/std-units-toDegrees.md +++ b/docs/kcl/functions/std-units-toDegrees.md @@ -9,7 +9,7 @@ Converts a number to degrees from its current units. ```kcl -units::toDegrees(@num: [number](/docs/kcl/types/number)(deg)): [number](/docs/kcl/types/number)(deg) +units::toDegrees(@num: number(deg)): number(deg) ``` diff --git a/docs/kcl/std-units-toFeet.md b/docs/kcl/functions/std-units-toFeet.md similarity index 78% rename from docs/kcl/std-units-toFeet.md rename to docs/kcl/functions/std-units-toFeet.md index e641eb290..389efa16d 100644 --- a/docs/kcl/std-units-toFeet.md +++ b/docs/kcl/functions/std-units-toFeet.md @@ -9,7 +9,7 @@ Convert a number to feet from its current units. ```kcl -units::toFeet(@num: [number](/docs/kcl/types/number)(ft)): [number](/docs/kcl/types/number)(ft) +units::toFeet(@num: number(ft)): number(ft) ``` diff --git a/docs/kcl/std-units-toInches.md b/docs/kcl/functions/std-units-toInches.md similarity index 78% rename from docs/kcl/std-units-toInches.md rename to docs/kcl/functions/std-units-toInches.md index 4b5e96720..c38ed2379 100644 --- a/docs/kcl/std-units-toInches.md +++ b/docs/kcl/functions/std-units-toInches.md @@ -9,7 +9,7 @@ Convert a number to inches from its current units. ```kcl -units::toInches(@num: [number](/docs/kcl/types/number)(in)): [number](/docs/kcl/types/number)(in) +units::toInches(@num: number(in)): number(in) ``` diff --git a/docs/kcl/std-units-toMeters.md b/docs/kcl/functions/std-units-toMeters.md similarity index 78% rename from docs/kcl/std-units-toMeters.md rename to docs/kcl/functions/std-units-toMeters.md index e8b059b99..d9e214e67 100644 --- a/docs/kcl/std-units-toMeters.md +++ b/docs/kcl/functions/std-units-toMeters.md @@ -9,7 +9,7 @@ Convert a number to meters from its current units. ```kcl -units::toMeters(@num: [number](/docs/kcl/types/number)(m)): [number](/docs/kcl/types/number)(m) +units::toMeters(@num: number(m)): number(m) ``` diff --git a/docs/kcl/std-units-toMillimeters.md b/docs/kcl/functions/std-units-toMillimeters.md similarity index 77% rename from docs/kcl/std-units-toMillimeters.md rename to docs/kcl/functions/std-units-toMillimeters.md index 1a485b2b5..dafde0542 100644 --- a/docs/kcl/std-units-toMillimeters.md +++ b/docs/kcl/functions/std-units-toMillimeters.md @@ -9,7 +9,7 @@ Convert a number to millimeters from its current units. ```kcl -units::toMillimeters(@num: [number](/docs/kcl/types/number)(mm)): [number](/docs/kcl/types/number)(mm) +units::toMillimeters(@num: number(mm)): number(mm) ``` diff --git a/docs/kcl/std-units-toRadians.md b/docs/kcl/functions/std-units-toRadians.md similarity index 99% rename from docs/kcl/std-units-toRadians.md rename to docs/kcl/functions/std-units-toRadians.md index 6857f4bd7..4fd89d332 100644 --- a/docs/kcl/std-units-toRadians.md +++ b/docs/kcl/functions/std-units-toRadians.md @@ -9,7 +9,7 @@ Converts a number to radians from its current units. ```kcl -units::toRadians(@num: [number](/docs/kcl/types/number)(rad)): [number](/docs/kcl/types/number)(rad) +units::toRadians(@num: number(rad)): number(rad) ``` diff --git a/docs/kcl/std-units-toYards.md b/docs/kcl/functions/std-units-toYards.md similarity index 78% rename from docs/kcl/std-units-toYards.md rename to docs/kcl/functions/std-units-toYards.md index 26de1bbfc..52293f421 100644 --- a/docs/kcl/std-units-toYards.md +++ b/docs/kcl/functions/std-units-toYards.md @@ -9,7 +9,7 @@ Converts a number to yards from its current units. ```kcl -units::toYards(@num: [number](/docs/kcl/types/number)(yd)): [number](/docs/kcl/types/number)(yd) +units::toYards(@num: number(yd)): number(yd) ``` diff --git a/docs/kcl/getCommonEdge.md b/docs/kcl/getCommonEdge.md index e3e4ec748..d24c7a9f6 100644 --- a/docs/kcl/getCommonEdge.md +++ b/docs/kcl/getCommonEdge.md @@ -9,7 +9,7 @@ Get the shared edge between two faces. ```kcl -getCommon[Edge](/docs/kcl/types/Edge)(faces: [[TagIdentifier](/docs/kcl/types#tag-identifier)]): Uuid +getCommonEdge(faces: [[TagIdentifier]](/docs/kcl/types#TagIdentifier)): Uuid ``` @@ -17,7 +17,7 @@ getCommon[Edge](/docs/kcl/types/Edge)(faces: [[TagIdentifier](/docs/kcl/types#ta | Name | Type | Description | Required | |----------|------|-------------|----------| -| `faces` | `[TagIdentifier]` | The tags of the faces you want to find the common edge between | Yes | +| `faces` | [`[TagIdentifier]`](/docs/kcl/types#TagIdentifier) | The tags of the faces you want to find the common edge between | Yes | ### Returns diff --git a/docs/kcl/getNextAdjacentEdge.md b/docs/kcl/getNextAdjacentEdge.md index efb08372b..5486828d1 100644 --- a/docs/kcl/getNextAdjacentEdge.md +++ b/docs/kcl/getNextAdjacentEdge.md @@ -9,7 +9,7 @@ Get the next adjacent edge to the edge given. ```kcl -getNextAdjacent[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/types#tag-identifier)): Uuid +getNextAdjacentEdge(edge: [TagIdentifier](/docs/kcl/types#TagIdentifier)): Uuid ``` @@ -17,7 +17,7 @@ getNextAdjacent[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/type | Name | Type | Description | Required | |----------|------|-------------|----------| -| `edge` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The tag of the edge you want to find the next adjacent edge of. | Yes | +| `edge` | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The tag of the edge you want to find the next adjacent edge of. | Yes | ### Returns diff --git a/docs/kcl/getOppositeEdge.md b/docs/kcl/getOppositeEdge.md index 5503c82fa..47742ed3c 100644 --- a/docs/kcl/getOppositeEdge.md +++ b/docs/kcl/getOppositeEdge.md @@ -9,7 +9,7 @@ Get the opposite edge to the edge given. ```kcl -getOpposite[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/types#tag-identifier)): Uuid +getOppositeEdge(edge: [TagIdentifier](/docs/kcl/types#TagIdentifier)): Uuid ``` @@ -17,7 +17,7 @@ getOpposite[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/types#ta | Name | Type | Description | Required | |----------|------|-------------|----------| -| `edge` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The tag of the edge you want to find the opposite edge of. | Yes | +| `edge` | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The tag of the edge you want to find the opposite edge of. | Yes | ### Returns diff --git a/docs/kcl/getPreviousAdjacentEdge.md b/docs/kcl/getPreviousAdjacentEdge.md index 07f7dca58..31c0ca714 100644 --- a/docs/kcl/getPreviousAdjacentEdge.md +++ b/docs/kcl/getPreviousAdjacentEdge.md @@ -9,7 +9,7 @@ Get the previous adjacent edge to the edge given. ```kcl -getPreviousAdjacent[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/types#tag-identifier)): Uuid +getPreviousAdjacentEdge(edge: [TagIdentifier](/docs/kcl/types#TagIdentifier)): Uuid ``` @@ -17,7 +17,7 @@ getPreviousAdjacent[Edge](/docs/kcl/types/Edge)(edge: [TagIdentifier](/docs/kcl/ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `edge` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The tag of the edge you want to find the previous adjacent edge of. | Yes | +| `edge` | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The tag of the edge you want to find the previous adjacent edge of. | Yes | ### Returns diff --git a/docs/kcl/index.md b/docs/kcl/index.md index 2ad34ff11..59ae2a4a2 100644 --- a/docs/kcl/index.md +++ b/docs/kcl/index.md @@ -12,24 +12,10 @@ layout: manual * [`Modules`](kcl/modules) * [`Settings`](kcl/settings) * [`Known Issues`](kcl/known-issues) -* [`Constants`](kcl/consts) -### Standard library +### Functions -* **Primitive types** - * [`bool`](kcl/types/bool) - * [`number`](kcl/types/number) - * [`string`](kcl/types/string) - * [`tag`](kcl/types/tag) * **std** - * [`END`](kcl/consts/std-END) - * [`START`](kcl/consts/std-START) - * [`X`](kcl/consts/std-X) - * [`XY`](kcl/consts/std-XY) - * [`XZ`](kcl/consts/std-XZ) - * [`Y`](kcl/consts/std-Y) - * [`YZ`](kcl/consts/std-YZ) - * [`Z`](kcl/consts/std-Z) * [`angledLine`](kcl/angledLine) * [`angledLineThatIntersects`](kcl/angledLineThatIntersects) * [`appearance`](kcl/appearance) @@ -45,7 +31,7 @@ layout: manual * [`getNextAdjacentEdge`](kcl/getNextAdjacentEdge) * [`getOppositeEdge`](kcl/getOppositeEdge) * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) - * [`helix`](kcl/std-helix) + * [`helix`](kcl/functions/std-helix) * [`intersect`](kcl/intersect) * [`involuteCircular`](kcl/involuteCircular) * [`lastSegX`](kcl/lastSegX) @@ -56,7 +42,7 @@ layout: manual * [`line`](kcl/line) * [`loft`](kcl/loft) * [`map`](kcl/map) - * [`offsetPlane`](kcl/std-offsetPlane) + * [`offsetPlane`](kcl/functions/std-offsetPlane) * [`patternCircular2d`](kcl/patternCircular2d) * [`patternCircular3d`](kcl/patternCircular3d) * [`patternLinear2d`](kcl/patternLinear2d) @@ -70,7 +56,7 @@ layout: manual * [`profileStartY`](kcl/profileStartY) * [`push`](kcl/push) * [`reduce`](kcl/reduce) - * [`revolve`](kcl/std-revolve) + * [`revolve`](kcl/functions/std-revolve) * [`rotate`](kcl/rotate) * [`scale`](kcl/scale) * [`segAng`](kcl/segAng) @@ -92,61 +78,90 @@ layout: manual * [`union`](kcl/union) * [`xLine`](kcl/xLine) * [`yLine`](kcl/yLine) +* **std::math** + * [`abs`](kcl/functions/std-math-abs) + * [`acos`](kcl/functions/std-math-acos) + * [`asin`](kcl/functions/std-math-asin) + * [`atan`](kcl/functions/std-math-atan) + * [`atan2`](kcl/functions/std-math-atan2) + * [`ceil`](kcl/functions/std-math-ceil) + * [`cos`](kcl/functions/std-math-cos) + * [`floor`](kcl/functions/std-math-floor) + * [`ln`](kcl/functions/std-math-ln) + * [`log`](kcl/functions/std-math-log) + * [`log10`](kcl/functions/std-math-log10) + * [`log2`](kcl/functions/std-math-log2) + * [`max`](kcl/functions/std-math-max) + * [`min`](kcl/functions/std-math-min) + * [`polar`](kcl/functions/std-math-polar) + * [`pow`](kcl/functions/std-math-pow) + * [`rem`](kcl/functions/std-math-rem) + * [`round`](kcl/functions/std-math-round) + * [`sin`](kcl/functions/std-math-sin) + * [`sqrt`](kcl/functions/std-math-sqrt) + * [`tan`](kcl/functions/std-math-tan) +* **std::sketch** + * [`circle`](kcl/functions/std-sketch-circle) + * [`mirror2d`](kcl/functions/std-sketch-mirror2d) +* **std::solid** + * [`chamfer`](kcl/functions/std-solid-chamfer) + * [`fillet`](kcl/functions/std-solid-fillet) + * [`hollow`](kcl/functions/std-solid-hollow) + * [`shell`](kcl/functions/std-solid-shell) +* **std::units** + * [`units::toCentimeters`](kcl/functions/std-units-toCentimeters) + * [`units::toDegrees`](kcl/functions/std-units-toDegrees) + * [`units::toFeet`](kcl/functions/std-units-toFeet) + * [`units::toInches`](kcl/functions/std-units-toInches) + * [`units::toMeters`](kcl/functions/std-units-toMeters) + * [`units::toMillimeters`](kcl/functions/std-units-toMillimeters) + * [`units::toRadians`](kcl/functions/std-units-toRadians) + * [`units::toYards`](kcl/functions/std-units-toYards) + +### Constants + +* **std** + * [`END`](kcl/consts/std-END) + * [`START`](kcl/consts/std-START) + * [`X`](kcl/consts/std-X) + * [`XY`](kcl/consts/std-XY) + * [`XZ`](kcl/consts/std-XZ) + * [`Y`](kcl/consts/std-Y) + * [`YZ`](kcl/consts/std-YZ) + * [`Z`](kcl/consts/std-Z) * **std::math** * [`E`](kcl/consts/std-math-E) * [`PI`](kcl/consts/std-math-PI) * [`TAU`](kcl/consts/std-math-TAU) - * [`abs`](kcl/std-math-abs) - * [`acos`](kcl/std-math-acos) - * [`asin`](kcl/std-math-asin) - * [`atan`](kcl/std-math-atan) - * [`atan2`](kcl/std-math-atan2) - * [`ceil`](kcl/std-math-ceil) - * [`cos`](kcl/std-math-cos) - * [`floor`](kcl/std-math-floor) - * [`ln`](kcl/std-math-ln) - * [`log`](kcl/std-math-log) - * [`log10`](kcl/std-math-log10) - * [`log2`](kcl/std-math-log2) - * [`max`](kcl/std-math-max) - * [`min`](kcl/std-math-min) - * [`polar`](kcl/std-math-polar) - * [`pow`](kcl/std-math-pow) - * [`rem`](kcl/std-math-rem) - * [`round`](kcl/std-math-round) - * [`sin`](kcl/std-math-sin) - * [`sqrt`](kcl/std-math-sqrt) - * [`tan`](kcl/std-math-tan) -* **std::sketch** - * [`circle`](kcl/std-sketch-circle) - * [`mirror2d`](kcl/std-sketch-mirror2d) -* **std::solid** - * [`chamfer`](kcl/std-solid-chamfer) - * [`fillet`](kcl/std-solid-fillet) - * [`hollow`](kcl/std-solid-hollow) - * [`shell`](kcl/std-solid-shell) * **std::turns** * [`turns::HALF_TURN`](kcl/consts/std-turns-HALF_TURN) * [`turns::QUARTER_TURN`](kcl/consts/std-turns-QUARTER_TURN) * [`turns::THREE_QUARTER_TURN`](kcl/consts/std-turns-THREE_QUARTER_TURN) * [`turns::ZERO`](kcl/consts/std-turns-ZERO) + +### Types + +See also the [types overview](types) + +* **Primitive types** + * [`End`](kcl/types.md#End) + * [`ImportedGeometry`](kcl/types.md#ImportedGeometry) + * [`Start`](kcl/types.md#Start) + * [`TagDeclarator`](kcl/types.md#TagDeclarator) + * [`TagIdentifier`](kcl/types.md#TagIdentifier) + * [`any`](kcl/types/std-types-any) + * [`bool`](kcl/types/std-types-bool) + * [`number`](kcl/types/std-types-number) + * [`string`](kcl/types/std-types-string) + * [`tag`](kcl/types/std-types-tag) * **std::types** - * [`Axis2d`](kcl/types/Axis2d) - * [`Axis3d`](kcl/types/Axis3d) - * [`Edge`](kcl/types/Edge) - * [`Face`](kcl/types/Face) - * [`Helix`](kcl/types/Helix) - * [`Plane`](kcl/types/Plane) - * [`Point2d`](kcl/types/Point2d) - * [`Point3d`](kcl/types/Point3d) - * [`Sketch`](kcl/types/Sketch) - * [`Solid`](kcl/types/Solid) -* **std::units** - * [`units::toCentimeters`](kcl/std-units-toCentimeters) - * [`units::toDegrees`](kcl/std-units-toDegrees) - * [`units::toFeet`](kcl/std-units-toFeet) - * [`units::toInches`](kcl/std-units-toInches) - * [`units::toMeters`](kcl/std-units-toMeters) - * [`units::toMillimeters`](kcl/std-units-toMillimeters) - * [`units::toRadians`](kcl/std-units-toRadians) - * [`units::toYards`](kcl/std-units-toYards) + * [`Axis2d`](kcl/types/std-types-Axis2d) + * [`Axis3d`](kcl/types/std-types-Axis3d) + * [`Edge`](kcl/types/std-types-Edge) + * [`Face`](kcl/types/std-types-Face) + * [`Helix`](kcl/types/std-types-Helix) + * [`Plane`](kcl/types/std-types-Plane) + * [`Point2d`](kcl/types/std-types-Point2d) + * [`Point3d`](kcl/types/std-types-Point3d) + * [`Sketch`](kcl/types/std-types-Sketch) + * [`Solid`](kcl/types/std-types-Solid) diff --git a/docs/kcl/int.md b/docs/kcl/int.md deleted file mode 100644 index 1ff85f72b..000000000 --- a/docs/kcl/int.md +++ /dev/null @@ -1,52 +0,0 @@ ---- -title: "int" -excerpt: "Convert a number to an integer." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Convert a number to an integer. - -DEPRECATED use floor(), ceil(), or round(). - -```js -int(num: number): number -``` - -### Tags - -* `convert` - - -### Arguments - -| Name | Type | Description | Required | -|----------|------|-------------|----------| -| `num` | [`number`](/docs/kcl/types/number) | | Yes | - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -n = int(ceil(5 / 2)) -assert(n, isEqualTo = 3, error = "5/2 = 2.5, rounded up makes 3") -// Draw n cylinders. -startSketchOn(XZ) - |> circle(center = [0, 0], radius = 2) - |> extrude(length = 5) - |> patternTransform( - instances = n, - transform = fn(id) { - return { translate = [4 * id, 0, 0] } - }, - ) -``` - -![Rendered example of int 0]() - - diff --git a/docs/kcl/intersect.md b/docs/kcl/intersect.md index 91911bbc0..30310ceb4 100644 --- a/docs/kcl/intersect.md +++ b/docs/kcl/intersect.md @@ -10,9 +10,9 @@ Intersect computes the geometric intersection of multiple solid bodies, returnin ```kcl intersect( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - tolerance?: [number](/docs/kcl/types/number), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + tolerance?: [number](/docs/kcl/types/std-types-number), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -20,12 +20,12 @@ intersect( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to intersect. | Yes | -| `tolerance` | [`number`](/docs/kcl/types/number) | The tolerance to use for the intersection operation. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solids to intersect. | Yes | +| `tolerance` | [`number`](/docs/kcl/types/std-types-number) | The tolerance to use for the intersection operation. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/involuteCircular.md b/docs/kcl/involuteCircular.md index d36928247..c8d790cbe 100644 --- a/docs/kcl/involuteCircular.md +++ b/docs/kcl/involuteCircular.md @@ -10,13 +10,13 @@ Extend the current sketch with a new involute circular curve. ```kcl involuteCircular( - sketch: [Sketch](/docs/kcl/types/Sketch), - startRadius: [number](/docs/kcl/types/number), - endRadius: [number](/docs/kcl/types/number), - angle: [number](/docs/kcl/types/number), - reverse?: [bool](/docs/kcl/types/bool), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + startRadius: [number](/docs/kcl/types/std-types-number), + endRadius: [number](/docs/kcl/types/std-types-number), + angle: [number](/docs/kcl/types/std-types-number), + reverse?: [bool](/docs/kcl/types/std-types-bool), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -24,16 +24,16 @@ involuteCircular( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `startRadius` | [`number`](/docs/kcl/types/number) | The involute is described between two circles, start_radius is the radius of the inner circle. | Yes | -| `endRadius` | [`number`](/docs/kcl/types/number) | The involute is described between two circles, end_radius is the radius of the outer circle. | Yes | -| `angle` | [`number`](/docs/kcl/types/number) | The angle to rotate the involute by. A value of zero will produce a curve with a tangent along the x-axis at the start point of the curve. | Yes | -| `reverse` | [`bool`](/docs/kcl/types/bool) | If reverse is true, the segment will start from the end of the involute, otherwise it will start from that start. Defaults to false. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `startRadius` | [`number`](/docs/kcl/types/std-types-number) | The involute is described between two circles, start_radius is the radius of the inner circle. | Yes | +| `endRadius` | [`number`](/docs/kcl/types/std-types-number) | The involute is described between two circles, end_radius is the radius of the outer circle. | Yes | +| `angle` | [`number`](/docs/kcl/types/std-types-number) | The angle to rotate the involute by. A value of zero will produce a curve with a tangent along the x-axis at the start point of the curve. | Yes | +| `reverse` | [`bool`](/docs/kcl/types/std-types-bool) | If reverse is true, the segment will start from the end of the involute, otherwise it will start from that start. Defaults to false. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/lastSegX.md b/docs/kcl/lastSegX.md index f1d2807e9..9c3a498d9 100644 --- a/docs/kcl/lastSegX.md +++ b/docs/kcl/lastSegX.md @@ -9,7 +9,7 @@ Extract the 'x' axis value of the last line segment in the provided 2-d sketch. ```kcl -lastSegX(sketch: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/number) +lastSegX(sketch: [Sketch](/docs/kcl/types/std-types-Sketch)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ lastSegX(sketch: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/num | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | The sketch whose line segment is being queried | Yes | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | The sketch whose line segment is being queried | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/lastSegY.md b/docs/kcl/lastSegY.md index 3d1d078eb..6c6e72be6 100644 --- a/docs/kcl/lastSegY.md +++ b/docs/kcl/lastSegY.md @@ -9,7 +9,7 @@ Extract the 'y' axis value of the last line segment in the provided 2-d sketch. ```kcl -lastSegY(sketch: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/number) +lastSegY(sketch: [Sketch](/docs/kcl/types/std-types-Sketch)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ lastSegY(sketch: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/num | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | The sketch whose line segment is being queried | Yes | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | The sketch whose line segment is being queried | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/legAngX.md b/docs/kcl/legAngX.md index ea374a70c..6dce39464 100644 --- a/docs/kcl/legAngX.md +++ b/docs/kcl/legAngX.md @@ -10,9 +10,9 @@ Compute the angle of the given leg for x. ```kcl legAngX( - hypotenuse: [number](/docs/kcl/types/number), - leg: [number](/docs/kcl/types/number), -): [number](/docs/kcl/types/number) + hypotenuse: [number](/docs/kcl/types/std-types-number), + leg: [number](/docs/kcl/types/std-types-number), +): [number](/docs/kcl/types/std-types-number) ``` ### Tags @@ -24,12 +24,12 @@ legAngX( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `hypotenuse` | [`number`](/docs/kcl/types/number) | The length of the triangle's hypotenuse | Yes | -| `leg` | [`number`](/docs/kcl/types/number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | +| `hypotenuse` | [`number`](/docs/kcl/types/std-types-number) | The length of the triangle's hypotenuse | Yes | +| `leg` | [`number`](/docs/kcl/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/legAngY.md b/docs/kcl/legAngY.md index 2396c499b..2a5279073 100644 --- a/docs/kcl/legAngY.md +++ b/docs/kcl/legAngY.md @@ -10,9 +10,9 @@ Compute the angle of the given leg for y. ```kcl legAngY( - hypotenuse: [number](/docs/kcl/types/number), - leg: [number](/docs/kcl/types/number), -): [number](/docs/kcl/types/number) + hypotenuse: [number](/docs/kcl/types/std-types-number), + leg: [number](/docs/kcl/types/std-types-number), +): [number](/docs/kcl/types/std-types-number) ``` ### Tags @@ -24,12 +24,12 @@ legAngY( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `hypotenuse` | [`number`](/docs/kcl/types/number) | The length of the triangle's hypotenuse | Yes | -| `leg` | [`number`](/docs/kcl/types/number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | +| `hypotenuse` | [`number`](/docs/kcl/types/std-types-number) | The length of the triangle's hypotenuse | Yes | +| `leg` | [`number`](/docs/kcl/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/legLen.md b/docs/kcl/legLen.md index 052b01a8c..7938bc70c 100644 --- a/docs/kcl/legLen.md +++ b/docs/kcl/legLen.md @@ -10,9 +10,9 @@ Compute the length of the given leg. ```kcl legLen( - hypotenuse: [number](/docs/kcl/types/number), - leg: [number](/docs/kcl/types/number), -): [number](/docs/kcl/types/number) + hypotenuse: [number](/docs/kcl/types/std-types-number), + leg: [number](/docs/kcl/types/std-types-number), +): [number](/docs/kcl/types/std-types-number) ``` ### Tags @@ -24,12 +24,12 @@ legLen( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `hypotenuse` | [`number`](/docs/kcl/types/number) | The length of the triangle's hypotenuse | Yes | -| `leg` | [`number`](/docs/kcl/types/number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | +| `hypotenuse` | [`number`](/docs/kcl/types/std-types-number) | The length of the triangle's hypotenuse | Yes | +| `leg` | [`number`](/docs/kcl/types/std-types-number) | The length of one of the triangle's legs (i.e. non-hypotenuse side) | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/line.md b/docs/kcl/line.md index 89b9d7da5..1f02c6cb5 100644 --- a/docs/kcl/line.md +++ b/docs/kcl/line.md @@ -10,11 +10,11 @@ Extend the current sketch with a new straight line. ```kcl line( - sketch: [Sketch](/docs/kcl/types/Sketch), - endAbsolute?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - end?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + endAbsolute?: [Point2d](/docs/kcl/types/std-types-Point2d), + end?: [Point2d](/docs/kcl/types/std-types-Point2d), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -22,14 +22,14 @@ line( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `endAbsolute` | [`[number]`](/docs/kcl/types/number) | Which absolute point should this line go to? Incompatible with `end`. | No | -| `end` | [`[number]`](/docs/kcl/types/number) | How far away (along the X and Y axes) should this line go? Incompatible with `endAbsolute`. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `endAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Which absolute point should this line go to? Incompatible with `end`. | No | +| `end` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | How far away (along the X and Y axes) should this line go? Incompatible with `endAbsolute`. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/loft.md b/docs/kcl/loft.md index 3f629fbaf..74ce1460c 100644 --- a/docs/kcl/loft.md +++ b/docs/kcl/loft.md @@ -10,14 +10,14 @@ The sketches need to closed and on the same plane. ```kcl loft( - sketches: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - vDegree: NonZeroU32, - bezApproximateRational: [bool](/docs/kcl/types/bool), - baseCurveIndex?: integer, - tolerance?: [number](/docs/kcl/types/number), - tagStart?: [TagDeclarator](/docs/kcl/types#tag-declaration), - tagEnd?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Solid](/docs/kcl/types/Solid) + sketches: [[Sketch]](/docs/kcl/types/std-types-Sketch), + vDegree: [number](/docs/kcl/types/std-types-number), + bezApproximateRational: [bool](/docs/kcl/types/std-types-bool), + baseCurveIndex?: [number](/docs/kcl/types/std-types-number), + tolerance?: [number](/docs/kcl/types/std-types-number), + tagStart?: [TagDeclarator](/docs/kcl/types#TagDeclarator), + tagEnd?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Solid](/docs/kcl/types/std-types-Solid) ``` @@ -25,17 +25,17 @@ loft( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | [`[Sketch]`](/docs/kcl/types/Sketch) | Which sketches to loft. Must include at least 2 sketches. | Yes | -| `vDegree` | `NonZeroU32` | Degree of the interpolation. Must be greater than zero. For example, use 2 for quadratic, or 3 for cubic interpolation in the V direction. This defaults to 2, if not specified. | Yes | -| `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 | +| `sketches` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | Which sketches to loft. Must include at least 2 sketches. | Yes | +| `vDegree` | [`number`](/docs/kcl/types/std-types-number) | Degree of the interpolation. Must be greater than zero. For example, use 2 for quadratic, or 3 for cubic interpolation in the V direction. This defaults to 2, if not specified. | Yes | +| `bezApproximateRational` | [`bool`](/docs/kcl/types/std-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` | [`number`](/docs/kcl/types/std-types-number) | 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/std-types-number) | Tolerance for the loft operation. | No | +| `tagStart` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the start of the loft, i.e. the original sketch | No | +| `tagEnd` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the end of the loft, i.e. the last sketch | No | ### Returns -[`Solid`](/docs/kcl/types/Solid) +[`Solid`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/map.md b/docs/kcl/map.md index 76bfb8754..184dd69d1 100644 --- a/docs/kcl/map.md +++ b/docs/kcl/map.md @@ -6,13 +6,13 @@ layout: manual Apply a function to every element of a list. -Given a list like `[a, b, c]`, and a function like `f`, returns `[f(a), f(b), f(c)]` +Given a list like `[[a, b, c]]`, and a function like `f`, returns `[[f(a), f(b), f(c)]]` ```kcl map( - array: [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/docs/kcl/types/KclValue)), + array: [[any]](/docs/kcl/types/std-types-any), f: FunctionSource, -): [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/docs/kcl/types/KclValue)) +): [[any]](/docs/kcl/types/std-types-any) ``` @@ -20,12 +20,12 @@ map( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `array` | [`[KclValue]`](/docs/kcl/types/KclValue) | Input array. The output array is this input array, but every element has had the function `f` run on it. | Yes | +| `array` | [`[any]`](/docs/kcl/types/std-types-any) | Input array. The output array is this input array, but every element has had the function `f` run on it. | Yes | | `f` | `FunctionSource` | A function. The output array is just the input array, but `f` has been run on every item. | Yes | ### Returns -[`[KclValue]`](/docs/kcl/types/KclValue) +[`[any]`](/docs/kcl/types/std-types-any) ### Examples diff --git a/docs/kcl/patternCircular2d.md b/docs/kcl/patternCircular2d.md index baf651308..228b64b94 100644 --- a/docs/kcl/patternCircular2d.md +++ b/docs/kcl/patternCircular2d.md @@ -10,13 +10,13 @@ Repeat a 2-dimensional sketch some number of times along a partial or complete c ```kcl patternCircular2d( - sketchSet: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - instances: integer, - center: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - arcDegrees: [number](/docs/kcl/types/number), - rotateDuplicates: [bool](/docs/kcl/types/bool), - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)) + sketchSet: [[Sketch]](/docs/kcl/types/std-types-Sketch), + instances: [number](/docs/kcl/types/std-types-number), + center: [Point2d](/docs/kcl/types/std-types-Point2d), + arcDegrees: [number](/docs/kcl/types/std-types-number), + rotateDuplicates: [bool](/docs/kcl/types/std-types-bool), + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Sketch]](/docs/kcl/types/std-types-Sketch) ``` @@ -24,16 +24,16 @@ patternCircular2d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketchSet` | [`[Sketch]`](/docs/kcl/types/Sketch) | Which sketch(es) to pattern | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | -| `center` | [`[number]`](/docs/kcl/types/number) | The center about which to make the pattern. This is a 2D vector. | Yes | -| `arcDegrees` | [`number`](/docs/kcl/types/number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | Yes | -| `rotateDuplicates` | [`bool`](/docs/kcl/types/bool) | Whether or not to rotate the duplicates as they are copied. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `sketchSet` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | Which sketch(es) to pattern | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `center` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | The center about which to make the pattern. This is a 2D vector. | Yes | +| `arcDegrees` | [`number`](/docs/kcl/types/std-types-number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | Yes | +| `rotateDuplicates` | [`bool`](/docs/kcl/types/std-types-bool) | Whether or not to rotate the duplicates as they are copied. | Yes | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Sketch]`](/docs/kcl/types/Sketch) +[`[Sketch]`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/patternCircular3d.md b/docs/kcl/patternCircular3d.md index a7eb350ed..1c4e5ba45 100644 --- a/docs/kcl/patternCircular3d.md +++ b/docs/kcl/patternCircular3d.md @@ -10,14 +10,14 @@ Repeat a 3-dimensional solid some number of times along a partial or complete ci ```kcl patternCircular3d( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - instances: integer, - axis: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - center: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - arcDegrees: [number](/docs/kcl/types/number), - rotateDuplicates: [bool](/docs/kcl/types/bool), - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + instances: [number](/docs/kcl/types/std-types-number), + axis: [[number]](/docs/kcl/types/std-types-number), + center: [Point3d](/docs/kcl/types/std-types-Point3d), + arcDegrees: [number](/docs/kcl/types/std-types-number), + rotateDuplicates: [bool](/docs/kcl/types/std-types-bool), + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -25,17 +25,17 @@ patternCircular3d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | Which solid(s) to pattern | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | -| `axis` | [`[number]`](/docs/kcl/types/number) | The axis around which to make the pattern. This is a 3D vector | Yes | -| `center` | [`[number]`](/docs/kcl/types/number) | The center about which to make the pattern. This is a 3D vector. | Yes | -| `arcDegrees` | [`number`](/docs/kcl/types/number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | Yes | -| `rotateDuplicates` | [`bool`](/docs/kcl/types/bool) | Whether or not to rotate the duplicates as they are copied. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | Which solid(s) to pattern | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `axis` | [`[number]`](/docs/kcl/types/std-types-number) | The axis around which to make the pattern. This is a 3D vector | Yes | +| `center` | [`Point3d`](/docs/kcl/types/std-types-Point3d) | The center about which to make the pattern. This is a 3D vector. | Yes | +| `arcDegrees` | [`number`](/docs/kcl/types/std-types-number) | The arc angle (in degrees) to place the repetitions. Must be greater than 0. | Yes | +| `rotateDuplicates` | [`bool`](/docs/kcl/types/std-types-bool) | Whether or not to rotate the duplicates as they are copied. | Yes | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/patternLinear2d.md b/docs/kcl/patternLinear2d.md index ac9fc71ad..44e8030b6 100644 --- a/docs/kcl/patternLinear2d.md +++ b/docs/kcl/patternLinear2d.md @@ -10,12 +10,12 @@ Repeat a 2-dimensional sketch along some dimension, with a dynamic amount of dis ```kcl patternLinear2d( - sketches: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - instances: integer, - distance: [number](/docs/kcl/types/number), - axis: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)) + sketches: [[Sketch]](/docs/kcl/types/std-types-Sketch), + instances: [number](/docs/kcl/types/std-types-number), + distance: [number](/docs/kcl/types/std-types-number), + axis: [Point2d](/docs/kcl/types/std-types-Point2d), + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Sketch]](/docs/kcl/types/std-types-Sketch) ``` @@ -23,15 +23,15 @@ patternLinear2d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | [`[Sketch]`](/docs/kcl/types/Sketch) | The sketch(es) to duplicate | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | -| `distance` | [`number`](/docs/kcl/types/number) | Distance between each repetition. Also known as 'spacing'. | Yes | -| `axis` | [`[number]`](/docs/kcl/types/number) | The axis of the pattern. A 2D vector. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `sketches` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | The sketch(es) to duplicate | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `distance` | [`number`](/docs/kcl/types/std-types-number) | Distance between each repetition. Also known as 'spacing'. | Yes | +| `axis` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | The axis of the pattern. A 2D vector. | Yes | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Sketch]`](/docs/kcl/types/Sketch) +[`[Sketch]`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/patternLinear3d.md b/docs/kcl/patternLinear3d.md index f6c556eae..c8c3598a7 100644 --- a/docs/kcl/patternLinear3d.md +++ b/docs/kcl/patternLinear3d.md @@ -10,12 +10,12 @@ Repeat a 3-dimensional solid along a linear path, with a dynamic amount of dista ```kcl patternLinear3d( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - instances: integer, - distance: [number](/docs/kcl/types/number), - axis: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + instances: [number](/docs/kcl/types/std-types-number), + distance: [number](/docs/kcl/types/std-types-number), + axis: [Point3d](/docs/kcl/types/std-types-Point3d), + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -23,15 +23,15 @@ patternLinear3d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solid(s) to duplicate | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | -| `distance` | [`number`](/docs/kcl/types/number) | Distance between each repetition. Also known as 'spacing'. | Yes | -| `axis` | [`[number]`](/docs/kcl/types/number) | The axis of the pattern. A 2D vector. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solid(s) to duplicate | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `distance` | [`number`](/docs/kcl/types/std-types-number) | Distance between each repetition. Also known as 'spacing'. | Yes | +| `axis` | [`Point3d`](/docs/kcl/types/std-types-Point3d) | The axis of the pattern. A 2D vector. | Yes | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/patternTransform.md b/docs/kcl/patternTransform.md index 943e3ee60..cb50f9784 100644 --- a/docs/kcl/patternTransform.md +++ b/docs/kcl/patternTransform.md @@ -36,11 +36,11 @@ The transform function returns a transform object. All properties of the object ```kcl patternTransform( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - instances: integer, + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + instances: [number](/docs/kcl/types/std-types-number), transform: FunctionSource, - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -48,14 +48,14 @@ patternTransform( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solid(s) to duplicate | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solid(s) to duplicate | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | `transform` | `FunctionSource` | How each replica should be transformed. The transform function takes a single parameter: an integer representing which number replication the transform is for. E.g. the first replica to be transformed will be passed the argument `1`. This simplifies your math: the transform function can rely on id `0` being the original instance passed into the `patternTransform`. See the examples. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/patternTransform2d.md b/docs/kcl/patternTransform2d.md index 0b4cb79b1..c13ce9795 100644 --- a/docs/kcl/patternTransform2d.md +++ b/docs/kcl/patternTransform2d.md @@ -10,11 +10,11 @@ Just like patternTransform, but works on 2D sketches not 3D solids. ```kcl patternTransform2d( - sketches: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - instances: integer, + sketches: [[Sketch]](/docs/kcl/types/std-types-Sketch), + instances: [number](/docs/kcl/types/std-types-number), transform: FunctionSource, - useOriginal?: [bool](/docs/kcl/types/bool), -): [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)) + useOriginal?: [bool](/docs/kcl/types/std-types-bool), +): [[Sketch]](/docs/kcl/types/std-types-Sketch) ``` @@ -22,14 +22,14 @@ patternTransform2d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | [`[Sketch]`](/docs/kcl/types/Sketch) | The sketch(es) to duplicate | Yes | -| `instances` | `integer` | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | +| `sketches` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | The sketch(es) to duplicate | Yes | +| `instances` | [`number`](/docs/kcl/types/std-types-number) | The number of total instances. Must be greater than or equal to 1. This includes the original entity. For example, if instances is 2, there will be two copies -- the original, and one new copy. If instances is 1, this has no effect. | Yes | | `transform` | `FunctionSource` | How each replica should be transformed. The transform function takes a single parameter: an integer representing which number replication the transform is for. E.g. the first replica to be transformed will be passed the argument `1`. This simplifies your math: the transform function can rely on id `0` being the original instance passed into the `patternTransform`. See the examples. | Yes | -| `useOriginal` | [`bool`](/docs/kcl/types/bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | +| `useOriginal` | [`bool`](/docs/kcl/types/std-types-bool) | If the target was sketched on an extrusion, setting this will use the original sketch as the target, not the entire joined solid. Defaults to false. | No | ### Returns -[`[Sketch]`](/docs/kcl/types/Sketch) +[`[Sketch]`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/pi.md b/docs/kcl/pi.md deleted file mode 100644 index 9f96bbd79..000000000 --- a/docs/kcl/pi.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -title: "pi" -excerpt: "Return the value of `pi`. Archimedes’ constant (π)." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Return the value of `pi`. Archimedes’ constant (π). - -**DEPRECATED** use the constant PI - -```js -pi(): number -``` - -### Tags - -* `math` - - - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -circumference = 70 - -exampleSketch = startSketchOn(XZ) - |> circle(center = [0, 0], radius = circumference / (2 * pi())) - -example = extrude(exampleSketch, length = 5) -``` - -![Rendered example of pi 0]() - - diff --git a/docs/kcl/polygon.md b/docs/kcl/polygon.md index 9db5c25b6..ebdc19289 100644 --- a/docs/kcl/polygon.md +++ b/docs/kcl/polygon.md @@ -10,12 +10,12 @@ Create a regular polygon with the specified number of sides that is either inscr ```kcl polygon( - sketchSurfaceOrGroup: [[Sketch](/docs/kcl/types/Sketch)OrSurface](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)OrSurface), - radius: [number](/docs/kcl/types/number), + sketchSurfaceOrGroup: [Sketch](/docs/kcl/types/std-types-Sketch) | [Plane](/docs/kcl/types/std-types-Plane) | [Face](/docs/kcl/types/std-types-Face), + radius: [number](/docs/kcl/types/std-types-number), numSides: u64, - center: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - inscribed?: [bool](/docs/kcl/types/bool), -): [Sketch](/docs/kcl/types/Sketch) + center: [Point2d](/docs/kcl/types/std-types-Point2d), + inscribed?: [bool](/docs/kcl/types/std-types-bool), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -23,15 +23,15 @@ polygon( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketchSurfaceOrGroup` | [`SketchOrSurface`](/docs/kcl/types/SketchOrSurface) | Plane or surface to sketch on | Yes | -| `radius` | [`number`](/docs/kcl/types/number) | The radius of the polygon | Yes | +| `sketchSurfaceOrGroup` | [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`Plane`](/docs/kcl/types/std-types-Plane) or [`Face`](/docs/kcl/types/std-types-Face) | Plane or surface to sketch on | Yes | +| `radius` | [`number`](/docs/kcl/types/std-types-number) | The radius of the polygon | Yes | | `numSides` | `u64` | The number of sides in the polygon | Yes | -| `center` | [`[number]`](/docs/kcl/types/number) | The center point of the polygon | Yes | -| `inscribed` | [`bool`](/docs/kcl/types/bool) | Whether the polygon is inscribed (true, the default) or circumscribed (false) about a circle with the specified radius | No | +| `center` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | The center point of the polygon | Yes | +| `inscribed` | [`bool`](/docs/kcl/types/std-types-bool) | Whether the polygon is inscribed (true, the default) or circumscribed (false) about a circle with the specified radius | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/pop.md b/docs/kcl/pop.md index 39e0f83f3..289d401f0 100644 --- a/docs/kcl/pop.md +++ b/docs/kcl/pop.md @@ -9,7 +9,7 @@ Remove the last element from an array. Returns a new array with the last element removed. ```kcl -pop(array: [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/docs/kcl/types/KclValue))): [KclValue](/docs/kcl/types/KclValue) +pop(array: [[any]](/docs/kcl/types/std-types-any)): [any](/docs/kcl/types/std-types-any) ``` @@ -17,11 +17,11 @@ pop(array: [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `array` | [`[KclValue]`](/docs/kcl/types/KclValue) | The array to pop from. Must not be empty. | Yes | +| `array` | [`[any]`](/docs/kcl/types/std-types-any) | The array to pop from. Must not be empty. | Yes | ### Returns -[`KclValue`](/docs/kcl/types/KclValue) - Any KCL value. +[`any`](/docs/kcl/types/std-types-any) - Any KCL value. ### Examples diff --git a/docs/kcl/profileStart.md b/docs/kcl/profileStart.md index 7d9b17c8e..049513689 100644 --- a/docs/kcl/profileStart.md +++ b/docs/kcl/profileStart.md @@ -9,7 +9,7 @@ Extract the provided 2-dimensional sketch's profile's origin value. ```kcl -profileStart(profile: [Sketch](/docs/kcl/types/Sketch)): [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)) +profileStart(profile: [Sketch](/docs/kcl/types/std-types-Sketch)): [[number]](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ profileStart(profile: [Sketch](/docs/kcl/types/Sketch)): [[[number](/docs/kcl/ty | Name | Type | Description | Required | |----------|------|-------------|----------| -| `profile` | [`Sketch`](/docs/kcl/types/Sketch) | Profile whose start is being used | Yes | +| `profile` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Profile whose start is being used | Yes | ### Returns -[`[number]`](/docs/kcl/types/number) +[`[number]`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/profileStartX.md b/docs/kcl/profileStartX.md index a0cf57202..104ed31ea 100644 --- a/docs/kcl/profileStartX.md +++ b/docs/kcl/profileStartX.md @@ -9,7 +9,7 @@ Extract the provided 2-dimensional sketch's profile's origin's 'x' value. ```kcl -profileStartX(profile: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/number) +profileStartX(profile: [Sketch](/docs/kcl/types/std-types-Sketch)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ profileStartX(profile: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/typ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `profile` | [`Sketch`](/docs/kcl/types/Sketch) | Profile whose start is being used | Yes | +| `profile` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Profile whose start is being used | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/profileStartY.md b/docs/kcl/profileStartY.md index 86bd57fa8..b3cde12f6 100644 --- a/docs/kcl/profileStartY.md +++ b/docs/kcl/profileStartY.md @@ -9,7 +9,7 @@ Extract the provided 2-dimensional sketch's profile's origin's 'y' value. ```kcl -profileStartY(profile: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/types/number) +profileStartY(profile: [Sketch](/docs/kcl/types/std-types-Sketch)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ profileStartY(profile: [Sketch](/docs/kcl/types/Sketch)): [number](/docs/kcl/typ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `profile` | [`Sketch`](/docs/kcl/types/Sketch) | Profile whose start is being used | Yes | +| `profile` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Profile whose start is being used | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/push.md b/docs/kcl/push.md index 442a78cc5..bc91896b6 100644 --- a/docs/kcl/push.md +++ b/docs/kcl/push.md @@ -10,9 +10,9 @@ Returns a new array with the element appended. ```kcl push( - array: [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/docs/kcl/types/KclValue)), - item: [KclValue](/docs/kcl/types/KclValue), -): [KclValue](/docs/kcl/types/KclValue) + array: [[any]](/docs/kcl/types/std-types-any), + item: [any](/docs/kcl/types/std-types-any), +): [any](/docs/kcl/types/std-types-any) ``` @@ -20,12 +20,12 @@ push( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `array` | [`[KclValue]`](/docs/kcl/types/KclValue) | The array which you're adding a new item to. | Yes | -| `item` | [`KclValue`](/docs/kcl/types/KclValue) | The new item to add to the array | Yes | +| `array` | [`[any]`](/docs/kcl/types/std-types-any) | The array which you're adding a new item to. | Yes | +| `item` | [`any`](/docs/kcl/types/std-types-any) | The new item to add to the array | Yes | ### Returns -[`KclValue`](/docs/kcl/types/KclValue) - Any KCL value. +[`any`](/docs/kcl/types/std-types-any) - Any KCL value. ### Examples diff --git a/docs/kcl/reduce.md b/docs/kcl/reduce.md index 64f131f36..e1ec6be93 100644 --- a/docs/kcl/reduce.md +++ b/docs/kcl/reduce.md @@ -10,10 +10,10 @@ Take a starting value. Then, for each element of an array, calculate the next va ```kcl reduce( - array: [[[KclValue](/docs/kcl/types/KclValue)]](/docs/kcl/types/[KclValue](/docs/kcl/types/KclValue)), - initial: [KclValue](/docs/kcl/types/KclValue), + array: [[any]](/docs/kcl/types/std-types-any), + initial: [any](/docs/kcl/types/std-types-any), f: FunctionSource, -): [KclValue](/docs/kcl/types/KclValue) +): [any](/docs/kcl/types/std-types-any) ``` @@ -21,13 +21,13 @@ reduce( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `array` | [`[KclValue]`](/docs/kcl/types/KclValue) | Each element of this array gets run through the function `f`, combined with the previous output from `f`, and then used for the next run. | Yes | -| `initial` | [`KclValue`](/docs/kcl/types/KclValue) | The first time `f` is run, it will be called with the first item of `array` and this initial starting value. | Yes | +| `array` | [`[any]`](/docs/kcl/types/std-types-any) | Each element of this array gets run through the function `f`, combined with the previous output from `f`, and then used for the next run. | Yes | +| `initial` | [`any`](/docs/kcl/types/std-types-any) | The first time `f` is run, it will be called with the first item of `array` and this initial starting value. | Yes | | `f` | `FunctionSource` | Run once per item in the input `array`. This function takes an item from the array, and the previous output from `f` (or `initial` on the very first run). The final time `f` is run, its output is returned as the final output from `reduce`. | Yes | ### Returns -[`KclValue`](/docs/kcl/types/KclValue) - Any KCL value. +[`any`](/docs/kcl/types/std-types-any) - Any KCL value. ### Examples diff --git a/docs/kcl/rotate.md b/docs/kcl/rotate.md index 922db39bd..200e0fd50 100644 --- a/docs/kcl/rotate.md +++ b/docs/kcl/rotate.md @@ -28,14 +28,14 @@ When rotating a part around an axis, you specify the axis of rotation and the an ```kcl rotate( - objects: [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry), - roll?: [number](/docs/kcl/types/number), - pitch?: [number](/docs/kcl/types/number), - yaw?: [number](/docs/kcl/types/number), - axis?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - angle?: [number](/docs/kcl/types/number), - global?: [bool](/docs/kcl/types/bool), -): [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry) + objects: [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry), + roll?: [number](/docs/kcl/types/std-types-number), + pitch?: [number](/docs/kcl/types/std-types-number), + yaw?: [number](/docs/kcl/types/std-types-number), + axis?: [[number]](/docs/kcl/types/std-types-number), + angle?: [number](/docs/kcl/types/std-types-number), + global?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry) ``` @@ -43,17 +43,17 @@ rotate( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to rotate. | Yes | -| `roll` | [`number`](/docs/kcl/types/number) | The roll angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | -| `pitch` | [`number`](/docs/kcl/types/number) | The pitch angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | -| `yaw` | [`number`](/docs/kcl/types/number) | The yaw angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | -| `axis` | [`[number]`](/docs/kcl/types/number) | The axis to rotate around. Must be used with `angle`. | No | -| `angle` | [`number`](/docs/kcl/types/number) | The angle to rotate in degrees. Must be used with `axis`. Must be between -360 and 360. | No | -| `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 | +| `objects` | [`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) | The solid, sketch, or set of solids or sketches to rotate. | Yes | +| `roll` | [`number`](/docs/kcl/types/std-types-number) | The roll angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | +| `pitch` | [`number`](/docs/kcl/types/std-types-number) | The pitch angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | +| `yaw` | [`number`](/docs/kcl/types/std-types-number) | The yaw angle in degrees. Must be between -360 and 360. Default is 0 if not given. | No | +| `axis` | [`[number]`](/docs/kcl/types/std-types-number) | The axis to rotate around. Must be used with `angle`. | No | +| `angle` | [`number`](/docs/kcl/types/std-types-number) | The angle to rotate in degrees. Must be used with `axis`. Must be between -360 and 360. | No | +| `global` | [`bool`](/docs/kcl/types/std-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 -[`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) - Data for a solid, sketch, or an imported geometry. +[`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) - Data for a solid, sketch, or an imported geometry. ### Examples diff --git a/docs/kcl/scale.md b/docs/kcl/scale.md index 70671ef43..f4cce07b8 100644 --- a/docs/kcl/scale.md +++ b/docs/kcl/scale.md @@ -16,12 +16,12 @@ If you want to apply the transform in global space, set `global` to `true`. The ```kcl scale( - objects: [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry), - x?: [number](/docs/kcl/types/number), - y?: [number](/docs/kcl/types/number), - z?: [number](/docs/kcl/types/number), - global?: [bool](/docs/kcl/types/bool), -): [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry) + objects: [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry), + x?: [number](/docs/kcl/types/std-types-number), + y?: [number](/docs/kcl/types/std-types-number), + z?: [number](/docs/kcl/types/std-types-number), + global?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry) ``` @@ -29,15 +29,15 @@ scale( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to scale. | Yes | -| `x` | [`number`](/docs/kcl/types/number) | The scale factor for the x axis. Default is 1 if not provided. | No | -| `y` | [`number`](/docs/kcl/types/number) | The scale factor for the y axis. Default is 1 if not provided. | No | -| `z` | [`number`](/docs/kcl/types/number) | The scale factor for the z axis. Default is 1 if not provided. | No | -| `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 | +| `objects` | [`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) | The solid, sketch, or set of solids or sketches to scale. | Yes | +| `x` | [`number`](/docs/kcl/types/std-types-number) | The scale factor for the x axis. Default is 1 if not provided. | No | +| `y` | [`number`](/docs/kcl/types/std-types-number) | The scale factor for the y axis. Default is 1 if not provided. | No | +| `z` | [`number`](/docs/kcl/types/std-types-number) | The scale factor for the z axis. Default is 1 if not provided. | No | +| `global` | [`bool`](/docs/kcl/types/std-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 -[`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) - Data for a solid, sketch, or an imported geometry. +[`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) - Data for a solid, sketch, or an imported geometry. ### Examples diff --git a/docs/kcl/segAng.md b/docs/kcl/segAng.md index c70a1a886..c98e541b1 100644 --- a/docs/kcl/segAng.md +++ b/docs/kcl/segAng.md @@ -9,7 +9,7 @@ Compute the angle (in degrees) of the provided line segment. ```kcl -segAng(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segAng(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segAng(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/segEnd.md b/docs/kcl/segEnd.md index f4c396042..bf823c756 100644 --- a/docs/kcl/segEnd.md +++ b/docs/kcl/segEnd.md @@ -9,7 +9,7 @@ Compute the ending point of the provided line segment. ```kcl -segEnd(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)) +segEnd(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [Point2d](/docs/kcl/types/std-types-Point2d) ``` @@ -17,11 +17,11 @@ segEnd(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [[[number](/docs/k | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`[number]`](/docs/kcl/types/number) +[`Point2d`](/docs/kcl/types/std-types-Point2d) ### Examples diff --git a/docs/kcl/segEndX.md b/docs/kcl/segEndX.md index 8ae1ed0a4..95a5d7cf0 100644 --- a/docs/kcl/segEndX.md +++ b/docs/kcl/segEndX.md @@ -9,7 +9,7 @@ Compute the ending point of the provided line segment along the 'x' axis. ```kcl -segEndX(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segEndX(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segEndX(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kc | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/segEndY.md b/docs/kcl/segEndY.md index d02209c00..76e42c185 100644 --- a/docs/kcl/segEndY.md +++ b/docs/kcl/segEndY.md @@ -9,7 +9,7 @@ Compute the ending point of the provided line segment along the 'y' axis. ```kcl -segEndY(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segEndY(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segEndY(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kc | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/segLen.md b/docs/kcl/segLen.md index fc3736075..abc7d5e73 100644 --- a/docs/kcl/segLen.md +++ b/docs/kcl/segLen.md @@ -9,7 +9,7 @@ Compute the length of the provided line segment. ```kcl -segLen(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segLen(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segLen(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/segStart.md b/docs/kcl/segStart.md index f981f7c2c..5d284f324 100644 --- a/docs/kcl/segStart.md +++ b/docs/kcl/segStart.md @@ -9,7 +9,7 @@ Compute the starting point of the provided line segment. ```kcl -segStart(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)) +segStart(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [Point2d](/docs/kcl/types/std-types-Point2d) ``` @@ -17,11 +17,11 @@ segStart(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [[[number](/docs | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`[number]`](/docs/kcl/types/number) +[`Point2d`](/docs/kcl/types/std-types-Point2d) ### Examples diff --git a/docs/kcl/segStartX.md b/docs/kcl/segStartX.md index 15373381a..c9ac34019 100644 --- a/docs/kcl/segStartX.md +++ b/docs/kcl/segStartX.md @@ -9,7 +9,7 @@ Compute the starting point of the provided line segment along the 'x' axis. ```kcl -segStartX(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segStartX(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segStartX(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/segStartY.md b/docs/kcl/segStartY.md index 579eec013..dc78c0a80 100644 --- a/docs/kcl/segStartY.md +++ b/docs/kcl/segStartY.md @@ -9,7 +9,7 @@ Compute the starting point of the provided line segment along the 'y' axis. ```kcl -segStartY(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +segStartY(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ segStartY(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/ | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/settings/project.md b/docs/kcl/settings-project.md similarity index 100% rename from docs/kcl/settings/project.md rename to docs/kcl/settings-project.md diff --git a/docs/kcl/settings/user.md b/docs/kcl/settings-user.md similarity index 100% rename from docs/kcl/settings/user.md rename to docs/kcl/settings-user.md diff --git a/docs/kcl/settings.md b/docs/kcl/settings.md index 4aaaeb783..fef877621 100644 --- a/docs/kcl/settings.md +++ b/docs/kcl/settings.md @@ -8,16 +8,16 @@ layout: manual There are three levels of settings available in Zoo Design Studio: -1. [User Settings](/docs/kcl/settings/user): Global settings that apply to all projects, stored in `user.toml` -2. [Project Settings](/docs/kcl/settings/project): Settings specific to a project, stored in `project.toml` +1. [User Settings](/docs/kcl/settings-user): Global settings that apply to all projects, stored in `user.toml` +2. [Project Settings](/docs/kcl/settings-project): Settings specific to a project, stored in `project.toml` 3. Per-file Settings: Settings that apply to a single KCL file, specified using the `@settings` attribute ## Configuration Files Zoo Design Studio uses TOML files for configuration: -* **User Settings**: `user.toml` - See [complete documentation](/docs/kcl/settings/user) -* **Project Settings**: `project.toml` - See [complete documentation](/docs/kcl/settings/project) +* **User Settings**: `user.toml` - See [complete documentation](/docs/kcl/settings-user) +* **Project Settings**: `project.toml` - See [complete documentation](/docs/kcl/settings-project) ## Per-file settings @@ -25,7 +25,7 @@ Settings which affect a single file are configured using the settings attribute. This must be at the top of the KCL file (comments before the attribute are permitted). For example: -```js +```kcl // The settings attribute. @settings(defaultLengthUnit = in) diff --git a/docs/kcl/startProfile.md b/docs/kcl/startProfile.md index fbf1aa4f4..34990b8c5 100644 --- a/docs/kcl/startProfile.md +++ b/docs/kcl/startProfile.md @@ -10,10 +10,10 @@ Start a new profile at a given point. ```kcl startProfile( - sketchSurface: [[Sketch](/docs/kcl/types/Sketch)Surface](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)Surface), - at: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketchSurface: [Plane](/docs/kcl/types/std-types-Plane) | [Face](/docs/kcl/types/std-types-Face), + at: [Point2d](/docs/kcl/types/std-types-Point2d), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -21,13 +21,13 @@ startProfile( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketchSurface` | [`SketchSurface`](/docs/kcl/types/SketchSurface) | What to start the profile on | Yes | -| `at` | [`[number]`](/docs/kcl/types/number) | Where to start the profile. An absolute point. | Yes | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Tag this first starting point | No | +| `sketchSurface` | [`Plane`](/docs/kcl/types/std-types-Plane) or [`Face`](/docs/kcl/types/std-types-Face) | What to start the profile on | Yes | +| `at` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Where to start the profile. An absolute point. | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Tag this first starting point | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/startSketchOn.md b/docs/kcl/startSketchOn.md index caf341b63..57068de97 100644 --- a/docs/kcl/startSketchOn.md +++ b/docs/kcl/startSketchOn.md @@ -17,10 +17,10 @@ This is important to understand because if you were to then sketch on the result 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. ```kcl -start[Sketch](/docs/kcl/types/Sketch)On( - planeOr[Solid](/docs/kcl/types/Solid): [[Sketch](/docs/kcl/types/Sketch)Data](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)Data), - face?: [[Face](/docs/kcl/types/Face)Tag](/docs/kcl/types/[Face](/docs/kcl/types/Face)Tag), -): [[Sketch](/docs/kcl/types/Sketch)Surface](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)Surface) +startSketchOn( + planeOrSolid: [Plane](/docs/kcl/types/std-types-Plane) | [Solid](/docs/kcl/types/std-types-Solid), + face?: [TagIdentifier](/docs/kcl/types#TagIdentifier) | [Start](/docs/kcl/types#Start) | [End](/docs/kcl/types#End), +): [Plane](/docs/kcl/types/std-types-Plane) | [Face](/docs/kcl/types/std-types-Face) ``` @@ -28,12 +28,12 @@ start[Sketch](/docs/kcl/types/Sketch)On( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `planeOrSolid` | [`SketchData`](/docs/kcl/types/SketchData) | The plane or solid to sketch on | Yes | -| `face` | [`FaceTag`](/docs/kcl/types/FaceTag) | Identify a face of a solid if a solid is specified as the input argument (`plane_or_solid`) | No | +| `planeOrSolid` | [`Plane`](/docs/kcl/types/std-types-Plane) or [`Solid`](/docs/kcl/types/std-types-Solid) | The plane or solid to sketch on | Yes | +| `face` | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) or [`Start`](/docs/kcl/types#Start) or [`End`](/docs/kcl/types#End) | Identify a face of a solid if a solid is specified as the input argument (`plane_or_solid`) | No | ### Returns -[`SketchSurface`](/docs/kcl/types/SketchSurface) - A sketch type. +[`Plane`](/docs/kcl/types/std-types-Plane) or [`Face`](/docs/kcl/types/std-types-Face) - A sketch type. ### Examples diff --git a/docs/kcl/std.json b/docs/kcl/std.json index 79f357358..5e18cb76f 100644 --- a/docs/kcl/std.json +++ b/docs/kcl/std.json @@ -26035,7 +26035,7 @@ }, { "name": "color", - "type": "String", + "type": "string", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "String", @@ -39018,7 +39018,7 @@ }, { "name": "interiorAbsolute", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", @@ -40627,7 +40627,7 @@ }, { "name": "endAbsolute", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", @@ -45676,7 +45676,7 @@ }, { "name": "error", - "type": "String", + "type": "string", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_String", @@ -45734,7 +45734,7 @@ }, { "name": "error", - "type": "String", + "type": "string", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_String", @@ -47438,7 +47438,7 @@ }, { "name": "control1", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -49047,7 +49047,7 @@ }, { "name": "control2", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -50656,7 +50656,7 @@ }, { "name": "end", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -57163,7 +57163,7 @@ }, { "name": "p1", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -58772,7 +58772,7 @@ }, { "name": "p2", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -60381,7 +60381,7 @@ }, { "name": "p3", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -106721,7 +106721,7 @@ }, { "name": "endAbsolute", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", @@ -108330,7 +108330,7 @@ }, { "name": "end", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", @@ -114833,7 +114833,7 @@ }, { "name": "vDegree", - "type": "NonZeroU32", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "NonZeroU32", @@ -118043,7 +118043,7 @@ }, { "name": "baseCurveIndex", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_uint32", @@ -135234,7 +135234,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -136840,7 +136840,7 @@ }, { "name": "center", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -146489,7 +146489,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -149705,7 +149705,7 @@ }, { "name": "center", - "type": "[number]", + "type": "Point3d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_3_of_TyF64", @@ -159354,7 +159354,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -162565,7 +162565,7 @@ }, { "name": "axis", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -169005,7 +169005,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -172216,7 +172216,7 @@ }, { "name": "axis", - "type": "[number]", + "type": "Point3d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_3_of_TyF64", @@ -178658,7 +178658,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -186704,7 +186704,7 @@ }, { "name": "instances", - "type": "integer", + "type": "number", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "uint32", @@ -197961,7 +197961,7 @@ }, { "name": "center", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -255081,7 +255081,7 @@ ], "returnValue": { "name": "", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -255283,7 +255283,7 @@ ], "returnValue": { "name": "", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -257147,7 +257147,7 @@ }, { "name": "at", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Array_size_2_of_TyF64", @@ -291976,7 +291976,7 @@ }, { "name": "endAbsolute", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", @@ -293585,7 +293585,7 @@ }, { "name": "end", - "type": "[number]", + "type": "Point2d", "schema": { "$schema": "https://spec.openapis.org/oas/3.0/schema/2019-04-02#/definitions/Schema", "title": "Nullable_Array_size_2_of_TyF64", diff --git a/docs/kcl/subtract.md b/docs/kcl/subtract.md index aa1125b3a..e2da38579 100644 --- a/docs/kcl/subtract.md +++ b/docs/kcl/subtract.md @@ -10,10 +10,10 @@ Performs a boolean subtraction operation, removing the volume of one or more too ```kcl subtract( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - tools: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - tolerance?: [number](/docs/kcl/types/number), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + tools: [[Solid]](/docs/kcl/types/std-types-Solid), + tolerance?: [number](/docs/kcl/types/std-types-number), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -21,13 +21,13 @@ subtract( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to use as the base to subtract from. | Yes | -| `tools` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to subtract. | Yes | -| `tolerance` | [`number`](/docs/kcl/types/number) | The tolerance to use for the subtraction operation. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solids to use as the base to subtract from. | Yes | +| `tools` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solids to subtract. | Yes | +| `tolerance` | [`number`](/docs/kcl/types/std-types-number) | The tolerance to use for the subtraction operation. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/subtract2d.md b/docs/kcl/subtract2d.md index 50d014889..57e78dd72 100644 --- a/docs/kcl/subtract2d.md +++ b/docs/kcl/subtract2d.md @@ -10,9 +10,9 @@ Use a 2-dimensional sketch to cut a hole in another 2-dimensional sketch. ```kcl subtract2d( - sketch: [Sketch](/docs/kcl/types/Sketch), - tool: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + tool: [[Sketch]](/docs/kcl/types/std-types-Sketch), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -20,12 +20,12 @@ subtract2d( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `tool` | [`[Sketch]`](/docs/kcl/types/Sketch) | The shape(s) which should be cut out of the sketch. | Yes | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `tool` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | The shape(s) which should be cut out of the sketch. | Yes | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/sweep.md b/docs/kcl/sweep.md index 701e986c9..807a0d974 100644 --- a/docs/kcl/sweep.md +++ b/docs/kcl/sweep.md @@ -12,13 +12,13 @@ You can provide more than one sketch to sweep, and they will all be swept along ```kcl sweep( - sketches: [[[Sketch](/docs/kcl/types/Sketch)]](/docs/kcl/types/[Sketch](/docs/kcl/types/Sketch)), - path: Sweep[Path](/docs/kcl/types/Path), - sectional?: [bool](/docs/kcl/types/bool), - tolerance?: [number](/docs/kcl/types/number), - tagStart?: [TagDeclarator](/docs/kcl/types#tag-declaration), - tagEnd?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + sketches: [[Sketch]](/docs/kcl/types/std-types-Sketch), + path: [Sketch](/docs/kcl/types/std-types-Sketch) | [Helix](/docs/kcl/types/std-types-Helix), + sectional?: [bool](/docs/kcl/types/std-types-bool), + tolerance?: [number](/docs/kcl/types/std-types-number), + tagStart?: [TagDeclarator](/docs/kcl/types#TagDeclarator), + tagEnd?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -26,16 +26,16 @@ sweep( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketches` | [`[Sketch]`](/docs/kcl/types/Sketch) | The sketch or set of sketches that should be swept in space | Yes | -| `path` | [`SweepPath`](/docs/kcl/types/SweepPath) | The path to sweep the sketch along | Yes | -| `sectional` | [`bool`](/docs/kcl/types/bool) | If true, the sweep will be broken up into sub-sweeps (extrusions, revolves, sweeps) based on the trajectory path components. | No | -| `tolerance` | [`number`](/docs/kcl/types/number) | Tolerance for this operation | No | -| `tagStart` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the start of the sweep, i.e. the original sketch | No | -| `tagEnd` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | A named tag for the face at the end of the sweep | No | +| `sketches` | [`[Sketch]`](/docs/kcl/types/std-types-Sketch) | The sketch or set of sketches that should be swept in space | Yes | +| `path` | [`Sketch`](/docs/kcl/types/std-types-Sketch) or [`Helix`](/docs/kcl/types/std-types-Helix) | The path to sweep the sketch along | Yes | +| `sectional` | [`bool`](/docs/kcl/types/std-types-bool) | If true, the sweep will be broken up into sub-sweeps (extrusions, revolves, sweeps) based on the trajectory path components. | No | +| `tolerance` | [`number`](/docs/kcl/types/std-types-number) | Tolerance for this operation | No | +| `tagStart` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the start of the sweep, i.e. the original sketch | No | +| `tagEnd` | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | A named tag for the face at the end of the sweep | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/tangentToEnd.md b/docs/kcl/tangentToEnd.md index f480ea1e4..c45bd7eb1 100644 --- a/docs/kcl/tangentToEnd.md +++ b/docs/kcl/tangentToEnd.md @@ -9,7 +9,7 @@ Returns the angle coming out of the end of the segment in degrees. ```kcl -tangentToEnd(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/docs/kcl/types/number) +tangentToEnd(tag: [TagIdentifier](/docs/kcl/types#TagIdentifier)): [number](/docs/kcl/types/std-types-number) ``` @@ -17,11 +17,11 @@ tangentToEnd(tag: [TagIdentifier](/docs/kcl/types#tag-identifier)): [number](/do | Name | Type | Description | Required | |----------|------|-------------|----------| -| `tag` | [`TagIdentifier`](/docs/kcl/types#tag-identifier) | The line segment being queried by its tag | Yes | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagIdentifier`](/docs/kcl/types#TagIdentifier) | The line segment being queried by its tag | Yes | ### Returns -[`number`](/docs/kcl/types/number) +[`number`](/docs/kcl/types/std-types-number) ### Examples diff --git a/docs/kcl/tangentialArc.md b/docs/kcl/tangentialArc.md index 7e36393ed..cbb12f1dc 100644 --- a/docs/kcl/tangentialArc.md +++ b/docs/kcl/tangentialArc.md @@ -10,13 +10,13 @@ When using radius and angle, draw a curved line segment along part of an imagina ```kcl tangentialArc( - sketch: [Sketch](/docs/kcl/types/Sketch), - endAbsolute?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - end?: [[[number](/docs/kcl/types/number)]](/docs/kcl/types/[number](/docs/kcl/types/number)), - radius?: [number](/docs/kcl/types/number), - angle?: [number](/docs/kcl/types/number), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + endAbsolute?: [Point2d](/docs/kcl/types/std-types-Point2d), + end?: [Point2d](/docs/kcl/types/std-types-Point2d), + radius?: [number](/docs/kcl/types/std-types-number), + angle?: [number](/docs/kcl/types/std-types-number), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -24,16 +24,16 @@ tangentialArc( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `endAbsolute` | [`[number]`](/docs/kcl/types/number) | Which absolute point should this arc go to? Incompatible with `end`, `radius`, and `offset`. | No | -| `end` | [`[number]`](/docs/kcl/types/number) | How far away (along the X and Y axes) should this arc go? Incompatible with `endAbsolute`, `radius`, and `offset`. | No | -| `radius` | [`number`](/docs/kcl/types/number) | Radius of the imaginary circle. `angle` must be given. Incompatible with `end` and `endAbsolute`. | No | -| `angle` | [`number`](/docs/kcl/types/number) | Offset of the arc in degrees. `radius` must be given. Incompatible with `end` and `endAbsolute`. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this arc | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `endAbsolute` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | Which absolute point should this arc go to? Incompatible with `end`, `radius`, and `offset`. | No | +| `end` | [`Point2d`](/docs/kcl/types/std-types-Point2d) | How far away (along the X and Y axes) should this arc go? Incompatible with `endAbsolute`, `radius`, and `offset`. | No | +| `radius` | [`number`](/docs/kcl/types/std-types-number) | Radius of the imaginary circle. `angle` must be given. Incompatible with `end` and `endAbsolute`. | No | +| `angle` | [`number`](/docs/kcl/types/std-types-number) | Offset of the arc in degrees. `radius` must be given. Incompatible with `end` and `endAbsolute`. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this arc | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/tau.md b/docs/kcl/tau.md deleted file mode 100644 index 60a25f16d..000000000 --- a/docs/kcl/tau.md +++ /dev/null @@ -1,42 +0,0 @@ ---- -title: "tau" -excerpt: "Return the value of `tau`. The full circle constant (τ). Equal to 2π." -layout: manual ---- - -**WARNING:** This function is deprecated. - -Return the value of `tau`. The full circle constant (τ). Equal to 2π. - -**DEPRECATED** use the constant TAU - -```js -tau(): number -``` - -### Tags - -* `math` - - - -### Returns - -[`number`](/docs/kcl/types/number) - - -### Examples - -```js -exampleSketch = startSketchOn(XZ) - |> startProfile(at = [0, 0]) - |> angledLine(angle = 50, length = 10 * tau()) - |> yLine(endAbsolute = 0) - |> close() - -example = extrude(exampleSketch, length = 5) -``` - -![Rendered example of tau 0]() - - diff --git a/docs/kcl/translate.md b/docs/kcl/translate.md index cb8b5bcdf..454b0801b 100644 --- a/docs/kcl/translate.md +++ b/docs/kcl/translate.md @@ -12,12 +12,12 @@ Translate is really useful for sketches if you want to move a sketch and then ro ```kcl translate( - objects: [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry), - x?: [number](/docs/kcl/types/number), - y?: [number](/docs/kcl/types/number), - z?: [number](/docs/kcl/types/number), - global?: [bool](/docs/kcl/types/bool), -): [[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)Or[Sketch](/docs/kcl/types/Sketch)OrImportedGeometry) + objects: [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry), + x?: [number](/docs/kcl/types/std-types-number), + y?: [number](/docs/kcl/types/std-types-number), + z?: [number](/docs/kcl/types/std-types-number), + global?: [bool](/docs/kcl/types/std-types-bool), +): [[Solid]](/docs/kcl/types/std-types-Solid) | [[Sketch]](/docs/kcl/types/std-types-Sketch) | [ImportedGeometry](/docs/kcl/types#ImportedGeometry) ``` @@ -25,15 +25,15 @@ translate( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `objects` | [`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) | The solid, sketch, or set of solids or sketches to move. | Yes | -| `x` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the x axis. Defaults to 0 if not provided. | No | -| `y` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the y axis. Defaults to 0 if not provided. | No | -| `z` | [`number`](/docs/kcl/types/number) | The amount to move the solid or sketch along the z axis. Defaults to 0 if not provided. | No | -| `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 | +| `objects` | [`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) | The solid, sketch, or set of solids or sketches to move. | Yes | +| `x` | [`number`](/docs/kcl/types/std-types-number) | The amount to move the solid or sketch along the x axis. Defaults to 0 if not provided. | No | +| `y` | [`number`](/docs/kcl/types/std-types-number) | The amount to move the solid or sketch along the y axis. Defaults to 0 if not provided. | No | +| `z` | [`number`](/docs/kcl/types/std-types-number) | The amount to move the solid or sketch along the z axis. Defaults to 0 if not provided. | No | +| `global` | [`bool`](/docs/kcl/types/std-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 -[`SolidOrSketchOrImportedGeometry`](/docs/kcl/types/SolidOrSketchOrImportedGeometry) - Data for a solid, sketch, or an imported geometry. +[`[Solid]`](/docs/kcl/types/std-types-Solid) or [`[Sketch]`](/docs/kcl/types/std-types-Sketch) or [`ImportedGeometry`](/docs/kcl/types#ImportedGeometry) - Data for a solid, sketch, or an imported geometry. ### Examples diff --git a/docs/kcl/types.md b/docs/kcl/types.md index cf454d512..c1c4ef22f 100644 --- a/docs/kcl/types.md +++ b/docs/kcl/types.md @@ -9,10 +9,6 @@ layout: manual All these types can be nested in various forms where nesting applies. Like arrays can hold objects and vice versa. -## Boolean - -`true` or `false` work when defining values. - ## Constant declaration Constants are defined with a name and a value, like so: @@ -23,7 +19,7 @@ myBool = false Currently you cannot redeclare a constant. -## Array +## Arrays An array is defined with `[]` braces. What is inside the brackets can be of any type. For example, the following is completely valid: @@ -36,7 +32,7 @@ If you want to get a value from an array you can use the index like so: `myArray[0]`. -## Object +## Objects An object is defined with `{}` braces. Here is an example object: @@ -47,6 +43,15 @@ myObj = { a = 0, b = "thing" } We support two different ways of getting properties from objects, you can call `myObj.a` or `myObj["a"]` both work. +## `ImportedGeometry` + +Using `import` you can import geometry defined using other CAD software. In KCL, +these objects have type `ImportedGeometry` and can mostly be treated like any +other solid (they can be rotated, scaled, etc.), although there is no access to +their internal components. See the [modules and imports docs](modules) for more +detail on importing geometry. + + ## Binary expressions You can also do math! Let's show an example below: @@ -176,7 +181,7 @@ Check the docs page for each function and look at its examples to see. Tags are used to give a name (tag) to a specific path. -### Tag Declaration +### `TagDeclarator` The syntax for declaring a tag is `$myTag` you would use it in the following way: @@ -199,7 +204,7 @@ startSketchOn(XZ) |> close() ``` -### Tag Identifier +### `TagIdentifier` As per the example above you can use the tag identifier to get a reference to the tagged object. The syntax for this is `myTag`. @@ -207,6 +212,16 @@ tagged object. The syntax for this is `myTag`. In the example above we use the tag identifier to get the angle of the segment `segAng(rectangleSegmentA001, %)`. +### `Start` + +There is a special tag, `START` (with type `Start`, although under the cover, it's a string) +for identifying the face of a solid which was the start of an extrusion (i.e., the surface which +is extruded). + +### `End` + +There is a special tag, `END` (with type `End`, although under the cover, it's a string) +for identifying the face of a solid which was finishes an extrusion. ### Tag Scope diff --git a/docs/kcl/types/ArtifactId.md b/docs/kcl/types/ArtifactId.md deleted file mode 100644 index 6447248f1..000000000 --- a/docs/kcl/types/ArtifactId.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -title: "ArtifactId" -excerpt: "" -layout: manual ---- - - -**Type:** [`string`](/docs/kcl/types/string) (`uuid`) - - - - - - - diff --git a/docs/kcl/types/BasePath.md b/docs/kcl/types/BasePath.md deleted file mode 100644 index 9d616b105..000000000 --- a/docs/kcl/types/BasePath.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -title: "BasePath" -excerpt: "A base path." -layout: manual ---- - -A base path. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - diff --git a/docs/kcl/types/EdgeCut.md b/docs/kcl/types/EdgeCut.md deleted file mode 100644 index 8046401eb..000000000 --- a/docs/kcl/types/EdgeCut.md +++ /dev/null @@ -1,58 +0,0 @@ ---- -title: "EdgeCut" -excerpt: "A fillet or a chamfer." -layout: manual ---- - -A fillet or a chamfer. - - - - - -**This schema accepts exactly one of the following:** - -A fillet. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `fillet`| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the engine command that called this fillet. | No | -| `radius` |`TyF64`| | No | -| `edgeId` |[`string`](/docs/kcl/types/string)| The engine id of the edge to fillet. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| | No | - - ----- -A chamfer. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `chamfer`| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the engine command that called this chamfer. | No | -| `length` |`TyF64`| | No | -| `edgeId` |[`string`](/docs/kcl/types/string)| The engine id of the edge to chamfer. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| | No | - - ----- - - - - diff --git a/docs/kcl/types/ExtrudeSurface.md b/docs/kcl/types/ExtrudeSurface.md deleted file mode 100644 index 991ec8e8a..000000000 --- a/docs/kcl/types/ExtrudeSurface.md +++ /dev/null @@ -1,98 +0,0 @@ ---- -title: "ExtrudeSurface" -excerpt: "An extrude surface." -layout: manual ---- - -An extrude surface. - - - - - -**This schema accepts exactly one of the following:** - -An extrude plane. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `extrudePlane`| | No | -| `faceId` |[`string`](/docs/kcl/types/string)| The face id for the extrude plane. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag. | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the geometry. | No | -| `sourceRange` |`[, `integer`, `integer`, `integer`]`| The source range. | No | - - ----- -An extruded arc. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `extrudeArc`| | No | -| `faceId` |[`string`](/docs/kcl/types/string)| The face id for the extrude plane. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag. | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the geometry. | No | -| `sourceRange` |`[, `integer`, `integer`, `integer`]`| The source range. | No | - - ----- -Geometry metadata. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `chamfer`| | No | -| `faceId` |[`string`](/docs/kcl/types/string)| The id for the chamfer surface. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag. | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the geometry. | No | -| `sourceRange` |`[, `integer`, `integer`, `integer`]`| The source range. | No | - - ----- -Geometry metadata. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `fillet`| | No | -| `faceId` |[`string`](/docs/kcl/types/string)| The id for the fillet surface. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag. | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the geometry. | No | -| `sourceRange` |`[, `integer`, `integer`, `integer`]`| The source range. | No | - - ----- - - - - diff --git a/docs/kcl/types/FaceTag.md b/docs/kcl/types/FaceTag.md deleted file mode 100644 index e9dad7cdd..000000000 --- a/docs/kcl/types/FaceTag.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -title: "FaceTag" -excerpt: "A tag for a face." -layout: manual ---- - -A tag for a face. - - - - -**This schema accepts any of the following:** - - -[`StartOrEnd`](/docs/kcl/types/StartOrEnd) - - - - - - - - ----- -A tag for the face. - -[`TagIdentifier`](/docs/kcl/types#tag-identifier) - - - - - - - - ----- - - - - - diff --git a/docs/kcl/types/GeoMeta.md b/docs/kcl/types/GeoMeta.md deleted file mode 100644 index 35b8f4c9e..000000000 --- a/docs/kcl/types/GeoMeta.md +++ /dev/null @@ -1,22 +0,0 @@ ---- -title: "GeoMeta" -excerpt: "Geometry metadata." -layout: manual ---- - -Geometry metadata. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `id` |[`string`](/docs/kcl/types/string)| The id of the geometry. | No | -| `sourceRange` |`[, `integer`, `integer`, `integer`]`| The source range. | No | - - diff --git a/docs/kcl/types/GeometryWithImportedGeometry.md b/docs/kcl/types/GeometryWithImportedGeometry.md deleted file mode 100644 index 3e73a32c8..000000000 --- a/docs/kcl/types/GeometryWithImportedGeometry.md +++ /dev/null @@ -1,84 +0,0 @@ ---- -title: "GeometryWithImportedGeometry" -excerpt: "A geometry including an imported geometry." -layout: manual ---- - -A geometry including an imported geometry. - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Sketch`](/docs/kcl/types/Sketch)| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the sketch (this will change when the engine's reference to it changes). | No | -| `paths` |`[` [`Path`](/docs/kcl/types/Path) `]`| The paths in the sketch. | No | -| `on` |[`SketchSurface`](/docs/kcl/types/SketchSurface)| What the sketch is on (can be a plane or a face). | No | -| `start` |[`BasePath`](/docs/kcl/types/BasePath)| The starting path. | No | -| `tags` |`object`| Tag identifiers that have been declared in this sketch. | No | -| `artifactId` |[`string`](/docs/kcl/types/string)| The original id of the sketch. This stays the same even if the sketch is is sketched on face etc. | No | -| `originalId` |[`string`](/docs/kcl/types/string)| | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Solid`](/docs/kcl/types/Solid)| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the solid. | No | -| `artifactId` |[`string`](/docs/kcl/types/string)| The artifact ID of the solid. Unlike `id`, this doesn't change. | No | -| `value` |`[` [`ExtrudeSurface`](/docs/kcl/types/ExtrudeSurface) `]`| The extrude surfaces. | No | -| `sketch` |[`Sketch`](/docs/kcl/types/Sketch)| The sketch. | No | -| `height` |[`number`](/docs/kcl/types/number)| The height of the solid. | No | -| `startCapId` |[`string`](/docs/kcl/types/string)| The id of the extrusion start cap | No | -| `endCapId` |[`string`](/docs/kcl/types/string)| The id of the extrusion end cap | No | -| `edgeCuts` |`[` [`EdgeCut`](/docs/kcl/types/EdgeCut) `]`| Chamfers or fillets on this solid. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| The units of the solid. | No | -| `sectional` |`boolean`| Is this a sectional solid? | No | - - ----- -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 | - - ----- - - - - diff --git a/docs/kcl/types/KclNone.md b/docs/kcl/types/KclNone.md deleted file mode 100644 index 1e7c7f8a4..000000000 --- a/docs/kcl/types/KclNone.md +++ /dev/null @@ -1,21 +0,0 @@ ---- -title: "KclNone" -excerpt: "KCL value for an optional parameter which was not given an argument. (remember, parameters are in the function declaration, arguments are in the function call/application)." -layout: manual ---- - -KCL value for an optional parameter which was not given an argument. (remember, parameters are in the function declaration, arguments are in the function call/application). - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | - - diff --git a/docs/kcl/types/KclValue.md b/docs/kcl/types/KclValue.md deleted file mode 100644 index d999068a5..000000000 --- a/docs/kcl/types/KclValue.md +++ /dev/null @@ -1,326 +0,0 @@ ---- -title: "KclValue" -excerpt: "Any KCL value." -layout: manual ---- - -Any KCL value. - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Uuid`| | No | -| `value` |[`string`](/docs/kcl/types/string)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Bool`| | No | -| `value` |`boolean`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Number`| | No | -| `value` |[`number`](/docs/kcl/types/number)| | No | -| `ty` |[`NumericType`](/docs/kcl/types/NumericType)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `String`| | No | -| `value` |[`string`](/docs/kcl/types/string)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `MixedArray`| | No | -| `value` |`[` [`KclValue`](/docs/kcl/types/KclValue) `]`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `HomArray`| | No | -| `value` |`[` [`KclValue`](/docs/kcl/types/KclValue) `]`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Object`| | No | -| `value` |`object`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`TagIdentifier`](/docs/kcl/types#tag-identifier)| | No | -| `value` |[`string`](/docs/kcl/types/string)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`TagDeclarator`](/docs/kcl/types#tag-declaration)| | No | -| `value` |[`string`](/docs/kcl/types/string)| | No | -| `digest` |`[, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`, `integer`]`| | No | -| `start` |`integer`| | No | -| `end` |`integer`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Plane`](/docs/kcl/types/Plane)| | No | -| `value` |[`Plane`](/docs/kcl/types/Plane)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Face`](/docs/kcl/types/Face)| | No | -| `value` |[`Face`](/docs/kcl/types/Face)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Sketch`](/docs/kcl/types/Sketch)| | No | -| `value` |[`Sketch`](/docs/kcl/types/Sketch)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Solid`](/docs/kcl/types/Solid)| | No | -| `value` |[`Solid`](/docs/kcl/types/Solid)| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`Helix`](/docs/kcl/types/Helix)| | No | -| `value` |[`Helix`](/docs/kcl/types/Helix)| | No | - - ----- -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` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Function`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Module`| | No | -| `value` |`integer`| Identifier of a source file. Uses a u32 to keep the size small. | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Type`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: [`KclNone`](/docs/kcl/types/KclNone)| | No | -| `value` |[`KclNone`](/docs/kcl/types/KclNone)| KCL value for an optional parameter which was not given an argument. (remember, parameters are in the function declaration, arguments are in the function call/application). | No | - - ----- - - - - diff --git a/docs/kcl/types/ModuleId.md b/docs/kcl/types/ModuleId.md deleted file mode 100644 index 9ed25fcfe..000000000 --- a/docs/kcl/types/ModuleId.md +++ /dev/null @@ -1,16 +0,0 @@ ---- -title: "ModuleId" -excerpt: "Identifier of a source file. Uses a u32 to keep the size small." -layout: manual ---- - -Identifier of a source file. Uses a u32 to keep the size small. - -**Type:** `integer` (`uint32`) - - - - - - - diff --git a/docs/kcl/types/NumericType.md b/docs/kcl/types/NumericType.md deleted file mode 100644 index ad7be7a57..000000000 --- a/docs/kcl/types/NumericType.md +++ /dev/null @@ -1,282 +0,0 @@ ---- -title: "NumericType" -excerpt: "" -layout: manual ---- - - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Count`| | No | - - ----- -A unit of length. - -**Type:** `object` - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Mm`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Cm`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `M`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Inches`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Feet`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Yards`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Unknown`| | No | - - ----- - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Length`| | No | - - ----- -A unit of angle. - -**Type:** `object` - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Degrees`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Radians`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Unknown`| | No | - - ----- - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Angle`| | No | - - ----- - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Known`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Default`| | No | -| `len` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `angle` |[`UnitAngle`](/docs/kcl/types/UnitAngle)| A unit of angle. | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Unknown`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Any`| | No | - - ----- - - - - diff --git a/docs/kcl/types/Path.md b/docs/kcl/types/Path.md deleted file mode 100644 index 859c07fad..000000000 --- a/docs/kcl/types/Path.md +++ /dev/null @@ -1,247 +0,0 @@ ---- -title: "Path" -excerpt: "A path." -layout: manual ---- - -A path. - - - - - -**This schema accepts exactly one of the following:** - -A path that goes to a point. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `ToPoint`| | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A arc that is tangential to the last path segment that goes to a point - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `TangentialArcTo`| | No | -| `center` |`[number, number]`| the arc's center | No | -| `ccw` |`boolean`| arc's direction | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A arc that is tangential to the last path segment - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `TangentialArc`| | No | -| `center` |`[number, number]`| the arc's center | No | -| `ccw` |`boolean`| arc's direction | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -a complete arc - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Circle`| | No | -| `center` |`[number, number]`| the arc's center | No | -| `radius` |[`number`](/docs/kcl/types/number)| the arc's radius | No | -| `ccw` |`boolean`| arc's direction This is used to compute the tangential angle. | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A base path. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `CircleThreePoint`| | No | -| `p1` |`[number, number]`| Point 1 of the circle | No | -| `p2` |`[number, number]`| Point 2 of the circle | No | -| `p3` |`[number, number]`| Point 3 of the circle | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A base path. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `ArcThreePoint`| | No | -| `p1` |`[number, number]`| Point 1 of the arc (base on the end of previous segment) | No | -| `p2` |`[number, number]`| Point 2 of the arc (interiorAbsolute kwarg) | No | -| `p3` |`[number, number]`| Point 3 of the arc (endAbsolute kwarg) | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A path that is horizontal. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Horizontal`| | No | -| `x` |[`number`](/docs/kcl/types/number)| The x coordinate. | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -An angled line to. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `AngledLineTo`| | No | -| `x` |[`number`](/docs/kcl/types/number)| The x coordinate. | No | -| `y` |[`number`](/docs/kcl/types/number)| The y coordinate. | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A base path. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Base`| | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- -A circular arc, not necessarily tangential to the current point. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Arc`| | No | -| `center` |`[number, number]`| Center of the circle that this arc is drawn on. | No | -| `radius` |[`number`](/docs/kcl/types/number)| Radius of the circle that this arc is drawn on. | No | -| `ccw` |`boolean`| True if the arc is counterclockwise. | No | -| `from` |`[number, number]`| The from point. | No | -| `to` |`[number, number]`| The to point. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | -| `tag` |[`TagDeclarator`](/docs/kcl/types#tag-declaration)| The tag of the path. | No | -| `__geoMeta` |[`GeoMeta`](/docs/kcl/types/GeoMeta)| Metadata. | No | - - ----- - - - - diff --git a/docs/kcl/types/PlaneData.md b/docs/kcl/types/PlaneData.md deleted file mode 100644 index 205ee2865..000000000 --- a/docs/kcl/types/PlaneData.md +++ /dev/null @@ -1,106 +0,0 @@ ---- -title: "PlaneData" -excerpt: "Orientation data that can be used to construct a plane, not a plane in itself." -layout: manual ---- - -Orientation data that can be used to construct a plane, not a plane in itself. - - - - - -**This schema accepts exactly one of the following:** - -The XY plane. - -**enum:** `XY` - - - - - - - - ----- -The opposite side of the XY plane. - -**enum:** `-XY` - - - - - - - - ----- -The XZ plane. - -**enum:** `XZ` - - - - - - - - ----- -The opposite side of the XZ plane. - -**enum:** `-XZ` - - - - - - - - ----- -The YZ plane. - -**enum:** `YZ` - - - - - - - - ----- -The opposite side of the YZ plane. - -**enum:** `-YZ` - - - - - - - - ----- -A defined plane. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `plane` |[`PlaneInfo`](/docs/kcl/types/PlaneInfo)| | No | - - ----- - - - - diff --git a/docs/kcl/types/PlaneInfo.md b/docs/kcl/types/PlaneInfo.md deleted file mode 100644 index b71c72ecd..000000000 --- a/docs/kcl/types/PlaneInfo.md +++ /dev/null @@ -1,22 +0,0 @@ ---- -title: "PlaneInfo" -excerpt: "" -layout: manual ---- - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `origin` |[`Point3d`](/docs/kcl/types/Point3d)| Origin of the plane. | No | -| `xAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane's X axis be? | No | -| `yAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane's Y axis be? | No | - - diff --git a/docs/kcl/types/PlaneType.md b/docs/kcl/types/PlaneType.md deleted file mode 100644 index e2ccc50de..000000000 --- a/docs/kcl/types/PlaneType.md +++ /dev/null @@ -1,53 +0,0 @@ ---- -title: "PlaneType" -excerpt: "Type for a plane." -layout: manual ---- - -Type for a plane. - - - - - -**This schema accepts exactly one of the following:** - - -**enum:** `XY`, `XZ`, `YZ` - - - - - - - - ----- -A custom plane. - -**enum:** `Custom` - - - - - - - - ----- -A custom plane which has not been sent to the engine. It must be sent before it is used. - -**enum:** `Uninit` - - - - - - - - ----- - - - - diff --git a/docs/kcl/types/Point2d.md b/docs/kcl/types/Point2d.md deleted file mode 100644 index 74ca70469..000000000 --- a/docs/kcl/types/Point2d.md +++ /dev/null @@ -1,17 +0,0 @@ ---- -title: "std::types::Point2d" -excerpt: "A point in two dimensional space." -layout: manual ---- - -A point in two dimensional space. - -```kcl -type [Point2d](/docs/kcl/types/Point2d) = [[number](/docs/kcl/types/number)(Length); 2] -``` - -[`Point2d`](/docs/kcl/types/Point2d) is an alias for a two-element array of [number](/docs/kcl/types/number)s. To write a value -with type [`Point2d`](/docs/kcl/types/Point2d), use an array, e.g., `[0, 0]` or `[5.0, 3.14]`. - - - diff --git a/docs/kcl/types/Point3d.md b/docs/kcl/types/Point3d.md deleted file mode 100644 index af4efdcfd..000000000 --- a/docs/kcl/types/Point3d.md +++ /dev/null @@ -1,17 +0,0 @@ ---- -title: "std::types::Point3d" -excerpt: "A point in three dimensional space." -layout: manual ---- - -A point in three dimensional space. - -```kcl -type [Point3d](/docs/kcl/types/Point3d) = [[number](/docs/kcl/types/number)(Length); 3] -``` - -[`Point3d`](/docs/kcl/types/Point3d) is an alias for a three-element array of [number](/docs/kcl/types/number)s. To write a value -with type [`Point3d`](/docs/kcl/types/Point3d), use an array, e.g., `[0, 0, 0]` or `[5.0, 3.14, 6.8]`. - - - diff --git a/docs/kcl/types/SketchData.md b/docs/kcl/types/SketchData.md deleted file mode 100644 index a727c58a9..000000000 --- a/docs/kcl/types/SketchData.md +++ /dev/null @@ -1,52 +0,0 @@ ---- -title: "SketchData" -excerpt: "Data for start sketch on. You can start a sketch on a plane or an solid." -layout: manual ---- - -Data for start sketch on. You can start a sketch on a plane or an solid. - - - - -**This schema accepts any of the following:** - -Orientation data that can be used to construct a plane, not a plane in itself. - -[`PlaneData`](/docs/kcl/types/PlaneData) - - - - - - - - ----- - -[`Plane`](/docs/kcl/types/Plane) - - - - - - - - ----- - -[`Solid`](/docs/kcl/types/Solid) - - - - - - - - ----- - - - - - diff --git a/docs/kcl/types/SketchOrSurface.md b/docs/kcl/types/SketchOrSurface.md deleted file mode 100644 index 1fc748b53..000000000 --- a/docs/kcl/types/SketchOrSurface.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -title: "SketchOrSurface" -excerpt: "A sketch surface or a sketch." -layout: manual ---- - -A sketch surface or a sketch. - - - - -**This schema accepts any of the following:** - -A sketch type. - -[`SketchSurface`](/docs/kcl/types/SketchSurface) - - - - - - - - ----- - -[`Sketch`](/docs/kcl/types/Sketch) - - - - - - - - ----- - - - - - diff --git a/docs/kcl/types/SketchSurface.md b/docs/kcl/types/SketchSurface.md deleted file mode 100644 index 534081971..000000000 --- a/docs/kcl/types/SketchSurface.md +++ /dev/null @@ -1,62 +0,0 @@ ---- -title: "SketchSurface" -excerpt: "A sketch type." -layout: manual ---- - -A sketch type. - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `plane`| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the plane. | No | -| `artifactId` |[`string`](/docs/kcl/types/string)| The artifact ID. | No | -| `value` |[`PlaneType`](/docs/kcl/types/PlaneType)| Type for a plane. | No | -| `origin` |[`Point3d`](/docs/kcl/types/Point3d)| Origin of the plane. | No | -| `xAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane's X axis be? | No | -| `yAxis` |[`Point3d`](/docs/kcl/types/Point3d)| What should the plane's Y axis be? | No | - - ----- -A face. - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `face`| | No | -| `id` |[`string`](/docs/kcl/types/string)| The id of the face. | No | -| `artifactId` |[`string`](/docs/kcl/types/string)| 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 | -| `solid` |[`Solid`](/docs/kcl/types/Solid)| The solid the face is on. | No | -| `units` |[`UnitLen`](/docs/kcl/types/UnitLen)| A unit of length. | No | - - ----- - - - - diff --git a/docs/kcl/types/SolidOrImportedGeometry.md b/docs/kcl/types/SolidOrImportedGeometry.md deleted file mode 100644 index 5944c7ba5..000000000 --- a/docs/kcl/types/SolidOrImportedGeometry.md +++ /dev/null @@ -1,51 +0,0 @@ ---- -title: "SolidOrImportedGeometry" -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 | - - ----- - - - - diff --git a/docs/kcl/types/SolidOrSketchOrImportedGeometry.md b/docs/kcl/types/SolidOrSketchOrImportedGeometry.md deleted file mode 100644 index 4da6545b1..000000000 --- a/docs/kcl/types/SolidOrSketchOrImportedGeometry.md +++ /dev/null @@ -1,66 +0,0 @@ ---- -title: "SolidOrSketchOrImportedGeometry" -excerpt: "Data for a solid, sketch, or an imported geometry." -layout: manual ---- - -Data for a solid, sketch, 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 | - - ----- - - - - diff --git a/docs/kcl/types/StartOrEnd.md b/docs/kcl/types/StartOrEnd.md deleted file mode 100644 index 6e8ed9329..000000000 --- a/docs/kcl/types/StartOrEnd.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -title: "StartOrEnd" -excerpt: "" -layout: manual ---- - - - - - - -**This schema accepts exactly one of the following:** - -The start face as in before you extruded. This could also be known as the bottom face. But we do not call it bottom because it would be the top face if you extruded it in the opposite direction or flipped the camera. - -**enum:** `start` - - - - - - - - ----- -The end face after you extruded. This could also be known as the top face. But we do not call it top because it would be the bottom face if you extruded it in the opposite direction or flipped the camera. - -**enum:** `end` - - - - - - - - ----- - - - - diff --git a/docs/kcl/types/SweepPath.md b/docs/kcl/types/SweepPath.md deleted file mode 100644 index b8e7e0865..000000000 --- a/docs/kcl/types/SweepPath.md +++ /dev/null @@ -1,40 +0,0 @@ ---- -title: "SweepPath" -excerpt: "A path to sweep along." -layout: manual ---- - -A path to sweep along. - - - - -**This schema accepts any of the following:** - - -[`Sketch`](/docs/kcl/types/Sketch) - - - - - - - - ----- - -[`Helix`](/docs/kcl/types/Helix) - - - - - - - - ----- - - - - - diff --git a/docs/kcl/types/UnitAngle.md b/docs/kcl/types/UnitAngle.md deleted file mode 100644 index 09a6aa892..000000000 --- a/docs/kcl/types/UnitAngle.md +++ /dev/null @@ -1,63 +0,0 @@ ---- -title: "UnitAngle" -excerpt: "A unit of angle." -layout: manual ---- - -A unit of angle. - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Degrees`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Radians`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Unknown`| | No | - - ----- - - - - diff --git a/docs/kcl/types/UnitLen.md b/docs/kcl/types/UnitLen.md deleted file mode 100644 index 5e00e5c39..000000000 --- a/docs/kcl/types/UnitLen.md +++ /dev/null @@ -1,123 +0,0 @@ ---- -title: "UnitLen" -excerpt: "A unit of length." -layout: manual ---- - -A unit of length. - - - - - -**This schema accepts exactly one of the following:** - - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Mm`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Cm`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `M`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Inches`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Feet`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Yards`| | No | - - ----- - -**Type:** `object` - - - - - -## Properties - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -| `type` |enum: `Unknown`| | No | - - ----- - - - - diff --git a/docs/kcl/types/Axis2d.md b/docs/kcl/types/std-types-Axis2d.md similarity index 100% rename from docs/kcl/types/Axis2d.md rename to docs/kcl/types/std-types-Axis2d.md diff --git a/docs/kcl/types/Axis3d.md b/docs/kcl/types/std-types-Axis3d.md similarity index 100% rename from docs/kcl/types/Axis3d.md rename to docs/kcl/types/std-types-Axis3d.md diff --git a/docs/kcl/types/Edge.md b/docs/kcl/types/std-types-Edge.md similarity index 100% rename from docs/kcl/types/Edge.md rename to docs/kcl/types/std-types-Edge.md diff --git a/docs/kcl/types/Face.md b/docs/kcl/types/std-types-Face.md similarity index 100% rename from docs/kcl/types/Face.md rename to docs/kcl/types/std-types-Face.md diff --git a/docs/kcl/types/Helix.md b/docs/kcl/types/std-types-Helix.md similarity index 100% rename from docs/kcl/types/Helix.md rename to docs/kcl/types/std-types-Helix.md diff --git a/docs/kcl/types/Plane.md b/docs/kcl/types/std-types-Plane.md similarity index 100% rename from docs/kcl/types/Plane.md rename to docs/kcl/types/std-types-Plane.md diff --git a/docs/kcl/types/std-types-Point2d.md b/docs/kcl/types/std-types-Point2d.md new file mode 100644 index 000000000..6f79b16c9 --- /dev/null +++ b/docs/kcl/types/std-types-Point2d.md @@ -0,0 +1,17 @@ +--- +title: "std::types::Point2d" +excerpt: "A point in two dimensional space." +layout: manual +--- + +A point in two dimensional space. + +```kcl +type Point2d = [number(Length); 2] +``` + +[`Point2d`](/docs/kcl/types/std-types-Point2d) is an alias for a two-element array of [number](/docs/kcl/types/number)s. To write a value +with type [`Point2d`](/docs/kcl/types/std-types-Point2d), use an array, e.g., `[[0, 0]]` or `[[5.0, 3.14]]`. + + + diff --git a/docs/kcl/types/std-types-Point3d.md b/docs/kcl/types/std-types-Point3d.md new file mode 100644 index 000000000..98a8a92be --- /dev/null +++ b/docs/kcl/types/std-types-Point3d.md @@ -0,0 +1,17 @@ +--- +title: "std::types::Point3d" +excerpt: "A point in three dimensional space." +layout: manual +--- + +A point in three dimensional space. + +```kcl +type Point3d = [number(Length); 3] +``` + +[`Point3d`](/docs/kcl/types/std-types-Point3d) is an alias for a three-element array of [number](/docs/kcl/types/number)s. To write a value +with type [`Point3d`](/docs/kcl/types/std-types-Point3d), use an array, e.g., `[[0, 0, 0]]` or `[[5.0, 3.14, 6.8]]`. + + + diff --git a/docs/kcl/types/Sketch.md b/docs/kcl/types/std-types-Sketch.md similarity index 99% rename from docs/kcl/types/Sketch.md rename to docs/kcl/types/std-types-Sketch.md index c0cd6408d..5f3368955 100644 --- a/docs/kcl/types/Sketch.md +++ b/docs/kcl/types/std-types-Sketch.md @@ -17,7 +17,7 @@ mySketch = startSketchOn(XY) |> close() ``` -The `mySketch` variable will be an executed [`Sketch`](/docs/kcl/types/Sketch) object. Executed being past +The `mySketch` variable will be an executed [`Sketch`](/docs/kcl/types/std-types-Sketch) object. Executed being past tense, because the engine has already executed the commands to create the sketch. The previous sketch commands will never be executed again, in this case. diff --git a/docs/kcl/types/Solid.md b/docs/kcl/types/std-types-Solid.md similarity index 99% rename from docs/kcl/types/Solid.md rename to docs/kcl/types/std-types-Solid.md index 888483e11..c27885419 100644 --- a/docs/kcl/types/Solid.md +++ b/docs/kcl/types/std-types-Solid.md @@ -18,7 +18,7 @@ myPart = startSketchOn(XY) |> extrude(length = 6) ``` -The `myPart` variable will be an executed [`Solid`](/docs/kcl/types/Solid) object. Executed being past +The `myPart` variable will be an executed [`Solid`](/docs/kcl/types/std-types-Solid) object. Executed being past tense, because the engine has already executed the commands to create the solid. The previous solid commands will never be executed again, in this case. diff --git a/docs/kcl/types/std-types-any.md b/docs/kcl/types/std-types-any.md new file mode 100644 index 000000000..6aba5d838 --- /dev/null +++ b/docs/kcl/types/std-types-any.md @@ -0,0 +1,12 @@ +--- +title: "any" +excerpt: "Any value." +layout: manual +--- + +Any value. + + + + + diff --git a/docs/kcl/types/bool.md b/docs/kcl/types/std-types-bool.md similarity index 100% rename from docs/kcl/types/bool.md rename to docs/kcl/types/std-types-bool.md diff --git a/docs/kcl/types/number.md b/docs/kcl/types/std-types-number.md similarity index 100% rename from docs/kcl/types/number.md rename to docs/kcl/types/std-types-number.md diff --git a/docs/kcl/types/string.md b/docs/kcl/types/std-types-string.md similarity index 100% rename from docs/kcl/types/string.md rename to docs/kcl/types/std-types-string.md diff --git a/docs/kcl/types/tag.md b/docs/kcl/types/std-types-tag.md similarity index 100% rename from docs/kcl/types/tag.md rename to docs/kcl/types/std-types-tag.md diff --git a/docs/kcl/union.md b/docs/kcl/union.md index f184bbbf0..15857230b 100644 --- a/docs/kcl/union.md +++ b/docs/kcl/union.md @@ -10,9 +10,9 @@ Union two or more solids into a single solid. ```kcl union( - solids: [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)), - tolerance?: [number](/docs/kcl/types/number), -): [[[Solid](/docs/kcl/types/Solid)]](/docs/kcl/types/[Solid](/docs/kcl/types/Solid)) + solids: [[Solid]](/docs/kcl/types/std-types-Solid), + tolerance?: [number](/docs/kcl/types/std-types-number), +): [[Solid]](/docs/kcl/types/std-types-Solid) ``` @@ -20,12 +20,12 @@ union( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to union. | Yes | -| `tolerance` | [`number`](/docs/kcl/types/number) | The tolerance to use for the union operation. | No | +| `solids` | [`[Solid]`](/docs/kcl/types/std-types-Solid) | The solids to union. | Yes | +| `tolerance` | [`number`](/docs/kcl/types/std-types-number) | The tolerance to use for the union operation. | No | ### Returns -[`[Solid]`](/docs/kcl/types/Solid) +[`[Solid]`](/docs/kcl/types/std-types-Solid) ### Examples diff --git a/docs/kcl/xLine.md b/docs/kcl/xLine.md index fa1f8430f..65f1c474d 100644 --- a/docs/kcl/xLine.md +++ b/docs/kcl/xLine.md @@ -10,11 +10,11 @@ Draw a line relative to the current origin to a specified distance away from the ```kcl xLine( - sketch: [Sketch](/docs/kcl/types/Sketch), - length?: [number](/docs/kcl/types/number), - endAbsolute?: [number](/docs/kcl/types/number), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + length?: [number](/docs/kcl/types/std-types-number), + endAbsolute?: [number](/docs/kcl/types/std-types-number), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -22,14 +22,14 @@ xLine( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `length` | [`number`](/docs/kcl/types/number) | How far away along the X axis should this line go? Incompatible with `endAbsolute`. | No | -| `endAbsolute` | [`number`](/docs/kcl/types/number) | Which absolute X value should this line go to? Incompatible with `length`. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `length` | [`number`](/docs/kcl/types/std-types-number) | How far away along the X axis should this line go? Incompatible with `endAbsolute`. | No | +| `endAbsolute` | [`number`](/docs/kcl/types/std-types-number) | Which absolute X value should this line go to? Incompatible with `length`. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/docs/kcl/yLine.md b/docs/kcl/yLine.md index 9ef57fb0f..8a1668363 100644 --- a/docs/kcl/yLine.md +++ b/docs/kcl/yLine.md @@ -10,11 +10,11 @@ Draw a line relative to the current origin to a specified distance away from the ```kcl yLine( - sketch: [Sketch](/docs/kcl/types/Sketch), - length?: [number](/docs/kcl/types/number), - endAbsolute?: [number](/docs/kcl/types/number), - tag?: [TagDeclarator](/docs/kcl/types#tag-declaration), -): [Sketch](/docs/kcl/types/Sketch) + sketch: [Sketch](/docs/kcl/types/std-types-Sketch), + length?: [number](/docs/kcl/types/std-types-number), + endAbsolute?: [number](/docs/kcl/types/std-types-number), + tag?: [TagDeclarator](/docs/kcl/types#TagDeclarator), +): [Sketch](/docs/kcl/types/std-types-Sketch) ``` @@ -22,14 +22,14 @@ yLine( | Name | Type | Description | Required | |----------|------|-------------|----------| -| `sketch` | [`Sketch`](/docs/kcl/types/Sketch) | Which sketch should this path be added to? | Yes | -| `length` | [`number`](/docs/kcl/types/number) | How far away along the Y axis should this line go? Incompatible with `endAbsolute`. | No | -| `endAbsolute` | [`number`](/docs/kcl/types/number) | Which absolute Y value should this line go to? Incompatible with `length`. | No | -| `tag` | [`TagDeclarator`](/docs/kcl/types#tag-declaration) | Create a new tag which refers to this line | No | +| `sketch` | [`Sketch`](/docs/kcl/types/std-types-Sketch) | Which sketch should this path be added to? | Yes | +| `length` | [`number`](/docs/kcl/types/std-types-number) | How far away along the Y axis should this line go? Incompatible with `endAbsolute`. | No | +| `endAbsolute` | [`number`](/docs/kcl/types/std-types-number) | Which absolute Y value should this line go to? Incompatible with `length`. | No | +| [`tag`](/docs/kcl/types/std-types-tag) | [`TagDeclarator`](/docs/kcl/types#TagDeclarator) | Create a new tag which refers to this line | No | ### Returns -[`Sketch`](/docs/kcl/types/Sketch) +[`Sketch`](/docs/kcl/types/std-types-Sketch) ### Examples diff --git a/rust/kcl-derive-docs/src/lib.rs b/rust/kcl-derive-docs/src/lib.rs index 0a0a5abd8..b1cb159c4 100644 --- a/rust/kcl-derive-docs/src/lib.rs +++ b/rust/kcl-derive-docs/src/lib.rs @@ -792,15 +792,21 @@ fn rust_type_to_openapi_type(t: &str) -> String { if t.starts_with("Option<") { t = t.replace("Option<", "").replace('>', ""); } + + if t == "[TyF64;2]" { + return "Point2d".to_owned(); + } + if t == "[TyF64;3]" { + return "Point3d".to_owned(); + } + if let Some((inner_type, _length)) = parse_array_type(&t) { t = format!("[{inner_type}]") } - if t == "f64" || t == "TyF64" { + if t == "f64" || t == "TyF64" || t == "u32" || t == "NonZeroU32" { return "number".to_string(); - } else if t == "u32" { - return "integer".to_string(); - } else if t == "str" { + } else if t == "str" || t == "String" { return "string".to_string(); } else { return t.replace("f64", "number").replace("TyF64", "number").to_string(); diff --git a/rust/kcl-lib/src/docs/gen_std_tests.rs b/rust/kcl-lib/src/docs/gen_std_tests.rs index 87f572a36..3f8c785ef 100644 --- a/rust/kcl-lib/src/docs/gen_std_tests.rs +++ b/rust/kcl-lib/src/docs/gen_std_tests.rs @@ -1,113 +1,60 @@ use std::{ - collections::{BTreeMap, HashMap}, - fs::File, + collections::HashMap, + fs::{self, File}, io::Read as _, + path::Path, }; use anyhow::Result; use base64::Engine; use convert_case::Casing; -use handlebars::Renderable; use indexmap::IndexMap; use itertools::Itertools; -use schemars::schema::SingleOrVec; use serde_json::json; use tokio::task::JoinSet; use super::kcl_doc::{ConstData, DocData, ExampleProperties, FnData, TyData}; -use crate::{ - docs::{is_primitive, StdLibFn}, - std::StdLib, - ExecutorContext, -}; +use crate::{docs::StdLibFn, std::StdLib, ExecutorContext}; -const TYPES_DIR: &str = "../../docs/kcl/types"; -const LANG_TOPICS: [&str; 5] = ["Types", "Modules", "Settings", "Known Issues", "Constants"]; -// These types are declared in std. -const DECLARED_TYPES: [&str; 14] = [ - "number", "string", "tag", "bool", "Sketch", "Solid", "Plane", "Helix", "Face", "Edge", "Point2d", "Point3d", - "Axis2d", "Axis3d", +const LANG_TOPICS: [&str; 4] = ["Types", "Modules", "Settings", "Known Issues"]; +// These types are declared in (KCL) std. +const DECLARED_TYPES: [&str; 15] = [ + "any", "number", "string", "tag", "bool", "Sketch", "Solid", "Plane", "Helix", "Face", "Edge", "Point2d", + "Point3d", "Axis2d", "Axis3d", ]; +// Types with special handling. +const SPECIAL_TYPES: [&str; 5] = ["TagDeclarator", "TagIdentifier", "Start", "End", "ImportedGeometry"]; + +const TYPE_REWRITES: [(&str, &str); 11] = [ + ("TagNode", "TagDeclarator"), + ("SketchData", "Plane | Solid"), + ("SketchOrSurface", "Sketch | Plane | Face"), + ("SketchSurface", "Plane | Face"), + ("SolidOrImportedGeometry", "[Solid] | ImportedGeometry"), + ( + "SolidOrSketchOrImportedGeometry", + "[Solid] | [Sketch] | ImportedGeometry", + ), + ("KclValue", "any"), + ("[KclValue]", "[any]"), + ("FaceTag", "TagIdentifier | Start | End"), + ("GeometryWithImportedGeometry", "Solid | Sketch | ImportedGeometry"), + ("SweepPath", "Sketch | Helix"), +]; + +fn rename_type(input: &str) -> &str { + for (i, o) in TYPE_REWRITES { + if input == i { + return o; + } + } + + input +} + fn init_handlebars() -> Result> { let mut hbs = handlebars::Handlebars::new(); - // Register the 'json' helper - hbs.register_helper( - "json", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let param = h.param(0).and_then(|v| v.value().as_str()).unwrap_or(""); - out.write(&serde_json::to_string(¶m).unwrap())?; - Ok(()) - }, - ), - ); - - // Register the 'basename' helper - hbs.register_helper( - "times", - Box::new( - |h: &handlebars::Helper, - hb: &handlebars::Handlebars, - ctx: &handlebars::Context, - rc: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let n = h.param(0).and_then(|v| v.value().as_u64()).ok_or_else(|| { - handlebars::RenderErrorReason::Other( - "times helper expects an integer as first parameter".to_string(), - ) - })?; - - let template = h - .template() - .ok_or_else(|| handlebars::RenderErrorReason::Other("times helper expects a block".to_string()))?; - - for i in 0..n { - let mut local_ctx = ctx.clone(); - let mut rc = rc.clone(); - let m = local_ctx.data_mut().as_object_mut().unwrap(); - m.insert("@index".to_string(), handlebars::JsonValue::Number(i.into())); - if i == 0 { - m.insert("@first".to_string(), handlebars::JsonValue::Bool(true)); - } - template.render(hb, &local_ctx, &mut rc, out)?; - } - - Ok(()) - }, - ), - ); - - hbs.register_helper( - "lte", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let a = h.param(0).and_then(|v| v.value().as_f64()).ok_or_else(|| { - handlebars::RenderErrorReason::Other("lte helper expects a number as first parameter".to_string()) - })?; - - let b = h.param(1).and_then(|v| v.value().as_f64()).ok_or_else(|| { - handlebars::RenderErrorReason::Other("lte helper expects a number as second parameter".to_string()) - })?; - - let result = a <= b; - out.write(if result { "true" } else { "false" })?; - - Ok(()) - }, - ), - ); hbs.register_helper( "firstLine", @@ -131,146 +78,6 @@ fn init_handlebars() -> Result> { ), ); - hbs.register_helper( - "neq", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let param1 = h - .param(0) - .ok_or_else(|| { - handlebars::RenderErrorReason::Other("neq helper expects two parameters".to_string()) - })? - .value(); - let param2 = h - .param(1) - .ok_or_else(|| { - handlebars::RenderErrorReason::Other("neq helper expects two parameters".to_string()) - })? - .value(); - - let result = param1 != param2; - out.write(if result { "true" } else { "false" })?; - - Ok(()) - }, - ), - ); - - // Register the 'lowercase' helper - hbs.register_helper( - "lowercase", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let param = h.param(0).and_then(|v| v.value().as_str()).unwrap_or(""); - out.write(¶m.to_lowercase())?; - Ok(()) - }, - ), - ); - - hbs.register_helper( - "pretty_enum", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - if let Some(enum_value) = h.param(0) { - if let Some(array) = enum_value.value().as_array() { - let pretty_options = array - .iter() - .filter_map(|v| v.as_str()) - .map(|s| format!("`{}`", s)) - .collect::>() - .join(", "); - out.write(&pretty_options)?; - return Ok(()); - } - } - out.write("Invalid enum")?; - Ok(()) - }, - ), - ); - - hbs.register_helper( - "pretty_enum", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - if let Some(enum_value) = h.param(0) { - if let Some(array) = enum_value.value().as_array() { - let pretty_options = array - .iter() - .filter_map(|v| v.as_str()) - .map(|s| format!("`{}`", s)) - .collect::>() - .join(", "); - out.write(&pretty_options)?; - return Ok(()); - } - } - out.write("Invalid enum")?; - Ok(()) - }, - ), - ); - - hbs.register_helper( - "pretty_ref", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - let param = h.param(0).and_then(|v| v.value().as_str()).unwrap_or(""); - let basename = param.split('/').next_back().unwrap_or(""); - out.write(&format!("`{}`", basename))?; - Ok(()) - }, - ), - ); - - // Register helper to remove newlines from a string. - hbs.register_helper( - "remove_newlines", - Box::new( - |h: &handlebars::Helper, - _: &handlebars::Handlebars, - _: &handlebars::Context, - _: &mut handlebars::RenderContext, - out: &mut dyn handlebars::Output| - -> handlebars::HelperResult { - if let Some(param) = h.param(0) { - if let Some(string) = param.value().as_str() { - out.write(&string.replace("\n", ""))?; - return Ok(()); - } - } - out.write("")?; - Ok(()) - }, - ), - ); - // Register a helper to do safe YAML new lines. hbs.register_helper( "safe_yaml", @@ -296,16 +103,9 @@ fn init_handlebars() -> Result> { ), ); - hbs.register_template_string("schemaType", include_str!("templates/schemaType.hbs"))?; - hbs.register_template_string("properties", include_str!("templates/properties.hbs"))?; - hbs.register_template_string("array", include_str!("templates/array.hbs"))?; - hbs.register_template_string("propertyType", include_str!("templates/propertyType.hbs"))?; - hbs.register_template_string("schema", include_str!("templates/schema.hbs"))?; hbs.register_template_string("index", include_str!("templates/index.hbs"))?; - hbs.register_template_string("consts-index", include_str!("templates/consts-index.hbs"))?; hbs.register_template_string("function", include_str!("templates/function.hbs"))?; hbs.register_template_string("const", include_str!("templates/const.hbs"))?; - hbs.register_template_string("type", include_str!("templates/type.hbs"))?; hbs.register_template_string("kclType", include_str!("templates/kclType.hbs"))?; Ok(hbs) @@ -318,7 +118,9 @@ fn generate_index(combined: &IndexMap>, kcl_lib: &[Doc functions.insert("std".to_owned(), Vec::new()); let mut constants = HashMap::new(); - constants.insert("std".to_owned(), Vec::new()); + + let mut types = HashMap::new(); + types.insert("Primitive types".to_owned(), Vec::new()); for key in combined.keys() { let internal_fn = combined @@ -335,33 +137,34 @@ fn generate_index(combined: &IndexMap>, kcl_lib: &[Doc .push((internal_fn.name(), internal_fn.name())); } + for name in SPECIAL_TYPES { + types + .get_mut("Primitive types") + .unwrap() + .push((name.to_owned(), format!("types.md#{name}"))); + } + for d in kcl_lib { if d.hide() { continue; } - functions.entry(d.mod_name()).or_default().push(match d { - DocData::Fn(f) => (f.preferred_name.clone(), d.file_name()), - DocData::Const(c) => (c.preferred_name.clone(), d.file_name()), - DocData::Ty(t) => (t.preferred_name.clone(), d.file_name()), - }); + let group = match d { + DocData::Fn(_) => functions.entry(d.mod_name()).or_default(), + DocData::Ty(_) => types.entry(d.mod_name()).or_default(), + DocData::Const(_) => constants.entry(d.mod_name()).or_default(), + }; - if let DocData::Const(c) = d { - constants - .entry(d.mod_name()) - .or_default() - .push((c.name.clone(), d.file_name())); - } + group.push((d.preferred_name().to_owned(), d.file_name())); } - // TODO we should sub-divide into types, constants, and functions. - let mut sorted: Vec<_> = functions + let mut sorted_fns: Vec<_> = functions .into_iter() .map(|(m, mut fns)| { fns.sort(); let val = json!({ "name": m, - "functions": fns.into_iter().map(|(n, f)| json!({ + "items": fns.into_iter().map(|(n, f)| json!({ "name": n, "file_name": f, })).collect::>(), @@ -369,35 +172,16 @@ fn generate_index(combined: &IndexMap>, kcl_lib: &[Doc (m, val) }) .collect(); - sorted.sort_by(|t1, t2| t1.0.cmp(&t2.0)); - let data: Vec<_> = sorted.into_iter().map(|(_, val)| val).collect(); + sorted_fns.sort_by(|t1, t2| t1.0.cmp(&t2.0)); + let functions_data: Vec<_> = sorted_fns.into_iter().map(|(_, val)| val).collect(); - let topics: Vec<_> = LANG_TOPICS - .iter() - .map(|name| { - json!({ - "name": name, - "file_name": name.to_lowercase().replace(' ', "-").replace("constants", "consts"), - }) - }) - .collect(); - let data = json!({ - "lang_topics": topics, - "modules": data, - }); - - let output = hbs.render("index", &data)?; - - expectorate::assert_contents("../../docs/kcl/index.md", &output); - - // Generate the index for the constants. let mut sorted_consts: Vec<_> = constants .into_iter() .map(|(m, mut consts)| { consts.sort(); let val = json!({ "name": m, - "consts": consts.into_iter().map(|(n, f)| json!({ + "items": consts.into_iter().map(|(n, f)| json!({ "name": n, "file_name": f, })).collect::>(), @@ -406,14 +190,45 @@ fn generate_index(combined: &IndexMap>, kcl_lib: &[Doc }) .collect(); sorted_consts.sort_by(|t1, t2| t1.0.cmp(&t2.0)); - let data: Vec<_> = sorted_consts.into_iter().map(|(_, val)| val).collect(); + let consts_data: Vec<_> = sorted_consts.into_iter().map(|(_, val)| val).collect(); + + let mut sorted_types: Vec<_> = types + .into_iter() + .map(|(m, mut tys)| { + tys.sort(); + let val = json!({ + "name": m, + "items": tys.into_iter().map(|(n, f)| json!({ + "name": n, + "file_name": f, + })).collect::>(), + }); + (m, val) + }) + .collect(); + sorted_types.sort_by(|t1, t2| t1.0.cmp(&t2.0)); + let types_data: Vec<_> = sorted_types.into_iter().map(|(_, val)| val).collect(); + + let topics: Vec<_> = LANG_TOPICS + .iter() + .map(|name| { + json!({ + "name": name, + "file_name": name.to_lowercase().replace(' ', "-"), + }) + }) + .collect(); + let data = json!({ - "consts": data, + "lang_topics": topics, + "functions": functions_data, + "consts": consts_data, + "types": types_data, }); - let output = hbs.render("consts-index", &data)?; + let output = hbs.render("index", &data)?; - expectorate::assert_contents("../../docs/kcl/consts.md", &output); + expectorate::assert_contents("../../docs/kcl/index.md", &output); Ok(()) } @@ -446,7 +261,7 @@ fn generate_example(index: usize, src: &str, props: &ExampleProperties, file_nam } fn generate_type_from_kcl(ty: &TyData, file_name: String, example_name: String) -> Result<()> { - if ty.properties.doc_hidden { + if ty.properties.doc_hidden || !DECLARED_TYPES.contains(&&*ty.name) { return Ok(()); } @@ -461,7 +276,7 @@ fn generate_type_from_kcl(ty: &TyData, file_name: String, example_name: String) let data = json!({ "name": ty.qual_name(), - "definition": ty.alias.as_ref().map(|t| cleanup_sig(format!("type {} = {t}", ty.preferred_name), ty.referenced_types.iter().filter(|t| !DECLARED_TYPES.contains(&&***t)))), + "definition": ty.alias.as_ref().map(|t| format!("type {} = {t}", ty.preferred_name)), "summary": ty.summary, "description": ty.description, "deprecated": ty.properties.deprecated, @@ -469,16 +284,13 @@ fn generate_type_from_kcl(ty: &TyData, file_name: String, example_name: String) }); let output = hbs.render("kclType", &data)?; - let output = cleanup_type_links( - &output, - ty.referenced_types.iter().filter(|t| !DECLARED_TYPES.contains(&&***t)), - ); + let output = cleanup_types(&output); expectorate::assert_contents(format!("../../docs/kcl/{}.md", file_name), &output); Ok(()) } -fn generate_function_from_kcl(function: &FnData, file_name: String) -> Result<()> { +fn generate_function_from_kcl(function: &FnData, file_name: String, example_name: String) -> Result<()> { if function.properties.doc_hidden { return Ok(()); } @@ -489,7 +301,7 @@ fn generate_function_from_kcl(function: &FnData, file_name: String) -> Result<() .examples .iter() .enumerate() - .filter_map(|(index, example)| generate_example(index, &example.0, &example.1, &file_name)) + .filter_map(|(index, example)| generate_example(index, &example.0, &example.1, &example_name)) .collect(); let data = json!({ @@ -497,10 +309,7 @@ fn generate_function_from_kcl(function: &FnData, file_name: String) -> Result<() "summary": function.summary, "description": function.description, "deprecated": function.properties.deprecated, - "fn_signature": cleanup_sig(function.preferred_name.clone() + &function.fn_signature(), function - .referenced_types - .iter() - .filter(|t| !DECLARED_TYPES.contains(&&***t))), + "fn_signature": function.preferred_name.clone() + &function.fn_signature(), "tags": [], "examples": examples, "is_utilities": false, @@ -521,14 +330,8 @@ fn generate_function_from_kcl(function: &FnData, file_name: String) -> Result<() }); let output = hbs.render("function", &data)?; - let output = cleanup_type_links( - &output, - function - .referenced_types - .iter() - .filter(|t| !DECLARED_TYPES.contains(&&***t)), - ); - expectorate::assert_contents(format!("../../docs/kcl/{}.md", file_name), &output); + let output = &cleanup_types(&output); + expectorate::assert_contents(format!("../../docs/kcl/{}.md", file_name), output); Ok(()) } @@ -562,11 +365,11 @@ fn generate_const_from_kcl(cnst: &ConstData, file_name: String, example_name: St Ok(()) } -fn generate_function(internal_fn: Box) -> Result> { +fn generate_function(internal_fn: Box) -> Result<()> { let hbs = init_handlebars()?; if internal_fn.unpublished() { - return Ok(BTreeMap::new()); + return Ok(()); } let fn_name = internal_fn.name(); @@ -598,48 +401,26 @@ fn generate_function(internal_fn: Box) -> Result>(), "return_value": internal_fn.return_value(false).map(|ret| { json!({ - "type_": ret.type_, + "type_": rename_type(&ret.type_), "description": ret.description(), }) }), @@ -647,295 +428,166 @@ fn generate_function(internal_fn: Box) -> Result(output: &str, types: impl Iterator) -> String { - let mut cleaned_output = output.to_string(); - - // Cleanup our weird number arrays. - // TODO: This is a hack for the handlebars template being too complex. - cleaned_output = cleaned_output.replace("`[, `number`, `number`]`", "`[number, number]`"); - cleaned_output = cleaned_output.replace("`[, `number`, `number`, `number`]`", "`[number, number, number]`"); - - // Fix the links to the types. - for type_name in types.map(|s| &**s).chain(DECLARED_TYPES) { - if type_name == "TagDeclarator" || type_name == "TagIdentifier" || type_name == "TagNode" || type_name == "tag" - { - continue; - } else { - let link = format!("(/docs/kcl/types/{})", type_name); - cleaned_output = - cleaned_output.replace(&format!("`{}`", type_name), &format!("[`{}`]{}", type_name, &link)); - // Do the same for the type with brackets. - cleaned_output = - cleaned_output.replace(&format!("`[{}]`", type_name), &format!("[`[{}]`]{}", type_name, link)); - } - } - - // TODO handle union types generically rather than special casing them. - cleaned_output = cleaned_output.replace( - "`Sketch | Plane | Face`", - "[`Sketch`](/docs/kcl/types/Sketch) or [`Plane`](/docs/kcl/types/Plane) or [`Face`](/docs/kcl/types/Face)", - ); - cleaned_output = cleaned_output.replace( - "`Axis3d | Edge`", - "[`Axis3d`](/docs/kcl/types/Axis3d) or [`Edge`](/docs/kcl/types/Edge)", - ); - cleaned_output = cleaned_output.replace( - "`Axis2d | Edge`", - "[`Axis2d`](/docs/kcl/types/Axis2d) or [`Edge`](/docs/kcl/types/Edge)", - ); - - // Fix the links to the types. - // Gross hack for the stupid alias types. - cleaned_output = cleaned_output.replace("TagNode", "TagDeclarator"); - - let link = "[`TagDeclarator`](/docs/kcl/types#tag-declaration)"; - cleaned_output = cleaned_output.replace("`TagDeclarator`", link); - let link = "[`TagIdentifier`](/docs/kcl/types#tag-identifier)"; - cleaned_output = cleaned_output.replace("`TagIdentifier`", link); - - cleaned_output -} - -// TODO total code dup with `cleanup_type_links`, just this version doesn't have the backticks. :-( -fn cleanup_sig<'a>(input: String, types: impl Iterator) -> String { - let mut cleaned_output = input; - - // Fix the links to the types. - for type_name in types.map(|s| &**s).chain(DECLARED_TYPES) { - if type_name == "TagDeclarator" || type_name == "TagIdentifier" || type_name == "TagNode" || type_name == "tag" - { - continue; - } else { - let link = format!("(/docs/kcl/types/{})", type_name); - // Do the same for the type with brackets. - cleaned_output = cleaned_output.replace(&format!("[{}]", type_name), &format!("[[{}]]{}", type_name, link)); - cleaned_output = cleaned_output.replace(type_name, &format!("[{}]{}", type_name, &link)); - } - } - - // TODO handle union types generically rather than special casing them. - cleaned_output = cleaned_output.replace( - "Sketch | Plane | Face", - "[Sketch](/docs/kcl/types/Sketch) | [Plane](/docs/kcl/types/Plane) | [Face](/docs/kcl/types/Face)", - ); - cleaned_output = cleaned_output.replace( - "Axis3d | Edge", - "[Axis3d](/docs/kcl/types/Axis3d) | [Edge](/docs/kcl/types/Edge)", - ); - cleaned_output = cleaned_output.replace( - "Axis2d | Edge", - "[Axis2d](/docs/kcl/types/Axis2d) | [Edge](/docs/kcl/types/Edge)", - ); - - // Fix the links to the types. - // Gross hack for the stupid alias types. - cleaned_output = cleaned_output.replace("TagNode", "TagDeclarator"); - - let link = "[TagDeclarator](/docs/kcl/types#tag-declaration)"; - cleaned_output = cleaned_output.replace("TagDeclarator", link); - let link = "[TagIdentifier](/docs/kcl/types#tag-identifier)"; - cleaned_output = cleaned_output.replace("TagIdentifier", link); - - cleaned_output -} - -fn add_to_types( - name: &str, - schema: &schemars::schema::Schema, - types: &mut BTreeMap, -) -> Result<()> { - if name.is_empty() { - return Err(anyhow::anyhow!("Empty type name")); - } - - if DECLARED_TYPES.contains(&name) || name == "TyF64" { - return Ok(()); - } - - if name.starts_with("number(") { - panic!("uom number"); - } - - let schemars::schema::Schema::Object(o) = schema else { - return Err(anyhow::anyhow!( - "Failed to get object schema, should have not been a primitive" - )); - }; - - if name == "SourceRange" { - types.insert(name.to_string(), schema.clone()); - return Ok(()); - } - - // If we have an array we want to generate the type markdown files for each item in the - // array. - if let Some(array) = &o.array { - // Recursively generate the type markdown files for each item in the array. - if let Some(items) = &array.items { - match items { - schemars::schema::SingleOrVec::Single(item) => { - if is_primitive(item)?.is_some() { - return Ok(()); - } - return add_to_types(name.trim_start_matches('[').trim_end_matches(']'), item, types); - } - schemars::schema::SingleOrVec::Vec(items) => { - for item in items { - if is_primitive(item)?.is_some() { - continue; - } - add_to_types(name.trim_start_matches('[').trim_end_matches(']'), item, types)?; - } - } - } - } else { - return Err(anyhow::anyhow!("Failed to get array items")); - } - } - - types.insert(name.to_string(), schema.clone()); - Ok(()) } -fn generate_type( - name: &str, - schema: &schemars::schema::Schema, - types: &BTreeMap, -) -> Result<()> { - if name.is_empty() { - return Err(anyhow::anyhow!("Empty type name")); +fn cleanup_types(input: &str) -> String { + #[derive(Copy, Clone, Eq, PartialEq, Debug)] + enum State { + Text, + PreCodeBlock, + CodeBlock, + CodeBlockType, + Slash, + Comment, } - // Skip over TagDeclarator and TagIdentifier since they have custom docs. - if name == "TagDeclarator" || name == "TagIdentifier" || name == "TagNode" || name == "TyF64" { - return Ok(()); - } + let mut output = String::new(); + let mut code_annot = String::new(); + let mut code = String::new(); + let mut code_type = String::new(); + let mut state = State::Text; + let mut ticks = 0; - let schemars::schema::Schema::Object(o) = schema else { - return Err(anyhow::anyhow!( - "Failed to get object schema, should have not been a primitive" - )); - }; - - // If we have an array we want to generate the type markdown files for each item in the - // array. - if let Some(array) = &o.array { - // Recursively generate the type markdown files for each item in the array. - if let Some(items) = &array.items { - match items { - schemars::schema::SingleOrVec::Single(item) => { - if is_primitive(item)?.is_some() { - return Ok(()); - } - return generate_type(name.trim_start_matches('[').trim_end_matches(']'), item, types); + for c in input.chars() { + if state == State::CodeBlockType { + if ['`', ',', '\n', ')', '/'].contains(&c) { + if code_type.starts_with(' ') { + code.push(' '); } - schemars::schema::SingleOrVec::Vec(items) => { - for item in items { - if is_primitive(item)?.is_some() { - continue; - } - generate_type(name.trim_start_matches('[').trim_end_matches(']'), item, types)?; + code.push_str(&cleanup_type_string(code_type.trim(), false)); + if code_type.ends_with(' ') { + code.push(' '); + } + + code_type = String::new(); + state = State::CodeBlock; + } else { + code_type.push(c); + continue; + } + } + if c == '`' { + if state == State::Comment { + code.push(c); + } else { + if state == State::Slash { + state = State::CodeBlock; + } + + ticks += 1; + if ticks == 3 { + if state == State::Text { + state = State::PreCodeBlock; + } else { + output.push_str("```"); + output.push_str(&code_annot); + output.push_str(&code); + // `code` includes the first two of three backticks + output.push('`'); + state = State::Text; + code_annot = String::new(); + code = String::new(); } - return Ok(()); + ticks = 0; + } else if state == State::Text && ticks == 2 && !code.is_empty() { + output.push_str(&cleanup_type_string(&code, true)); + code = String::new(); + ticks = 0; + } else if state == State::CodeBlock { + code.push(c); } } } else { - return Err(anyhow::anyhow!("Failed to get array items")); + if ticks == 2 { + // Empty code block + ticks = 0; + } + + if c == '\n' && (state == State::PreCodeBlock || state == State::Comment) { + state = State::CodeBlock; + } + + if c == '/' { + match state { + State::CodeBlock => state = State::Slash, + State::Slash => state = State::Comment, + _ => {} + } + } else if state == State::Slash { + state = State::CodeBlock; + } + + match state { + State::Text if ticks == 0 => output.push(c), + State::Text if ticks == 1 => code.push(c), + State::Text => unreachable!(), + State::PreCodeBlock => code_annot.push(c), + State::CodeBlock | State::Slash | State::Comment => code.push(c), + State::CodeBlockType => unreachable!(), + } + + if c == ':' && state == State::CodeBlock { + state = State::CodeBlockType; + } } } - // Make sure the name is pascal cased. - if !(name.is_case(convert_case::Case::Pascal) - || name == "Point3d" - || name == "Point2d" - || name == "CircularPattern2dData" - || name == "CircularPattern3dData" - || name == "LinearPattern2dData" - || name == "LinearPattern3dData" - || name == "Mirror2dData" - || name == "Axis2dOrEdgeReference" - || name == "Axis3dOrEdgeReference" - || name == "AxisAndOrigin2d" - || name == "AxisAndOrigin3d") - { - return Err(anyhow::anyhow!("Type name is not pascal cased: {}", name)); - } - - let cleaned_schema = recurse_and_create_references(name, schema, types)?; - - let schemars::schema::Schema::Object(o) = cleaned_schema else { - return Err(anyhow::anyhow!( - "Failed to get object schema, should have not been a primitive" - )); - }; - - let hbs = init_handlebars()?; - - // Add the name as the title. - let mut object = o.clone(); - if let Some(metadata) = object.metadata.as_mut() { - metadata.title = Some(name.to_string()); - } else { - object.metadata = Some(Box::new(schemars::schema::Metadata { - title: Some(name.to_string()), - ..Default::default() - })); - } - - // Cleanup the description. - let object = cleanup_type_description(&object) - .map_err(|e| anyhow::anyhow!("Failed to cleanup type description for type `{}`: {}", name, e))?; - - let data = json!(schemars::schema::Schema::Object(object)); - - let mut output = hbs.render("type", &data)?; - // Fix the links to the types. - output = cleanup_type_links(&output, types.keys()); - expectorate::assert_contents(format!("{}/{}.md", TYPES_DIR, name), &output); - - Ok(()) + output } -fn cleanup_type_description(object: &schemars::schema::SchemaObject) -> Result { - let mut object = object.clone(); - if let Some(metadata) = object.metadata.as_mut() { - if let Some(description) = metadata.description.as_mut() { - // Find any ```kcl code blocks and format the code. - // Parse any code blocks from the doc string. - let mut code_blocks = Vec::new(); - let d = description.clone(); - for line in d.lines() { - if line.starts_with("```kcl") && line.ends_with("```") { - code_blocks.push(line); +fn cleanup_type_string(input: &str, fmt_for_text: bool) -> String { + assert!( + !(input.starts_with('[') && input.ends_with(']') && input.contains('|')), + "Arrays of unions are not supported" + ); + + let input = rename_type(input); + + let tys: Vec<_> = input + .split('|') + .map(|ty| { + let ty = ty.trim(); + + let mut prefix = String::new(); + let mut suffix = String::new(); + + if fmt_for_text { + prefix.push('`'); + suffix.push('`'); + } + + let ty = if ty.starts_with('[') { + if ty.ends_with("; 1+]") { + prefix = format!("{prefix}["); + suffix = format!("; 1+]{suffix}"); + &ty[1..ty.len() - 5] + } else if ty.ends_with(']') { + prefix = format!("{prefix}["); + suffix = format!("]{suffix}"); + &ty[1..ty.len() - 1] + } else { + ty } + } else { + ty + }; + + if SPECIAL_TYPES.contains(&ty) { + format!("[{prefix}{ty}{suffix}](/docs/kcl/types#{ty})") + } else if DECLARED_TYPES.contains(&ty) { + format!("[{prefix}{ty}{suffix}](/docs/kcl/types/std-types-{ty})") + } else { + format!("{prefix}{input}{suffix}") } + }) + .collect(); - // Parse the kcl and recast it. - for code_block in &code_blocks { - let trimmed = code_block.trim_start_matches("```kcl").trim_end_matches("```"); - let program = crate::Program::parse_no_errs(trimmed)?; - - let options = crate::parsing::ast::types::FormatOptions { - insert_final_newline: false, - ..Default::default() - }; - let cleaned = program.ast.recast(&options, 0); - - *description = description.replace(code_block, &format!("```kcl\n{}\n```", cleaned)); - } - } - } - - Ok(object) + tys.join(if fmt_for_text { " or " } else { " | " }) } fn clean_function_name(name: &str) -> String { @@ -946,14 +598,6 @@ fn clean_function_name(name: &str) -> String { fn_name = fn_name.replace("last_seg_", "last_segment_"); } else if fn_name.contains("_2_d") { fn_name = fn_name.replace("_2_d", "_2d"); - } else if fn_name.contains("_greater_than_or_eq") { - fn_name = fn_name.replace("_greater_than_or_eq", "_gte"); - } else if fn_name.contains("_less_than_or_eq") { - fn_name = fn_name.replace("_less_than_or_eq", "_lte"); - } else if fn_name.contains("_greater_than") { - fn_name = fn_name.replace("_greater_than", "_gt"); - } else if fn_name.contains("_less_than") { - fn_name = fn_name.replace("_less_than", "_lt"); } else if fn_name.contains("_3_d") { fn_name = fn_name.replace("_3_d", "_3d"); } else if fn_name == "seg_ang" { @@ -962,172 +606,11 @@ fn clean_function_name(name: &str) -> String { fn_name = "segment_length".to_string(); } else if fn_name.starts_with("seg_") { fn_name = fn_name.replace("seg_", "segment_"); - } else if fn_name.starts_with("log_") { - fn_name = fn_name.replace("log_", "log"); - } else if fn_name.ends_with("tan_2") { - fn_name = fn_name.replace("tan_2", "tan2"); } fn_name } -/// Recursively create references for types we already know about. -fn recurse_and_create_references( - name: &str, - schema: &schemars::schema::Schema, - types: &BTreeMap, -) -> Result { - if DECLARED_TYPES.contains(&name) || name == "TyF64" { - return Ok(schema.clone()); - } - - let schemars::schema::Schema::Object(o) = schema else { - return Err(anyhow::anyhow!( - "Failed to get object schema, should have not been a primitive" - )); - }; - - // If we already have a reference add the metadata to the reference if it has none. - if let Some(reference) = &o.reference { - let mut obj = o.clone(); - let reference = reference.trim_start_matches("#/components/schemas/"); - if DECLARED_TYPES.contains(&reference) || reference == "TyF64" { - return Ok(schema.clone()); - } - - let t = types - .get(reference) - .ok_or_else(|| anyhow::anyhow!("Failed to get type: {} {:?}", reference, types.keys()))?; - - let schemars::schema::Schema::Object(to) = t else { - return Err(anyhow::anyhow!( - "Failed to get object schema, should have not been a primitive" - )); - }; - - // If this is a primitive just use the primitive. - if to.subschemas.is_none() && to.object.is_none() && to.reference.is_none() { - return Ok(t.clone()); - } - - // Otherwise append the metadata to our reference. - if let Some(metadata) = obj.metadata.as_mut() { - if metadata.description.is_none() { - metadata.description = to.metadata.as_ref().and_then(|m| m.description.clone()); - } - } else { - obj.metadata = to.metadata.clone(); - } - - let obj = cleanup_type_description(&obj) - .map_err(|e| anyhow::anyhow!("Failed to cleanup type description for type `{}`: {}", name, e))?; - return Ok(schemars::schema::Schema::Object(obj)); - } - - let mut obj = o.clone(); - - // If we have an object iterate over the properties and recursively create references. - if let Some(object) = &mut obj.object { - for (_, value) in object.properties.iter_mut() { - let new_value = recurse_and_create_references(name, value, types)?; - *value = new_value; - } - } - - // If we have an array iterate over the items and recursively create references. - if let Some(array) = &mut obj.array { - if let Some(items) = &mut array.items { - match items { - schemars::schema::SingleOrVec::Single(item) => { - let new_item = recurse_and_create_references(name, item, types)?; - *item = Box::new(new_item); - } - schemars::schema::SingleOrVec::Vec(items) => { - for item in items { - let new_item = recurse_and_create_references(name, item, types)?; - *item = new_item; - } - } - } - } - } - - // If we have subschemas iterate over them and recursively create references. - if let Some(subschema) = &mut obj.subschemas { - // Do anyOf. - if let Some(any_of) = &mut subschema.any_of { - // If we only have one item in anyOf we can just return that item. - if any_of.len() == 1 { - let mut new_item = recurse_and_create_references(name, &any_of[0], types)?; - if let schemars::schema::Schema::Object(new_obj) = &mut new_item { - if let Some(metadata) = new_obj.metadata.as_mut() { - metadata.description = obj.metadata.as_ref().and_then(|m| m.description.clone()); - } else { - new_obj.metadata = obj.metadata.clone(); - } - } - return Ok(new_item); - } - for item in any_of { - let new_item = recurse_and_create_references(name, item, types)?; - *item = new_item; - } - } - - // Do allOf. - if let Some(all_of) = &mut subschema.all_of { - // If we only have one item in allOf we can just return that item. - if all_of.len() == 1 { - let mut new_item = recurse_and_create_references(name, &all_of[0], types)?; - if let schemars::schema::Schema::Object(new_obj) = &mut new_item { - if let Some(metadata) = new_obj.metadata.as_mut() { - metadata.description = obj.metadata.as_ref().and_then(|m| m.description.clone()); - } else { - new_obj.metadata = obj.metadata.clone(); - } - } - return Ok(new_item); - } - for item in all_of { - let new_item = recurse_and_create_references(name, item, types)?; - *item = new_item; - } - } - - // Do oneOf. - if let Some(one_of) = &mut subschema.one_of { - // If we only have one item in oneOf we can just return that item. - if one_of.len() == 1 { - let mut new_item = recurse_and_create_references(name, &one_of[0], types)?; - if let schemars::schema::Schema::Object(new_obj) = &mut new_item { - if let Some(metadata) = new_obj.metadata.as_mut() { - metadata.description = obj.metadata.as_ref().and_then(|m| m.description.clone()); - } else { - new_obj.metadata = obj.metadata.clone(); - } - } - return Ok(new_item); - } - for item in one_of { - let new_item = recurse_and_create_references(name, item, types)?; - *item = new_item; - } - } - - if subschema.one_of.is_none() && subschema.all_of.is_none() && subschema.any_of.is_none() && obj.array.is_none() - { - if let Some(SingleOrVec::Single(_)) = &o.instance_type { - return Ok(schema.clone()); - } - } - } - - let obj = cleanup_type_description(&obj) - .map_err(|e| anyhow::anyhow!("Failed to cleanup type description for type `{}`: {}", name, e))?; - - Ok(schemars::schema::Schema::Object(obj.clone())) -} - #[test] fn test_generate_stdlib_markdown_docs() { let stdlib = StdLib::new(); @@ -1137,25 +620,24 @@ fn test_generate_stdlib_markdown_docs() { // Generate the index which is the table of contents. generate_index(&combined, &kcl_std).unwrap(); - let mut types = BTreeMap::new(); for key in combined.keys().sorted() { let internal_fn = combined.get(key).unwrap(); - let fn_types = generate_function(internal_fn.clone()).unwrap(); - types.extend(fn_types); - } - - // Generate the type markdown files. - for (name, schema) in &types { - generate_type(name, schema, &types).unwrap(); + generate_function(internal_fn.clone()).unwrap(); } for d in &kcl_std { match d { - DocData::Fn(f) => generate_function_from_kcl(f, d.file_name()).unwrap(), + DocData::Fn(f) => generate_function_from_kcl(f, d.file_name(), d.example_name()).unwrap(), DocData::Const(c) => generate_const_from_kcl(c, d.file_name(), d.example_name()).unwrap(), DocData::Ty(t) => generate_type_from_kcl(t, d.file_name(), d.example_name()).unwrap(), } } + + // Copy manually written docs to the output directory. + for entry in fs::read_dir("../../docs/kcl-src").unwrap() { + let path = entry.unwrap().path(); + fs::copy(&path, Path::new("../../docs/kcl").join(path.file_name().unwrap())).unwrap(); + } } #[test] @@ -1185,8 +667,7 @@ fn test_generate_stdlib_json_schema() { async fn test_code_in_topics() { let mut join_set = JoinSet::new(); for name in LANG_TOPICS { - let filename = - format!("../../docs/kcl/{}.md", name.to_lowercase().replace(' ', "-")).replace("constants", "consts"); + let filename = format!("../../docs/kcl/{}.md", name.to_lowercase().replace(' ', "-")); let mut file = File::open(&filename).unwrap(); let mut text = String::new(); file.read_to_string(&mut text).unwrap(); diff --git a/rust/kcl-lib/src/docs/kcl_doc.rs b/rust/kcl-lib/src/docs/kcl_doc.rs index a36ecde75..e01e8b72b 100644 --- a/rust/kcl-lib/src/docs/kcl_doc.rs +++ b/rust/kcl-lib/src/docs/kcl_doc.rs @@ -1,8 +1,4 @@ -use std::{ - collections::{HashMap, HashSet}, - fmt, - str::FromStr, -}; +use std::{collections::HashMap, fmt, str::FromStr}; use regex::Regex; use tower_lsp::lsp_types::{ @@ -13,7 +9,7 @@ use tower_lsp::lsp_types::{ use crate::{ execution::annotations, parsing::{ - ast::types::{Annotation, ImportSelector, ItemVisibility, Node, PrimitiveType, Type, VariableKind}, + ast::types::{Annotation, ImportSelector, ItemVisibility, Node, VariableKind}, token::NumericSuffix, }, ModuleId, @@ -159,6 +155,15 @@ impl DocData { } } + #[allow(dead_code)] + pub fn preferred_name(&self) -> &str { + match self { + DocData::Fn(f) => &f.preferred_name, + DocData::Const(c) => &c.preferred_name, + DocData::Ty(t) => &t.preferred_name, + } + } + pub fn qual_name(&self) -> &str { match self { DocData::Fn(f) => &f.qual_name, @@ -180,18 +185,18 @@ impl DocData { #[allow(dead_code)] pub fn file_name(&self) -> String { match self { - DocData::Fn(f) => f.qual_name.replace("::", "-"), + DocData::Fn(f) => format!("functions/{}", f.qual_name.replace("::", "-")), DocData::Const(c) => format!("consts/{}", c.qual_name.replace("::", "-")), - DocData::Ty(t) => format!("types/{}", t.name.clone()), + DocData::Ty(t) => format!("types/{}", t.qual_name.replace("::", "-")), } } #[allow(dead_code)] pub fn example_name(&self) -> String { match self { - DocData::Fn(f) => f.qual_name.replace("::", "-"), + DocData::Fn(f) => format!("fn_{}", f.qual_name.replace("::", "-")), DocData::Const(c) => format!("const_{}", c.qual_name.replace("::", "-")), - DocData::Ty(t) => t.name.clone(), + DocData::Ty(t) => format!("ty_{}", t.qual_name.replace("::", "-")), } } @@ -400,8 +405,6 @@ pub struct FnData { /// Code examples. /// These are tested and we know they compile and execute. pub examples: Vec<(String, ExampleProperties)>, - #[allow(dead_code)] - pub referenced_types: Vec, pub module_name: String, } @@ -420,16 +423,6 @@ impl FnData { let name = var.declaration.id.name.clone(); qual_name.push_str(&name); - let mut referenced_types = HashSet::new(); - if let Some(t) = &expr.return_type { - collect_type_names(&mut referenced_types, t); - } - for p in &expr.params { - if let Some(t) = &p.type_ { - collect_type_names(&mut referenced_types, t); - } - } - FnData { preferred_name: format!("{preferred_prefix}{name}"), name, @@ -445,7 +438,6 @@ impl FnData { summary: None, description: None, examples: Vec::new(), - referenced_types: referenced_types.into_iter().collect(), module_name: module_name.to_owned(), } } @@ -726,8 +718,6 @@ pub struct TyData { /// Code examples. /// These are tested and we know they compile and execute. pub examples: Vec<(String, ExampleProperties)>, - #[allow(dead_code)] - pub referenced_types: Vec, pub module_name: String, } @@ -741,10 +731,6 @@ impl TyData { ) -> Self { let name = ty.name.name.clone(); qual_name.push_str(&name); - let mut referenced_types = HashSet::new(); - if let Some(t) = &ty.alias { - collect_type_names(&mut referenced_types, t); - } TyData { preferred_name: format!("{preferred_prefix}{name}"), @@ -760,7 +746,6 @@ impl TyData { summary: None, description: None, examples: Vec::new(), - referenced_types: referenced_types.into_iter().collect(), module_name: module_name.to_owned(), } } @@ -1056,35 +1041,6 @@ impl ApplyMeta for ArgData { } } -fn collect_type_names(acc: &mut HashSet, ty: &Type) { - match ty { - Type::Primitive(primitive_type) => { - acc.insert(collect_type_names_from_primitive(primitive_type)); - } - Type::Array { ty, .. } => { - collect_type_names(acc, ty); - } - Type::Union { tys } => tys.iter().for_each(|t| { - acc.insert(collect_type_names_from_primitive(t)); - }), - Type::Object { properties } => properties.iter().for_each(|p| { - if let Some(t) = &p.type_ { - collect_type_names(acc, t) - } - }), - } -} - -fn collect_type_names_from_primitive(ty: &PrimitiveType) -> String { - match ty { - PrimitiveType::String => "string".to_owned(), - PrimitiveType::Number(_) => "number".to_owned(), - PrimitiveType::Boolean => "bool".to_owned(), - PrimitiveType::Tag => "tag".to_owned(), - PrimitiveType::Named(id) => id.name.clone(), - } -} - #[cfg(test)] mod test { use kcl_derive_docs::for_each_std_mod; diff --git a/rust/kcl-lib/src/docs/templates/array.hbs b/rust/kcl-lib/src/docs/templates/array.hbs deleted file mode 100644 index 3a1fcc1d5..000000000 --- a/rust/kcl-lib/src/docs/templates/array.hbs +++ /dev/null @@ -1 +0,0 @@ -{{~ #if maxItems ~}}{{~ #if (lte maxItems 3) ~}}`[{{#times maxItems ~}}{{~ #if @first ~}}{{else ~}}, {{/if ~}}{{> propertyType ../items}}{{/times}}]`{{else ~}}`[` {{ > propertyType items }} `]`{{~ /if ~}}{{else ~}}`[` {{ > propertyType items }} `]`{{~ /if ~}} diff --git a/rust/kcl-lib/src/docs/templates/consts-index.hbs b/rust/kcl-lib/src/docs/templates/consts-index.hbs deleted file mode 100644 index b489921d5..000000000 --- a/rust/kcl-lib/src/docs/templates/consts-index.hbs +++ /dev/null @@ -1,17 +0,0 @@ ---- -title: "KCL Constants" -excerpt: "Documentation for the KCL constants." -layout: manual ---- - -## Table of Contents - -{{#each consts}} - -### `{{name}}` - -{{#each consts}} -- [`{{name}}`](/docs/kcl/{{file_name}}) -{{/each}} -{{/each}} - diff --git a/rust/kcl-lib/src/docs/templates/index.hbs b/rust/kcl-lib/src/docs/templates/index.hbs index 40cfc6e09..f03800824 100644 --- a/rust/kcl-lib/src/docs/templates/index.hbs +++ b/rust/kcl-lib/src/docs/templates/index.hbs @@ -12,11 +12,31 @@ layout: manual * [`{{name}}`](kcl/{{file_name}}) {{/each}} -### Standard library +### Functions -{{#each modules}} -* **{{name}}** {{#each functions}} +* **{{name}}** +{{#each items}} * [`{{name}}`](kcl/{{file_name}}) {{/each}} {{/each}} + +### Constants + +{{#each consts}} +* **{{name}}** +{{#each items}} + * [`{{name}}`](kcl/{{file_name}}) +{{/each}} +{{/each}} + +### Types + +See also the [types overview](types) + +{{#each types}} +* **{{name}}** +{{#each items}} + * [`{{name}}`](kcl/{{file_name}}) +{{/each}} +{{/each}} \ No newline at end of file diff --git a/rust/kcl-lib/src/docs/templates/properties.hbs b/rust/kcl-lib/src/docs/templates/properties.hbs deleted file mode 100644 index 283f68456..000000000 --- a/rust/kcl-lib/src/docs/templates/properties.hbs +++ /dev/null @@ -1,13 +0,0 @@ -{{#if properties}} -{{#if @root.inDefinition}} -#### Properties -{{else}} -## Properties -{{/if}} - -| Property | Type | Description | Required | -|----------|------|-------------|----------| -{{#each properties}} -| `{{@key}}` | {{~ > propertyType this ~}} | {{{firstLine this.description}}} | {{#if (lookup ../required @key)}}Yes{{else}}No{{/if}} | -{{/each}} -{{/if}} diff --git a/rust/kcl-lib/src/docs/templates/propertyType.hbs b/rust/kcl-lib/src/docs/templates/propertyType.hbs deleted file mode 100644 index 1c7064831..000000000 --- a/rust/kcl-lib/src/docs/templates/propertyType.hbs +++ /dev/null @@ -1,11 +0,0 @@ -{{~ #if $ref ~}} -{{pretty_ref $ref}}{{else if anyOf ~}} -**anyOf:** {{#each anyOf}}{{> propertyType this}}{{#unless @last}} **OR** {{/unless}}{{/each}}{{else if oneOf ~}} -**oneOf:** {{#each oneOf}}{{> propertyType this}}{{#unless @last}} **OR** {{/unless}}{{/each}}{{else if allOf ~}} -**allOf:** {{#each allOf}}{{> propertyType this}}{{#unless @last}} **OR** {{/unless}}{{/each}}{{else if enum ~}} -enum: {{pretty_enum enum}}{{else if items ~}} -{{~ >array ~}}{{else ~}} -`{{type}}{{~ #if format }}{{#if neq format "double" }} ({{format}}){{~/if ~}} -{{~ /if ~}}` -{{~ #if maximum }} (**maximum:** {{maximum}}){{~/if~}}{{~ #if minimum }} (**minimum:** {{minimum}}){{~/if~}} -{{~ /if ~}} diff --git a/rust/kcl-lib/src/docs/templates/schema.hbs b/rust/kcl-lib/src/docs/templates/schema.hbs deleted file mode 100644 index 6dca717f5..000000000 --- a/rust/kcl-lib/src/docs/templates/schema.hbs +++ /dev/null @@ -1,70 +0,0 @@ -{{#if description}} -{{{description}}} -{{/if}} - -{{#if $ref}} -{{pretty_ref $ref}} -{{else if enum}} -**enum:** {{pretty_enum enum}} -{{else if type}} -**Type:** `{{type}}`{{~ #if format }} (`{{format}}`){{~/if ~}}{{~ #if maximum }} (**maximum:** {{maximum}}){{~/if~}}{{~ #if minimum }} (**minimum:** {{minimum}}){{~/if~}} -{{else}} -{{/if}} - -{{#if $schema}} -**Schema:** `{{$schema}}` -{{/if}} - -{{#if items}} -{{>array}} -{{/if}} - -{{#if anyOf}} -**This schema accepts any of the following:** - -{{#each anyOf}} -{{> schema this}} ----- -{{/each}} -{{/if}} - -{{#if oneOf}} -**This schema accepts exactly one of the following:** - -{{#each oneOf}} -{{> schema this}} ----- -{{/each}} -{{/if}} - -{{#if allOf}} -**This schema requires all of the following:** - -{{#each allOf}} -{{> schema this}} ----- -{{/each}} -{{/if}} - -{{> properties}} - -{{#if definitions}} -## Definitions - -{{#each definitions}} -### {{@key}} - -{{> schemaType this}} - -{{/each}} -{{/if}} - -{{#if examples}} -## Examples - -{{#each examples}} -```json -{{{json this}}} -``` -{{/each}} -{{/if}} diff --git a/rust/kcl-lib/src/docs/templates/schemaType.hbs b/rust/kcl-lib/src/docs/templates/schemaType.hbs deleted file mode 100644 index b28637518..000000000 --- a/rust/kcl-lib/src/docs/templates/schemaType.hbs +++ /dev/null @@ -1,19 +0,0 @@ -{{#if $ref}} -{{pretty_ref $ref}} -{{else if anyOf}} -**anyOf** -{{else if oneOf}} -**oneOf** -{{else if allOf}} -**allOf** -{{else if enum}} -**enum:** {{pretty_enum enum}} -{{else}} -`{{type}}`{{ -#if - format}} (`{{format}}`){{ -/if -}} -{{ -/if -}} diff --git a/rust/kcl-lib/src/docs/templates/type.hbs b/rust/kcl-lib/src/docs/templates/type.hbs deleted file mode 100644 index 0a1050857..000000000 --- a/rust/kcl-lib/src/docs/templates/type.hbs +++ /dev/null @@ -1,7 +0,0 @@ ---- -title: "{{title}}" -excerpt: "{{safe_yaml description}}" -layout: manual ---- - -{{> schema this}} diff --git a/rust/kcl-lib/src/lsp/tests.rs b/rust/kcl-lib/src/lsp/tests.rs index 669a7133d..4ca1cf4c0 100644 --- a/rust/kcl-lib/src/lsp/tests.rs +++ b/rust/kcl-lib/src/lsp/tests.rs @@ -1016,7 +1016,7 @@ startSketchOn(XY) match hover.unwrap().contents { tower_lsp::lsp_types::HoverContents::Markup(tower_lsp::lsp_types::MarkupContent { value, .. }) => { - assert!(value.contains("end?: [number]")); + assert!(value.contains("end?: Point2d")); assert!(value.contains("How far away (along the X and Y axes) should this line go?")); } _ => unreachable!(), @@ -4012,7 +4012,7 @@ startSketchOn(XY) match hover.unwrap().contents { tower_lsp::lsp_types::HoverContents::Markup(tower_lsp::lsp_types::MarkupContent { value, .. }) => { - assert!(value.contains("end?: [number]")); + assert!(value.contains("end?: Point2d")); assert!(value.contains("How far away (along the X and Y axes) should this line go?")); } _ => unreachable!(), diff --git a/rust/kcl-lib/src/settings/generate_settings_docs.rs b/rust/kcl-lib/src/settings/generate_settings_docs.rs index 3e484349e..20695567e 100644 --- a/rust/kcl-lib/src/settings/generate_settings_docs.rs +++ b/rust/kcl-lib/src/settings/generate_settings_docs.rs @@ -39,8 +39,8 @@ base_unit = "mm" text_wrapping = false "#; -const PROJECT_SETTINGS_DOC_PATH: &str = "../../docs/kcl/settings/project.md"; -const USER_SETTINGS_DOC_PATH: &str = "../../docs/kcl/settings/user.md"; +const PROJECT_SETTINGS_DOC_PATH: &str = "../../docs/kcl/settings-project.md"; +const USER_SETTINGS_DOC_PATH: &str = "../../docs/kcl/settings-user.md"; fn init_handlebars() -> handlebars::Handlebars<'static> { let mut hbs = handlebars::Handlebars::new(); diff --git a/rust/kcl-lib/std/types.kcl b/rust/kcl-lib/std/types.kcl index 995221bb3..848dc98b3 100644 --- a/rust/kcl-lib/std/types.kcl +++ b/rust/kcl-lib/std/types.kcl @@ -1,6 +1,10 @@ @no_std @settings(defaultLengthUnit = mm) +/// Any value. +@(impl = primitive) +export type any + /// A number /// /// May be signed or unsigned, an integer or decimal value. diff --git a/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md b/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md index 1c1175c73..b611fa6d0 100644 --- a/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md +++ b/rust/kcl-lib/tests/kcl_samples/axial-fan/artifact_graph_flowchart.snap.md @@ -605,19 +605,19 @@ flowchart LR 84 --- 147 84 --- 233 87 --- 169 - 87 x--> 183 + 87 x--> 184 87 --- 212 87 --- 257 89 --- 168 - 89 x--> 183 + 89 x--> 184 89 --- 214 89 --- 258 90 --- 167 - 90 x--> 183 + 90 x--> 184 90 --- 211 90 --- 256 92 --- 166 - 92 x--> 183 + 92 x--> 184 92 --- 213 92 --- 259 119 --- 162 @@ -865,10 +865,10 @@ flowchart LR 221 <--x 181 222 <--x 181 193 <--x 182 - 211 <--x 184 - 212 <--x 184 - 213 <--x 184 - 214 <--x 184 + 211 <--x 183 + 212 <--x 183 + 213 <--x 183 + 214 <--x 183 203 <--x 186 204 <--x 186 205 <--x 186 diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_x0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_x0.png deleted file mode 100644 index 5e10b3a04..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_x0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_y0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_y0.png deleted file mode 100644 index 01ba6d038..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angle_to_match_length_y0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_x_length0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_x_length0.png deleted file mode 100644 index c9a36c911..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_x_length0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_y_length0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_y_length0.png deleted file mode 100644 index 7fe8900e6..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_of_y_length0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_x0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_x0.png deleted file mode 100644 index 5c056bc06..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_x0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_y0.png b/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_y0.png deleted file mode 100644 index c6d65c6bd..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_angled_line_to_y0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_gt0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_gt0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_assert_gt0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_gte0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_gte0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_assert_gte0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_lt0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_lt0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_assert_lt0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_lte0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_lte0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_assert_lte0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png b/rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_assert_order0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_atan0.png b/rust/kcl-lib/tests/outputs/serial_test_example_atan0.png deleted file mode 100644 index b6db63cd5..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_atan0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_e0.png b/rust/kcl-lib/tests/outputs/serial_test_example_e0.png deleted file mode 100644 index 5c79e062e..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_e0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-helix0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-helix0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-helix1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-helix1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-helix2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-helix2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-helix3.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix3.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-helix3.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-helix3.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-abs0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-abs0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-abs0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-abs0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-acos0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-acos0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-acos0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-acos0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-asin0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-asin0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-asin0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-asin0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-atan20.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-atan20.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-atan20.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-atan20.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-ceil0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-ceil0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-ceil0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-ceil0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-cos0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-cos0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-cos0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-cos0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-floor0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-floor0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-floor0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-floor0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-ln0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-ln0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-ln0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-ln0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-log0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-log0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-log100.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log100.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-log100.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log100.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-log20.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log20.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-log20.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-log20.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-max0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-max0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-max0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-max0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-min0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-min0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-min0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-min0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-polar0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-polar0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-polar0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-polar0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-pow0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-pow0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-pow0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-pow0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_Sketch1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-rem0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_Sketch1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-rem0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-round0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-round0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-round0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-round0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-sin0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-sin0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-sin0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-sin0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-sqrt0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-sqrt0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-sqrt0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-sqrt0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-tan0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-tan0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-math-tan0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-math-tan0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane3.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane3.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane3.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane3.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane4.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane4.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-offsetPlane4.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-offsetPlane4.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve10.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve10.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve10.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve10.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve11.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve11.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve11.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve11.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve12.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve12.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve12.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve12.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve3.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve3.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve3.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve3.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve4.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve4.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve4.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve4.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve5.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve5.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve5.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve5.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve6.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve6.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve6.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve6.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve7.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve7.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve7.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve7.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve8.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve8.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve8.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve8.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-revolve9.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve9.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-revolve9.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-revolve9.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_circle0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-circle0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_circle0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-circle0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_circle1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-circle1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_circle1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-circle1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d3.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d3.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d3.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d3.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d4.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d4.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-mirror2d4.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-sketch-mirror2d4.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-chamfer0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-chamfer0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-chamfer0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-chamfer0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-chamfer1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-chamfer1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-chamfer1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-chamfer1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-fillet0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-fillet0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-fillet0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-fillet0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-fillet1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-fillet1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-fillet1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-fillet1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_Solid0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_Solid0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-hollow2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell1.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell2.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell2.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell2.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell2.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell3.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell3.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell3.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell3.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell4.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell4.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell4.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell4.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell5.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell5.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell5.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell5.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell6.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell6.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-shell6.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-solid-shell6.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-units-toDegrees0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-units-toDegrees0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-units-toDegrees0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-units-toDegrees0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-units-toRadians0.png b/rust/kcl-lib/tests/outputs/serial_test_example_fn_std-units-toRadians0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-units-toRadians0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_fn_std-units-toRadians0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_cm0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_cm0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_cm0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_ft0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_ft0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_ft0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_inches0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_inches0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_inches0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_m0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_m0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_m0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_mm0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_mm0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_mm0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_from_yd0.png b/rust/kcl-lib/tests/outputs/serial_test_example_from_yd0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_from_yd0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_get_edge0.png b/rust/kcl-lib/tests/outputs/serial_test_example_get_edge0.png deleted file mode 100644 index 314ce69ad..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_get_edge0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_get_extrude_wall_transform0.png b/rust/kcl-lib/tests/outputs/serial_test_example_get_extrude_wall_transform0.png deleted file mode 100644 index ba35d22dc..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_get_extrude_wall_transform0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_hole0.png b/rust/kcl-lib/tests/outputs/serial_test_example_hole0.png deleted file mode 100644 index 29c490844..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_hole0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_hole1.png b/rust/kcl-lib/tests/outputs/serial_test_example_hole1.png deleted file mode 100644 index 399c5e7c4..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_hole1.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import0.png b/rust/kcl-lib/tests/outputs/serial_test_example_import0.png deleted file mode 100644 index c38b6868d..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import1.png b/rust/kcl-lib/tests/outputs/serial_test_example_import1.png deleted file mode 100644 index 74b7216c1..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import1.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import2.png b/rust/kcl-lib/tests/outputs/serial_test_example_import2.png deleted file mode 100644 index 9a8ab9c3c..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import2.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import3.png b/rust/kcl-lib/tests/outputs/serial_test_example_import3.png deleted file mode 100644 index fdb439990..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import3.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import4.png b/rust/kcl-lib/tests/outputs/serial_test_example_import4.png deleted file mode 100644 index 987fba8e6..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import4.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_import5.png b/rust/kcl-lib/tests/outputs/serial_test_example_import5.png deleted file mode 100644 index 4e87e466c..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_import5.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_int0.png b/rust/kcl-lib/tests/outputs/serial_test_example_int0.png deleted file mode 100644 index c566903b3..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_int0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_line1.png b/rust/kcl-lib/tests/outputs/serial_test_example_line1.png deleted file mode 100644 index 77183632e..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_line1.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_line_to0.png b/rust/kcl-lib/tests/outputs/serial_test_example_line_to0.png deleted file mode 100644 index b7311cc65..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_line_to0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_pi0.png b/rust/kcl-lib/tests/outputs/serial_test_example_pi0.png deleted file mode 100644 index 971c03c9d..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_pi0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at0.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at0.png deleted file mode 100644 index a7cbc75e1..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at1.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at1.png deleted file mode 100644 index d6e57761f..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at1.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at2.png b/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at2.png deleted file mode 100644 index 6362e805d..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_start_profile_at2.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-rem0.png b/rust/kcl-lib/tests/outputs/serial_test_example_std-math-rem0.png deleted file mode 100644 index 6148ae432..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_std-math-rem0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle0.png b/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle0.png deleted file mode 100644 index 5bd912447..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle1.png b/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle1.png deleted file mode 100644 index b085a4fc5..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_std-sketch-circle1.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_tau0.png b/rust/kcl-lib/tests/outputs/serial_test_example_tau0.png deleted file mode 100644 index de171cb67..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_tau0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_Sketch0.png b/rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Sketch0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_Sketch0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Sketch0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_Solid1.png b/rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Sketch1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_Solid1.png rename to rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Sketch1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow0.png b/rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Solid0.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_std-solid-hollow0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Solid0.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_assert_equal0.png b/rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Solid1.png similarity index 100% rename from rust/kcl-lib/tests/outputs/serial_test_example_assert_equal0.png rename to rust/kcl-lib/tests/outputs/serial_test_example_ty_std-types-Solid1.png diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_x_line_to0.png b/rust/kcl-lib/tests/outputs/serial_test_example_x_line_to0.png deleted file mode 100644 index 0494b56e1..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_x_line_to0.png and /dev/null differ diff --git a/rust/kcl-lib/tests/outputs/serial_test_example_y_line_to0.png b/rust/kcl-lib/tests/outputs/serial_test_example_y_line_to0.png deleted file mode 100644 index 9282b8117..000000000 Binary files a/rust/kcl-lib/tests/outputs/serial_test_example_y_line_to0.png and /dev/null differ