blob: 9d3b1cea9a10fbf27a5542b655178ca38bac9408 [file] [log] [blame] [view]
# Starting the server
The analysis server is run by executing the `dart language_server` command,
which is implemented in the `dartdev` package. That command invokes the `main`
function in `bin/server.dart`. The only thing `main` does is to create an
instance of `ServerStarter` and pass the command-line arguments to it.
The starter interprets the command-line arguments in order to create and
initialize an `AnalysisServer`.
Even though the command-line tools don't use it that way, the analysis server is
designed to be a long-lived process.
The server communicates with a single client (the process that started the
server) using one of two wire protocols: a legacy protocol, which is used to
support IntelliJ and Android Studio, and LSP (the
[Language Server Protocol](https://microsoft.github.io/language-server-protocol)
from Microsoft), which is used to support VS Code and several other IDEs and
editors. The protocol is selected at start-up via command-line arguments.
To learn more about how the server communicates with the client, you can read
about either [LSP](lsp.md) or the [legacy protocol](legacy.md).
Based on the selected protocol, the starter creates an instance of one of the
two concrete subclasses of `AnalysisServer`, either `LspAnalysisServer` or
`LegacyAnalysisServer`, and initializes it.
To learn how the server implements support for the protocols, read about the
[request handlers](handlers.md).