diff options
| author | L Lllvvuu <git@llllvvuu.dev> | 2023-09-19 21:41:07 -0700 | 
|---|---|---|
| committer | Lewis Russell <me@lewisr.dev> | 2023-09-22 12:51:51 +0100 | 
| commit | e353c869cea4541d00d627ec82724d3f247225a3 (patch) | |
| tree | 09f7fb19e9ad60f5dffbdd5fa33b3e9672890b48 /runtime/syntax/javascript.vim | |
| parent | b7763d7f6b7fdcabe06658c664457df8bc147563 (diff) | |
| download | rneovim-e353c869cea4541d00d627ec82724d3f247225a3.tar.gz rneovim-e353c869cea4541d00d627ec82724d3f247225a3.tar.bz2 rneovim-e353c869cea4541d00d627ec82724d3f247225a3.zip | |
fix(languagetree): don't treat unparsed nodes as occupying full range
This is incorrect in the following scenario:
1. The language tree is Lua > Vim > Lua.
2. An edit simultaneously wipes out the `_regions` of all nodes, while
   taking the Vim injection off-screen.
3. The Vim injection is not re-parsed, so the child Lua `_regions` is
   still `nil`.
4. The child Lua is assumed, incorrectly, to occupy the whole document.
5. This causes the injections to be parsed again, resulting in Lua > Vim
   > Lua > Vim.
6. Now, by the same process, Vim ends up with its range assumed over the
   whole document. Now the parse is broken and results in broken
   highlighting and poor performance.
It should be fine to instead treat an unparsed node as occupying
nothing (i.e. effectively non-existent). Since, either:
- The parent was just parsed, hence defining `_regions`
- The parent was not just parsed, in which case this node doesn't need
  to be parsed either.
Also, the name `has_regions` is confusing; it seems to simply
mean the opposite of "root" or "full_document". However, this PR does
not touch it.
Diffstat (limited to 'runtime/syntax/javascript.vim')
0 files changed, 0 insertions, 0 deletions
