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/b616e/b616ed53777181eaf0ae5176e75593a8487d9d34" alt=""
data:image/s3,"s3://crabby-images/7572c/7572c63ae96659f24c12ccbc26db85461b226c71" 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/e7227/e7227cbc0dda8ec209e1e7ca83157827543d81d2" alt=""
data:image/s3,"s3://crabby-images/2dcc7/2dcc71f776da1c28ab86162ec2738c594ba578fd" 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/e7227/e7227cbc0dda8ec209e1e7ca83157827543d81d2" alt=""
data:image/s3,"s3://crabby-images/2dcc7/2dcc71f776da1c28ab86162ec2738c594ba578fd" alt=""
Extension installation
See documentation on how to install editor extensions.
Learn more →
data:image/s3,"s3://crabby-images/302ce/302ce9b1f99f5e3b57a29fd2bc4c1de3749671f1" alt=""
data:image/s3,"s3://crabby-images/c0b24/c0b241e5e022e3db65884acba376607d8ac88317" 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/4991d/4991d8f285c5215f363ac6bb82278f1bc460acd8" alt=""
data:image/s3,"s3://crabby-images/d1f59/d1f59321e992401850bebfe3b355c7a96efda371" 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.