Syntax highlighting, autocomplete, formatting, and more
TypeSpec is supported by a variety of readily available tools, designed to boost your productivity right from the start.
Get started data:image/s3,"s3://crabby-images/79957/799575cd3e34f060819da02f2cb4722d357c8c46" alt=""
data:image/s3,"s3://crabby-images/157a1/157a1e90aceb30cdf7c319c0248c99ad6bdd5de3" alt=""
Style consistency
Built-in formatter
TypeSpec provides an opinionated formatter that enables you to enforce a consistent style in your codebase.
data:image/s3,"s3://crabby-images/f4936/f49366e46989fade217b52cb2cbb66d7f625e557" alt=""
data:image/s3,"s3://crabby-images/e08f4/e08f4ff700fe001691bb6d698def8dbfde7e7b16" alt=""
Formatter usage
See documentation on how to use the formatter.
Learn more →
Unformatted
import "@typespec/http";
using TypeSpec.Http;
@service({ title: "Accounting firm" }) namespace MyOrg.Accounting;
model Account { id: string; name: string; balance: decimal128;}
interface Accounts {
@route(":open") open(account: Account): void; @route(":close") close(id: string): void;
}
Formatted
import "@typespec/http";
using TypeSpec.Http;
@service({ title: "Accounting firm",})namespace MyOrg.Accounting;
model Account { id: string; name: string; balance: decimal128;}
interface Accounts { @route(":open") open(account: Account): void; @route(":close") close(id: string): void;}
Warning
Warning and errors
Errors and warnings in your spec are reported as you type.
data:image/s3,"s3://crabby-images/f4936/f49366e46989fade217b52cb2cbb66d7f625e557" alt=""
data:image/s3,"s3://crabby-images/e08f4/e08f4ff700fe001691bb6d698def8dbfde7e7b16" alt=""
Extension installation
See documentation on how to install editor extensions.
Learn more →
data:image/s3,"s3://crabby-images/d9443/d94435ee77bcf2f061148470f5f862601d201f74" alt=""
data:image/s3,"s3://crabby-images/ed8ee/ed8ee7afb7607813d6cf299758d91ddf2857709d" alt=""
Intellisense
Autocomplete and more
IntelliSense shows you intelligent code completion, hover information, and signature help so that you can quickly and efficiency write correct code.
data:image/s3,"s3://crabby-images/de200/de2009ed106ce9acf8dcccffedbb0734db403697" alt=""
data:image/s3,"s3://crabby-images/0077c/0077cbabfa6ad8329b744051d423f2ef831f1a27" alt=""
Refactor
Bulk renaming
One of the simplest forms of refactoring is renaming a reference. Rename an identifier and see all of its references updated across your TypeSpec project.