Skip to content

Commit

Permalink
Fix performance regression in Goto Symbol overlay
Browse files Browse the repository at this point in the history
  • Loading branch information
jwortmann committed Oct 28, 2023
1 parent 3b17a99 commit ce89f45
Showing 1 changed file with 13 additions and 9 deletions.
22 changes: 13 additions & 9 deletions plugin/symbols.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
import weakref
from .core.protocol import DocumentSymbol
from .core.protocol import DocumentSymbolParams
from .core.protocol import Point
from .core.protocol import Request
from .core.protocol import SymbolInformation
from .core.protocol import SymbolKind
from .core.protocol import SymbolTag
from .core.registry import LspTextCommand
from .core.sessions import print_to_status_bar
from .core.typing import Any, List, Optional, Tuple, Dict, Union, cast
from .core.views import offset_to_point
from .core.views import range_to_region
from .core.views import SublimeKind
from .core.views import SYMBOL_KINDS
Expand Down Expand Up @@ -91,17 +93,16 @@ def symbol_to_list_input_item(
details.append(detail)
if hierarchy:
details.append(hierarchy + " > " + name)
region = range_to_region(selection_range, view)
else:
item = cast(SymbolInformation, item)
container_name = item.get('containerName')
if container_name:
details.append(container_name)
region = range_to_region(item['location']['range'], view)
selection_range = item['location']['range']
deprecated = SymbolTag.Deprecated in (item.get('tags') or []) or item.get('deprecated', False)
return sublime.ListInputItem(
name,
{'kind': kind, 'region': [region.a, region.b], 'deprecated': deprecated},
{'kind': kind, 'range': selection_range, 'deprecated': deprecated},
details=" • ".join(details),
annotation=st_kind[2],
kind=st_kind
Expand Down Expand Up @@ -199,7 +200,7 @@ def handle_response_async(self, response: Union[List[DocumentSymbol], List[Symbo
items = cast(List[SymbolInformation], response)
for item in items:
self.items.append(symbol_to_list_input_item(self.view, item))
self.items.sort(key=lambda item: item.value['region'])
self.items.sort(key=lambda item: Point.from_lsp(item.value['range']['start']))
window = self.view.window()
if window:
self.cached = True
Expand Down Expand Up @@ -285,20 +286,23 @@ def list_items(self) -> Tuple[List[sublime.ListInputItem], int]:
items = [item for item in self.items if not self.kind or item.value['kind'] == self.kind]
selected_index = 0
if self.old_selection:
pt = self.old_selection[0].b
caret_point = offset_to_point(self.view, self.old_selection[0].b)
for index, item in enumerate(items):
if item.value['region'][0] <= pt:
start = item.value['range']['start']
if start['line'] < caret_point.row or \
start['line'] == caret_point.row and start['character'] <= caret_point.col:
selected_index = index
else:
break
return items, selected_index

def preview(self, text: Any) -> Union[str, sublime.Html, None]:
if isinstance(text, dict):
r = text.get('region')
r = text.get('range')
if r:
self.view.run_command('lsp_selection_set', {'regions': [(r[0], r[1])]})
self.view.show_at_center(r[0])
region = range_to_region(r, self.view)
self.view.run_command('lsp_selection_set', {'regions': [(region.a, region.b)]})
self.view.show_at_center(region.a)
if text.get('deprecated'):
return "⚠ Deprecated"
return ""
Expand Down

0 comments on commit ce89f45

Please sign in to comment.