An extremely fast Python type checker and language server, written in Rust.
Find a file
David Peter 35e23aa481
Some checks are pending
CI / python package (push) Waiting to run
CI / pre-commit (push) Waiting to run
CI / Check generated files unedited (push) Waiting to run
CI / mkdocs (push) Waiting to run
Bump version to 0.0.1-alpha.33 (#1829)
2025-12-09 23:16:30 +01:00
.github Use our org-wide Renovate preset (#1726) 2025-12-02 13:08:37 -05:00
assets/badge ty badge (#897) 2025-07-28 20:35:08 +01:00
docs Stabilize auto-import (#1810) 2025-12-09 09:40:50 -05:00
python/ty add py.typed (#276) 2025-05-08 09:00:10 -07:00
ruff@a9be810c38 Bump version to 0.0.1-alpha.33 (#1829) 2025-12-09 23:16:30 +01:00
scripts Use npm ci --ignore-scripts instead of npm install (#1722) 2025-12-02 10:14:55 -05:00
.editorconfig Move TOML indent size config (#251) 2025-05-07 18:13:32 +00:00
.gitattributes [CI] Add check for changes in autogenerated files (#415) 2025-05-16 08:05:04 +02:00
.gitignore Initial commit 2025-05-02 11:37:31 -05:00
.gitmodules Add ruff as a submodule 2025-05-02 11:41:08 -05:00
.markdownlint.yaml Update pre-commit dependencies (#809) 2025-07-11 07:59:44 +00:00
.pre-commit-config.yaml Update pre-commit dependencies (#1694) 2025-12-01 00:40:55 +00:00
.python-version Commit the uv.lock and .python-version files (#61) 2025-05-06 09:45:39 -05:00
_typos.toml Bump version to 0.0.1-alpha.21 (#1205) 2025-09-19 08:42:23 +02:00
CHANGELOG.md Bump version to 0.0.1-alpha.33 (#1829) 2025-12-09 23:16:30 +01:00
CODE_OF_CONDUCT.md Update email in code of conduct (#55) 2025-05-06 08:32:29 +02:00
CONTRIBUTING.md remove the suggestion that updating ty-vscode is optional (#1639) 2025-11-25 17:13:51 -08:00
dist-workspace.toml Bump version to 0.0.1-alpha.33 (#1829) 2025-12-09 23:16:30 +01:00
Dockerfile Enable Docker build workflow (#38) 2025-05-05 15:48:32 -05:00
LICENSE Drop -MIT suffix from license file (#26) 2025-05-05 08:31:14 -05:00
mkdocs.insiders.yml Copy basic template and styling for documentation from uv (#729) 2025-07-02 09:40:49 -05:00
mkdocs.public.yml Copy basic template and styling for documentation from uv (#729) 2025-07-02 09:40:49 -05:00
mkdocs.template.yml Sync env.md script in release pipeline (#782) 2025-07-08 11:34:51 -04:00
pyproject.toml Bump version to 0.0.1-alpha.33 (#1829) 2025-12-09 23:16:30 +01:00
README.md Small documentation improvements (#1606) 2025-11-21 10:24:10 +01:00
SECURITY.md Add SECURITY.md (#23) 2025-05-05 15:18:41 +02:00
uv.lock Bump version to 0.0.1-alpha.33 (#1829) 2025-12-09 23:16:30 +01:00

ty

ty PyPI Discord

An extremely fast Python type checker and language server, written in Rust.

Getting started

Try out the online playground, or run ty with uvx to get started quickly:

uvx ty

For other ways to install ty, see the installation documentation.

If you do not provide a subcommand, ty will list available commands — for detailed information about command-line options, see the CLI reference.

Use the check command to run the type checker:

uvx ty check

ty will run on all Python files in the working directory and or subdirectories. If used from a project, ty will run on all Python files in the project (starting in the directory with the pyproject.toml)

You can also provide specific paths to check:

uvx ty check example.py

When type checking, ty will find installed packages in the active virtual environment (via VIRTUAL_ENV) or discover a virtual environment named .venv in the project root or working directory. It will not find packages in non-virtual environments without specifying the target path with --python. See the module discovery documentation for details.

Learning more

To learn more about using ty, see the documentation.

Getting involved

If you have questions or want to report a bug, please open an issue in this repository.

Development of this project takes place in the Ruff repository at this time. Please open pull requests there for changes to anything in the ruff submodule (which includes all of the Rust source code).

See the contributing guide for more details.

License

ty is licensed under the MIT license (LICENSE or https://opensource.org/licenses/MIT).

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in ty by you, as defined in the MIT license, shall be licensed as above, without any additional terms or conditions.