-
Notifications
You must be signed in to change notification settings - Fork 881
Description
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.
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.