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/ac1ce/ac1ce0d8d8a460350015740809ab37c658b59d94" alt=""
data:image/s3,"s3://crabby-images/1309d/1309d848f295eb3f10e17f62182c0f6d9adedfe9" 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/3921a/3921a58dce6701c9201a803df5cdb5a491c14574" alt=""
data:image/s3,"s3://crabby-images/b5061/b5061b5d5fd665709a4d48e5bcae3fd0dad295d4" 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/3921a/3921a58dce6701c9201a803df5cdb5a491c14574" alt=""
data:image/s3,"s3://crabby-images/b5061/b5061b5d5fd665709a4d48e5bcae3fd0dad295d4" alt=""
Extension installation
See documentation on how to install editor extensions.
Learn more →
data:image/s3,"s3://crabby-images/07250/072502ec1e904f1089405a87298f30e85c6c3ffd" alt=""
data:image/s3,"s3://crabby-images/36b47/36b47d65ccb16fbae5dd0edf1ac51a47b788bbeb" 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/20348/2034847d50d5ffd5a6aa3a57fc78d0269064a5ab" alt=""
data:image/s3,"s3://crabby-images/dbcb1/dbcb1c7207e991f2f6fb475bd05e8b8192c5ead1" 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.