Skip to content

Commit

Permalink
Add complete_all_chars setting, initialize listener once and early out
Browse files Browse the repository at this point in the history
  • Loading branch information
tomv564 committed Aug 26, 2017
1 parent 98fba2b commit 16decfb
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 40 deletions.
1 change: 1 addition & 0 deletions LSP.sublime-settings
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
"auto_show_diagnostics_panel": true,
"show_diagnostics_phantoms": false,
"show_diagnostics_in_view_status": true,
"complete_all_chars": true,
"log_debug": false,
"log_server": true,
"log_stderr": false
Expand Down
80 changes: 40 additions & 40 deletions main.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
auto_show_diagnostics_panel = True
show_diagnostics_phantoms = False
show_diagnostics_in_view_status = True
only_complete_on_trigger_characters = False
complete_all_chars = False
log_debug = True
log_server = True
log_stderr = False
Expand Down Expand Up @@ -263,6 +263,7 @@ def update_settings(settings_obj: sublime.Settings):
global auto_show_diagnostics_panel
global show_diagnostics_phantoms
global show_diagnostics_in_view_status
global complete_all_chars
global log_debug
global log_server
global log_stderr
Expand All @@ -281,6 +282,7 @@ def update_settings(settings_obj: sublime.Settings):
auto_show_diagnostics_panel = settings_obj.get("auto_show_diagnostics_panel", True)
show_diagnostics_phantoms = settings_obj.get("show_diagnostics_phantoms", False)
show_diagnostics_in_view_status = settings_obj.get("show_diagnostics_in_view_status", True)
complete_all_chars = settings_obj.get("complete_all_chars", True)
log_debug = settings_obj.get("log_debug", False)
log_server = settings_obj.get("log_server", True)
log_stderr = settings_obj.get("log_stderr", False)
Expand Down Expand Up @@ -1519,10 +1521,12 @@ class CompletionState(object):
CANCELLING = 3


class CompletionHandler2(sublime_plugin.ViewEventListener):
class CompletionHandler(sublime_plugin.ViewEventListener):
def __init__(self, view):
self.view = view
self.autocomplete_triggers = None
self.initialized = False
self.enabled = False
self.trigger_chars = [] # type: List[str]
self.completions = [] # type: List[Tuple[str, str]]
self.state = CompletionState.IDLE
self.next_request = None
Expand All @@ -1532,69 +1536,65 @@ def is_applicable(cls, settings):
syntax = settings.get('syntax')
return is_supported_syntax(syntax)

def initialize_triggers(self):
def initialize(self):
self.initialized = True
client = client_for_view(self.view)
if client:
completionProvider = client.get_capability(
'completionProvider')
if completionProvider:
self.autocomplete_triggers = completionProvider.get(
'triggerCharacters')
self.enabled = True
self.trigger_chars = completionProvider.get(
'triggerCharacters') or []
return

self.autocomplete_triggers = []

def is_after_trigger_character(self, location):
if location > 0:
prev_char = self.view.substr(
sublime.Region(location - 1, location))
return prev_char in self.autocomplete_triggers
return prev_char in self.trigger_chars

def on_query_completions(self, prefix, locations):
debug('enter at state {}'.format(self.state))
if self.state == CompletionState.IDLE:
self.do_request(prefix, locations)
self.completions = []
if not self.initialized:
self.initialize()

elif self.state == CompletionState.REQUESTING or self.state == CompletionState.CANCELLING:
debug('replacing request')
self.next_request = (prefix, locations)
self.state = CompletionState.CANCELLING
if self.enabled:
debug('enter at state {}'.format(self.state))
if self.state == CompletionState.IDLE:
self.do_request(prefix, locations)
self.completions = [] # type: List[Tuple[str, str]]

elif self.state == CompletionState.REQUESTING or self.state == CompletionState.CANCELLING:
debug('replacing request')
self.next_request = (prefix, locations)
self.state = CompletionState.CANCELLING

elif self.state == CompletionState.APPLYING:
debug('applying', self.completions)
self.state = CompletionState.IDLE
elif self.state == CompletionState.APPLYING:
debug('applying', self.completions)
self.state = CompletionState.IDLE

return self.completions, (sublime.INHIBIT_WORD_COMPLETIONS
| sublime.INHIBIT_EXPLICIT_COMPLETIONS)
return self.completions, (sublime.INHIBIT_WORD_COMPLETIONS
| sublime.INHIBIT_EXPLICIT_COMPLETIONS)

def do_request(self, prefix, locations):
self.next_request = None
view = self.view

if not is_supported_view(view):
return None

# don't store client so we can handle restarts
client = client_for_view(view)
if not client:
return

completionProvider = client.get_capability('completionProvider')
if not completionProvider:
return

if only_complete_on_trigger_characters and not self.is_after_trigger_character():
return
if complete_all_chars or self.is_after_trigger_character(locations[0]):
snapshot = view.substr(view.full_line(locations[0])).strip()
row, col = view.rowcol(locations[0])
debug('requesting for: "{}" {}:{}'.format(snapshot, row, col))

snapshot = view.substr(view.full_line(locations[0])).strip()
row, col = view.rowcol(locations[0])
debug('requesting for: "{}" {}:{}'.format(snapshot, row, col))

purge_did_change(view.buffer_id())
client.send_request(
Request.complete(get_document_position(view, locations[0])),
self.handle_response)
self.state = CompletionState.REQUESTING
purge_did_change(view.buffer_id())
client.send_request(
Request.complete(get_document_position(view, locations[0])),
self.handle_response)
self.state = CompletionState.REQUESTING

def format_completion(self, item) -> 'Tuple[str, str]':
label = item.get("label")
Expand Down

0 comments on commit 16decfb

Please sign in to comment.