Skip to content
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

Order of multiple TextDocumentContentChangeEvent #279

Closed
wants to merge 2 commits into from

Conversation

ljw1004
Copy link
Contributor

@ljw1004 ljw1004 commented Aug 4, 2017

What should happen if textDocument/didChange contains multiple contentChanges? This will happen if (1) an editor client supports multiple cursors, and (2) a language server supports incremental edits.

(Contrast with TextEdit, where in cases where the LSP server sends multiple TextEdits to the client, the client is expected to sort them in reverse order).

I think that for uniformity with TextEdit, we should say that whoever receives an array of edits (be they TextEdits or TextDocumentContentChangeEvents) is responsible for sorting them and applying them in reverse order. And whoever sends them is responsible for ensuring that they're non-overlapping.

Of course, most LSP servers don't yet do this. Most of them at the moment seem to just apply the array of edits blindly in the order in which they were received.

I think therefore, in our transitional period up until LSP servers start doing that, the clients should (for convenience and compatibility) do the sorting themselves. Atom editor already does, and VSCode editor should follow suite.
atom/atom-languageclient#72

ljw1004 added 2 commits August 4, 2017 10:46
What should happen if `textDocument/didChange` contains multiple `contentChanges`? This will happen if (1) an editor client supports multiple cursors, and (2) a language server supports incremental edits.

(Contrast with `TextEdit`, where in cases where the LSP server sends multiple `TextEdit`s to the client, the client is expected to sort them in reverse order).

I think that for uniformity with `TextEdit`, we should say that whoever receives an array of edits (be they `TextEdit`s or `TextDocumentContentChangeEvent`s) is responsible for sorting them and applying them in reverse order. And whoever sends them is responsible for ensuring that they're non-overlapping.

Of course, most LSP servers don't yet do this. Most of them at the moment seem to just apply the array of edits blindly in the order in which they were received.

I think therefore, in our transitional period up until LSP servers start doing that, the clients should (for convenience and compatibility) do the sorting themselves. Atom editor already does, and VSCode editor should follow suite.
atom/atom-languageclient#72
@@ -1496,6 +1496,8 @@ _Registration Options_: `TextDocumentRegistrationOptions`

The document change notification is sent from the client to the server to signal changes to a text document. In 2.0 the shape of the params has changed to include proper version numbers and language ids.

Similarly to `TextEdit`, if multiple `contentChange`s are applied to a text document, all text edits describe changes made to the initial document version. Execution-wise text edits should be applied from the bottom to the top of the text document. Overlapping text edits are not supported.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Based on fcb32f9, it seems like the claim that the changes are for the initial version of the document is incorrect?

Copy link
Contributor

@rcjsuen rcjsuen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added sorting in my language server but perhaps clients are supposed to ensure that the changes are sent in the right order?

@dbaeumer
Copy link
Member

dbaeumer commented Sep 8, 2017

No this is not correct and I clarified this at least for document changes in the protocol. The behavior is as follows to make it as easy as possible to consume changes or create text edits. The burden of doing the right thing is basically pushed to the too (e.g. client). The behavior is as follows:

  • content changes in document events: each change in the array describes a state change of the document. If there are two content changes c1 and c2 and the document was in state S10 then c1 moves the document to S11 and c2 to S12. So the changes should be applied in the order in which they are sent.

  • text edits generated on the server and send to the client move a document from one state to the next. So if a text document edit contains 2 text edits and they are applied to a document of state S10 they move the document to S11. So there is no need to order the edits. All that must be ensure is that the edits aren't overlapping.

I clarified the documentation for this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants