2025-05-02 03:56:27 +12:00
|
|
|
---
|
2025-05-08 08:26:56 +12:00
|
|
|
title: "Settings"
|
2025-05-11 19:32:33 +12:00
|
|
|
excerpt: "Documentation of the KCL language for the Zoo Design Studio."
|
2025-05-02 03:56:27 +12:00
|
|
|
layout: manual
|
|
|
|
---
|
|
|
|
|
|
|
|
# KCL Settings
|
|
|
|
|
|
|
|
There are three levels of settings available in Zoo Design Studio:
|
|
|
|
|
2025-05-08 16:35:11 +12:00
|
|
|
1. [User Settings](/docs/kcl-lang/settings/user): Global settings that apply to all projects, stored in `user.toml`
|
|
|
|
2. [Project Settings](/docs/kcl-lang/settings/project): Settings specific to a project, stored in `project.toml`
|
2025-05-02 03:56:27 +12:00
|
|
|
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:
|
|
|
|
|
2025-05-08 16:35:11 +12:00
|
|
|
* **User Settings**: `user.toml` - See [complete documentation](/docs/kcl-lang/settings/user)
|
|
|
|
* **Project Settings**: `project.toml` - See [complete documentation](/docs/kcl-lang/settings/project)
|
2025-05-02 03:56:27 +12:00
|
|
|
|
|
|
|
## 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).
|