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/2ddac/2ddac1ad2179ff4ca7f652519b2f28128b246aff" alt=""
data:image/s3,"s3://crabby-images/de748/de7489dda2d787a3d5768016f0d93b0a3f691eb2" 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/7e22b/7e22bfd28e67e6e75cc29383cc9521534573cb2e" alt=""
data:image/s3,"s3://crabby-images/f67ce/f67ceab8f6d6f0533e7dd3e37ebc275ef919069d" 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/7e22b/7e22bfd28e67e6e75cc29383cc9521534573cb2e" alt=""
data:image/s3,"s3://crabby-images/f67ce/f67ceab8f6d6f0533e7dd3e37ebc275ef919069d" alt=""
Extension installation
See documentation on how to install editor extensions.
Learn more →
data:image/s3,"s3://crabby-images/99b96/99b96a180077eb28ab5ddc36faef954df316e31e" alt=""
data:image/s3,"s3://crabby-images/8da16/8da16d14bc74b8c5ec8a77882d63d6be33d77fe6" 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/1a4f9/1a4f903b19070dc74e3cbdb4e0f7f5695815281a" alt=""
data:image/s3,"s3://crabby-images/2e88a/2e88a56d179d938cb5f7ba214bd36f629ed00874" 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.