-
Notifications
You must be signed in to change notification settings - Fork 807
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to abort during initialize? #246
Comments
Digging further into the code, I've come to a different conclusion for LSP servers that don't depend upon dynamic registration:
Why should it respond to the Initialize request promptly?
|
@ljw1004 I agree with your conclusion of sending the initialize response as soon as possible. What we could think about having a Language Server status item and add this to the LSP so that the server can let the client know about its status. This could even show progress until the initialization is done. However the user experience would still not be very good here since for example code compete would present and empty list (or nothing) without letting the user know that the server is not ready yet. |
Another option: instead of a Language Server status item, it could instead be handled with a ResponseError - maybe a new code |
How can the client abort/cancel/shutdown during initialization?
Our language service sometimes takes ~5 minutes to start up, during which time it's unable to successfully handle any requests or notifications. Because if this I decided to make the "initialize" method only respond once it has finished starting up [see at end for explanation why].
But how to handle the case when the client wants to abandon the initialization part way through?
I imagine the client could send a
$/cancelRequest
notification to cancel the initialize request. This is allowed by JsonRpc, but LSP says the only notification allowed before the initialize request isexit
, and other notifications should be dropped, and the client must not send additional notifications until the server has responded to initialize.I imagine the client could send a
shutdown
request. The LSP spec says that the server must respond with code -32002 if this (or any) request comes before the initialize request, and says the client must not send any requests until after the initialize response.I imagine the client could send a
exit
notification. This would work in theory according to the LSP spec. But the way LanguageClient is implemented, when you callstop()
, it first sends ashutdown
request, and only if that succeeds will it send theexit
notification. So this plan won't work well. Indeed, if LanguageClient is asked to stop() in the middle of initialization, it will transition into theStopping
state and not dispose of anything or clean anything up.https://github.com/Microsoft/vscode-languageserver-node/blob/master/client/src/client.ts#L1530
Why can't the server respond immediately to the initialize request? ... If it responded to initialize immediately, then the client would merrily send loads of "didOpen/didChange" notifications, and the server would have no way of indicating that it wasn't ready for them, so it would have to queue every single such notification up until such time as it could handle them. That'd be crummy. Dynamic registration might notionally work, but I don't think it's good to rely on clients supporting it.
The text was updated successfully, but these errors were encountered: