-
Notifications
You must be signed in to change notification settings - Fork 12.6k
Standalone Server (tsserver)
The TypeScript standalone server (aka tsserver
) is a node executable that encapsulates the TypeScript compiler and language services, and exposes them through a JSON protocol. tsserver
is well suited for editors and IDE support.
The server communication protocol is defined in protocol.d.ts.
The executable can be found in lib folder under the typescript package.
npm install --save typescript
ls node_modules\lib\tsserver.js
tsserver
listens on stdin
and writes messages back to stdout
.
Requests are JSON following the protocol definition. Here is an example request to open a file c:/DefinitelyTyped/gregorian-calendar/index.d.ts
:
{"seq":1,"type":"quickinfo","command":"open","arguments":{"file":"c:/DefinitelyTyped/gregorian-calendar/index.d.ts"}}
Responses are augmented JSON format. the Message stars with a header with the content length followed by a line separator (\r\n
) followed by the response body as a JSON string:
Here is an example of a response for a quickinfo
command:
Content-Length: 116
{"seq":0,"type":"response","command":"quickinfo","request_seq":2,"success":false,"message":"No content available."}
Similarly events have the same format as a response.
Here is an example event for error message:
Content-Length: 261
{"seq":0,"type":"event","event":"semanticDiag","body":{"file":"c:/DefinitelyTyped/gregorian-calendar/index.d.ts","diagnostics":[{"start":{"line":264,"offset":44},"end":{"line":264,"offset":50},"text":"Binding element 'Object' implicitly has an 'any' type."}]}}
tsserver
supports a set of commands. The full list of commands supported by the server can be found under ts.server.protocol.CommandTypes.
Each command is associated with a request and a response interface. For instance command "completions"
corresponds to request interface CompletionsRequest
, and response interface defined in CompletionsResponse
.
TypeScript-Sublime-Plugin is a Sublime text plugin written in Python that uses tsserver
.
VS Code's TypeScript support is implemented in TypeScript using tsserver
.
Tide is an elisp implementation for emacs plugin using tsserver
tsserver
logging is configured through the TSS_LOG
environment variable.
TSS_LOG
can have the following format:
[-level <terse | normal | requestTime | verbose>]
[-traceToConsole <true | false>]
[-logToFile <true | false>]
[-file <log file path>]
Note: file
defaults to __dirname\.log<PID>
if not specified
Example: set TSS_LOG=-level verbose -file c:\tmp\tsserver.log
tsserver
on startup will try to load module ./cancellationToken
from the containing directory. This module should export a factory function that accepts a list of command line arguments and returns HostCancellationToken. tsserver will use this token to check if in-flight operation should be cancelled.
NOTE: This token will be used for all operations so if one operation is cancelled and cancellation was reported through the token then when another operation is started - token should be reset into the non-cancelled state.
Default implementation of the cancellation token uses presence of named pipes as a way to signal cancellation.
- before spawning the server client generates a unique name. This name is passed to the server as a
cancellationPipeName
command line argument. - if some operation on the client side should be cancelled - client opens a named pipe with a name generated on step 1. Nothing needs to be written in the pipe - default cancellation token will interpret the presence of named pipe as a cancellation request.
- After receiving acknowledgment from the server client closes the pipe so it can use the same pipe name for the next operation.
Option | Description |
---|---|
--cancellationPipeName |
Name of the pipe used as a request cancellation semaphore. See Cancellation for more information. |
--eventPort |
Port used for receiving events. If non is specified events are sent to stdout. |
--useSingleInferredProject |
Put all open .ts and .js files that do not have a .tsconfig file in a common project |
News
Debugging TypeScript
- Performance
- Performance-Tracing
- Debugging-Language-Service-in-VS-Code
- Getting-logs-from-TS-Server-in-VS-Code
- JavaScript-Language-Service-in-Visual-Studio
- Providing-Visual-Studio-Repro-Steps
Contributing to TypeScript
- Contributing to TypeScript
- TypeScript Design Goals
- Coding Guidelines
- Useful Links for TypeScript Issue Management
- Writing Good Design Proposals
- Compiler Repo Notes
- Deployment
Building Tools for TypeScript
- Architectural Overview
- Using the Compiler API
- Using the Language Service API
- Standalone Server (tsserver)
- TypeScript MSBuild In Depth
- Debugging Language Service in VS Code
- Writing a Language Service Plugin
- Docker Quickstart
FAQs
The Main Repo