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

refactor(lsp): batch updates with a zipper #1004

Merged
merged 1 commit into from
Jan 19, 2023

Conversation

rgrinberg
Copy link
Member

@rgrinberg rgrinberg commented Jan 10, 2023

Neovim is particularly guilty of sending a ton of change notifications - essentially one for every character change. The end result is that editing large documents slows the lsp server to a crawl. The issue is somewhat mitigated by debouncing, but the delays that introduces are rather annoying.

We fix the issue by batching the updates in a single notification. We move along the WIP document using a zipper to insert the edits. In the end, we flatten everything into a string without allocating large intermediate strings. Insertions near the zipper location are fast.

@copy no more debouncing should be necessary in neovim.

@rgrinberg rgrinberg requested a review from ulugbekna January 10, 2023 01:10
@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch 2 times, most recently from 8f6bf23 to cfa4a41 Compare January 10, 2023 03:07
@rgrinberg rgrinberg added this to the 1.15.1 milestone Jan 10, 2023
@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch 3 times, most recently from b606c07 to c78d0f2 Compare January 10, 2023 15:38
@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch 4 times, most recently from 76ed9c7 to 2decda8 Compare January 11, 2023 22:14
@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch from 2decda8 to af0b870 Compare January 12, 2023 00:22
@rgrinberg
Copy link
Member Author

@ulugbekna in addition to code review, it would be nice if you could test this in day to day usage. I'm doing so already, but I'm on neovim.

@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch from af0b870 to 8400ad6 Compare January 14, 2023 00:40
@ulugbekna
Copy link
Collaborator

ulugbekna commented Jan 16, 2023 via email

@rgrinberg
Copy link
Member Author

rgrinberg commented Jan 16, 2023 via email

@rgrinberg rgrinberg removed this from the 1.15.1 milestone Jan 17, 2023
@ulugbekna ulugbekna force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch from 8400ad6 to 0759a17 Compare January 19, 2023 12:00
Copy link
Collaborator

@ulugbekna ulugbekna left a comment

Choose a reason for hiding this comment

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

I rebased and made a couple of small changes. Hope that's okay. Let me know if not.

Looks good, great work

lsp/src/string_zipper.ml Outdated Show resolved Hide resolved
lsp/src/string_zipper.ml Outdated Show resolved Hide resolved
lsp/src/position.ml Outdated Show resolved Hide resolved
<!-- ps-id: f22a5053-5768-454b-9007-8e8993f80f0b -->
@rgrinberg rgrinberg force-pushed the ps/rr/refactor_lsp___batch_updates_with_a_zipper branch from 0759a17 to e05e120 Compare January 19, 2023 17:40
@rgrinberg rgrinberg merged commit c8c1096 into master Jan 19, 2023
rgrinberg added a commit to rgrinberg/opam-repository that referenced this pull request Jun 18, 2023
CHANGES:

## Fixes

- Disable code lens by default. The support can be re-enabled by explicitly
  setting it in the configuration. (ocaml/ocaml-lsp#1134)

- Fix initilization of `ocamlformat-rpc` in some edge cases when ocamlformat is
  initialized concurrently (ocaml/ocaml-lsp#1132)

- Kill unnecessary `$ dune ocaml-merlin` with SIGTERM rather than SIGKILL
  (ocaml/ocaml-lsp#1124)

- Refactor comment parsing to use `odoc-parser` and `cmarkit` instead of
  `octavius` and `omd` (ocaml/ocaml-lsp#1088)

  This allows users who migrated to omd 2.X to install ocaml-lsp-server in the
  same opam switch.

  We also slightly improved markdown generation support and fixed a couple in
  the generation of inline heading and module types.

- Allow opening documents that were already open. This is a workaround for
  neovim's lsp client (ocaml/ocaml-lsp#1067)

- Disable type annotation for functions (ocaml/ocaml-lsp#1054)

- Respect codeActionLiteralSupport capability (ocaml/ocaml-lsp#1046)

- Fix a document syncing issue when utf-16 is the position encoding (ocaml/ocaml-lsp#1004)

- Disable "Type-annotate" action for code that is already annotated.
  ([ocaml/ocaml-lsp#1037](ocaml/ocaml-lsp#1037)), fixes
  [ocaml/ocaml-lsp#1036](ocaml/ocaml-lsp#1036)

- Fix semantic highlighting of long identifiers when using preprocessors
  ([ocaml/ocaml-lsp#1049](ocaml/ocaml-lsp#1049), fixes
  [ocaml/ocaml-lsp#1034](ocaml/ocaml-lsp#1034))

- Fix the type of DocumentSelector in cram document registration (ocaml/ocaml-lsp#1068)

- Accept the `--clientProcessId` command line argument. (ocaml/ocaml-lsp#1074)

- Accept `--port` as a synonym for `--socket`. (ocaml/ocaml-lsp#1075)

- Fix connecting to dune rpc on Windows. (ocaml/ocaml-lsp#1080)

## Features

- Add "Remove type annotation" code action. (ocaml/ocaml-lsp#1039)

- Support settings through `didChangeConfiguration` notification (ocaml/ocaml-lsp#1103)

- Add "Extract local" and "Extract function" code actions. (ocaml/ocaml-lsp#870)

- Depend directly on `merlin-lib` 4.9 (ocaml/ocaml-lsp#1070)
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.

ocaml-lsp reports bogus erros on large files when editor autosaving is enabled
2 participants