npm install -g pnpm
pnpm install
This will install all of the npm dependencies of all projects in the
repo. Do this whenever you git pull
or your workspace is freshly
cleaned/cloned.
Note that pnpm install
must be done before building in VS Code or
using the command line.
npx playwright install
If you are not at the root of the repo you have to use -w
option to specify you want to run the command for the workspace. pnpm -w <command>
.
pnpm build
This will build all projects in the correct dependency order.
pnpm build
This will build all projects that have changed since the last pnpm build
in
dependency order.
cd packages/<project>
pnpm build
pnpm test
Starting this command will rebuild the typescript files on save.
pnpm watch
Sometimes there are ghost files left in the dist folder (common when renaming or deleting a TypeScript file), running this will get a clean state.
pnpm clean
cd packages/<project>
pnpm test
Tests sometimes log extra info using logVerboseTestOutput
To see
this output on the command line, set environment variable
TYPESPEC_VERBOSE_TEST_OUTPUT=true.
pnpm format
PR validation enforces code formatting style rules for the repo. This command will reformat code automatically so that it passes.
You can also check if your code is formatted correctly without
reformatting anything using pnpm check-format
.
See also below for having this happen automatically in VS Code whenever you save.
For all packages except the compiler this will be done automatically as part of each package build
script.
If you want to regenerate decorator signatures without a full build you can run:
pnpm gen-extern-signature
For the compiler you will need to run it manually or run the whole workspace build. This is because for the tool to run it needs the compiler to build first.
pnpm change
pnpm lint
PR validation enforces linting rules for the repo. This command will run the linter on all packages.
pnpm regen-samples
PR validation runs OpenAPI emitters on samples and compares them to known, reviewed, checked-in versions. If your PR would change the generated output, run this command to regenerate any samples and check those files in with your PR. Carefully review whether the changes are intentional.
pnpm regen-docs
PR validation will ensure that reference docs are up to date.
- Vitest Test Explorer:
Run tests from the IDE. (Version
0.2.43
is bugged on OSX, use0.2.42
instead) - Prettier: Automatically keep code formatted correctly on save.
- ESLint: Show eslint errors in warnings in UI.
- Code Spell Checker: Show spell check errors in document.
Always open the root of the repo as the workspace. Things are setup to allow easy development across packages rather than opening one package at a time in the IDE.
- File -> Open Workspace, select root folder where the TypeSpec repo was cloned
- Or run
code /path/to/repo/root
on the command line
- Terminal -> Run Build Task (
Ctrl+Shift+B
)
This will setup a an incremental watching build for the whole repo. From there on, your changes will be built whenever you save.
Problems will be reported in the Problems pane automatically and the Terminal pane will have three parallel watch tasks running:
watch-source
: tsc process that recompile on TypeScript changeswatch-spec
: process that regenerates spec.html when spec.emu.html changeswatch-tmlanguage
: process that regenerates typespec.tmlanguage when tmlanguage.ts changes
# Run all the tests
pnpm test
# Run in a specific package tests in watch mode
npm run test:watch
There are several "Run and Debug" tasks set up. Click on the Run and Debug icon on the sidebar, pick one from its down, and press F5 to debug the last one you chose.
- VS Code Extension: This will run and debug an experimental instance of VS Code with the TypeSpec extension for VS Code and TypeSpec language server running live with any of your changes. It will attach to both the VS Code client process and the language server process automatically.
- Compile Scratch: Use this to debug compiling
packages/samples/scratch/*.tsp
. The TypeSpec source code in that folder is excluded from source control by design. Create TypeSpec files there to experiment and debug how the compiler reacts. - Compile Scratch (nostdlib): Same as above, but skips parsing and evaluating the TypeSpec standard library. Sometimes it's easier to
- Attach to Default Port: Use this to attach to a manually run
node --debug
command. - Attach to Language Server: Use this to attach to the language server process of an already running client process. Useful if you want to debug the language server in VS Code while debugging the VS client in VS.
- Regenerate .tmlanguage: This runs the code that produces the typespec.tmlanguage file that provides syntax highlighting of TypeSpec in VS and VS Code. Select this to debug its build process.
Install Visual Studio 17.0 or later. It is not currently possible to build the VS extension without it, and of course you'll need Visual Studio to run and debug the Visual Studio extension.
See the command line build steps above. If you have VS installed, the VS extension will be included in your command line full repo builds automatically.
If you do not have VS installed the command line build steps above will simply skip building the VS extension and only build the VS Code extension.
- Open packages/typespec-vs/Microsoft.TypeSpec.VisualStudio.sln in Visual Studio
- Build -> Build solution (
Ctrl+Shift+B
)
Unlike TypeScript in VS Code above, this is not a watching build, but it is relatively fast to run. Press Ctrl+Shift+B again to build any changes after you make them.
- Click on the play icon in the toolbar or press
F5
This will run and debug an experimental instance of VS with a version of the TypeSpec extension for VS Code running live with any of your changes to the extension or the TypeSpec language server.
The VS debugger will attach only to the VS client process. Use "Attach to Language Server" described above to debug the language server in VS Code.
pnpm dogfood
This will globally install the @typespec/compiler package, putting your
build of typespec
on PATH, and install the VS Code extension if VS Code
is installed.
Note the important difference between this and the steps to run and
debug the VS Code extension above: the dogfood
command installs the
TypeSpec extension with your changes in regular, non-experimental instance
of VS Code, meaning you will have it always, and not only when running
the debug steps above. This is exactly like using tsp vscode install
,
only instead of downloading the latest release, it uses a build with your
changes applied.
There is no automatic dogfood
process for installing the VS
extension non-experimentally, but if you build the typespec-vs project from
the command line following the steps above, or build its Release
configuration in Visual Studio, then you can install it by
double-clicking on packages/typespec-vs/Microsoft.TypeSpec.VisualStudio.vsix
that gets produced.
For contributors of the repo the build will trigger automatically but for other's forks it will need a manual trigger from a contributor. As a contributor you can run the following command to trigger the build and create a TypeSpec playground link for this PR.
/azp run TypeSpec Pull Request Try It
Trigger a workflow that will format the code, commit and push.
/typespeceng format
Go to packages/website
and run the command:
npm start
The website on github.io should be published when releasing new packages.
To release:
- Go to https://github.com/microsoft/typespec/actions/workflows/website-gh-pages.yml
- Click the
Run workflow
dropdown and select themain
branch.
The various language emitters will live in the in the repo under the following directory structure
packages/{protocol}-{client|server}-{language}
- Contains the@typespec/{protocol}-{client|server}-{language}
package which is intended to be consumed by customers in their tsconfig.yaml file.packages/{protocol}-{client|server}-{language}-generator
- Contains the@typespec/{protocol}-{client|server}-{language}-generator
package which is the backend implementation of for a given emitter and usually contains code languages such as .NET, Python, or Java. This package is only intended to be used as a dependency of the root emitter package.packages/{protocol}-{client|server}-{language}-generator\**
- This directory will contain whatever is needed to build the backend emitter code generator. It will contain whatever folder structure is needed to build that specific native code. It will also contain an isolated ci.yml file which will be the build pipeline for this package.
There is a goal to be able to ship these emitter packages independent from the rest of the packages in this repo as such they by default be excluded from the root pnpm workspace. Any npm package work will be isolated to those directories with a goal of eventually moving to a consistent model so that we can both work in isolation as well as work as a E2E.
For language specific contributing information look for the contributing.md file in that specific lanague emitter folder.