aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorSteve Matney2026-01-25 00:42:14 -0700
committerGitHub2026-01-25 16:42:14 +0900
commitf730dedca70e8570a0aaf9807013deac880b6f25 (patch)
treee6fb7c13026fb287542e7ddb00b8c38503b6c3ff
parent9b51f6696046ee352dfd6ba6bcb9e803b149d5be (diff)
downloadale-f730dedca70e8570a0aaf9807013deac880b6f25.tar.gz

Utilizing -fzf for tsserver responses along with regular lsp responses (#5084)

  • Utilizing -fzf for tsserver responses along with regular lsp responses

  • Refactoring FormatResponseItem in references.vim to accept response item config

-rw-r--r--autoload/ale/references.vim153
1 files changed, 71 insertions, 82 deletions
diff --git a/autoload/ale/references.vim b/autoload/ale/references.vim
index 6cf3ff5ec..d8ed12755 100644
--- a/autoload/ale/references.vim
+++ b/autoload/ale/references.vim
@@ -18,98 +18,92 @@ function! ale#references#ClearLSPData() abort
let s:references_map = {}
endfunction
-function! ale#references#FormatTSResponseItem(response_item, options) abort
- let l:match = substitute(a:response_item.lineText, '^\s*\(.\{-}\)\s*$', '\1', '')
+function! ale#references#FormatResponseItem(response_item, options) abort
+ let l:filename = get(a:response_item, 'filename', '')
+ let l:column = get(a:response_item, 'column', 0)
+ let l:line = get(a:response_item, 'line', 0)
+ let l:line_text = get(a:response_item, 'line_text', '')
+
+ try
+ let l:line_text = substitute(
+ \ l:line_text,
+ \ '^\s*\(.\{-}\)\s*$', '\1', ''
+ \)
+ catch
+ " This happens in tests
+ endtry
+
+
+ if get(a:options, 'use_fzf') == 1
+ " grep-style output (filename:line:col:text) so that fzf can properly
+ " show matches and previews using ':' as delimiter
+ return l:filename . ':' . l:line . ':' . l:column . ':' . l:line_text
+ endif
if get(a:options, 'open_in') is# 'quickfix'
return {
- \ 'filename': a:response_item.file,
- \ 'lnum': a:response_item.start.line,
- \ 'col': a:response_item.start.offset,
- \ 'text': l:match,
+ \ 'filename': l:filename,
+ \ 'lnum': l:line,
+ \ 'col': l:column,
+ \ 'text': l:line_text,
\}
else
return {
- \ 'filename': a:response_item.file,
- \ 'line': a:response_item.start.line,
- \ 'column': a:response_item.start.offset,
- \ 'match': l:match,
+ \ 'filename': l:filename,
+ \ 'line': l:line,
+ \ 'column': l:column,
+ \ 'match': l:line_text,
\}
endif
endfunction
+function! ale#references#DisplayReferences(item_list, options) abort
+ if empty(a:item_list)
+ call ale#util#Execute('echom ''No references found.''')
+ else
+ if get(a:options, 'use_fzf') == 1
+ if !exists('*fzf#run')
+ throw 'fzf#run function not found. You also need Vim plugin from the main fzf repository (i.e. junegunn/fzf *and* junegunn/fzf.vim)'
+ endif
+
+ call ale#fzf#ShowReferences(a:item_list, a:options)
+ elseif get(a:options, 'open_in') is# 'quickfix'
+ call setqflist([], 'r')
+ call setqflist(a:item_list, 'a')
+ call ale#util#Execute('cc 1')
+ else
+ call ale#preview#ShowSelection(a:item_list, a:options)
+ endif
+ endif
+endfunction
+
function! ale#references#HandleTSServerResponse(conn_id, response) abort
if get(a:response, 'command', '') is# 'references'
\&& has_key(s:references_map, a:response.request_seq)
let l:options = remove(s:references_map, a:response.request_seq)
+ let l:format_options = copy(l:options)
if get(a:response, 'success', v:false) is v:true
let l:item_list = []
for l:response_item in a:response.body.refs
+ let l:format_response_item = {
+ \ 'filename': l:response_item.file,
+ \ 'line': l:response_item.start.line,
+ \ 'column': l:response_item.start.offset,
+ \ 'line_text': l:response_item.lineText,
+ \ }
call add(
\ l:item_list,
- \ ale#references#FormatTSResponseItem(l:response_item, l:options)
+ \ ale#references#FormatResponseItem(l:format_response_item, l:format_options)
\)
endfor
- if empty(l:item_list)
- call ale#util#Execute('echom ''No references found.''')
- else
- if get(l:options, 'open_in') is# 'quickfix'
- call setqflist([], 'r')
- call setqflist(l:item_list, 'a')
- call ale#util#Execute('cc 1')
- else
- call ale#preview#ShowSelection(l:item_list, l:options)
- endif
- endif
+ call ale#references#DisplayReferences(l:item_list, l:format_options)
endif
endif
endfunction
-function! ale#references#FormatLSPResponseItem(response_item, options) abort
- let l:line_text = ''
-
- let l:line= a:response_item.range.start.line
- let l:col = a:response_item.range.start.character
- let l:filename = ale#util#ToResource(a:response_item.uri)
-
- if get(a:options, 'show_contents') == 1
- try
- let l:line_text = substitute(readfile(l:filename)[l:line], '^\s*\(.\{-}\)\s*$', '\1', '')
- catch
- " This happens in tests
- endtry
- endif
-
- if get(a:options, 'use_fzf') == 1
- let l:filename = ale#util#ToResource(a:response_item.uri)
- let l:nline = a:response_item.range.start.line + 1
- let l:ncol = a:response_item.range.start.character + 1
-
- " grep-style output (filename:line:col:text) so that fzf can properly
- " show matches and previews using ':' as delimiter
- return l:filename . ':' . l:nline . ':' . l:ncol . ':' . l:line_text
- endif
-
- if get(a:options, 'open_in') is# 'quickfix'
- return {
- \ 'filename': l:filename,
- \ 'lnum': a:response_item.range.start.line + 1,
- \ 'col': a:response_item.range.start.character + 1,
- \ 'text': l:line_text,
- \}
- else
- return {
- \ 'filename': l:filename,
- \ 'line': l:line + 1,
- \ 'column': l:col + 1,
- \ 'match': l:line_text,
- \}
- endif
-endfunction
-
function! ale#references#HandleLSPResponse(conn_id, response) abort
if ! (has_key(a:response, 'id') && has_key(s:references_map, a:response.id))
return
@@ -123,29 +117,24 @@ function! ale#references#HandleLSPResponse(conn_id, response) abort
if type(l:result) is v:t_list
for l:response_item in l:result
+ let l:filename = ale#util#ToResource(get(l:response_item, 'uri', ''))
+ let l:read_line = l:response_item.range.start.line
+ let l:line = l:read_line + 1
+ let l:format_response_item = {
+ \ 'filename': l:filename,
+ \ 'line': l:line,
+ \ 'column': l:response_item.range.start.character + 1,
+ \ 'line_text': get(l:options, 'show_contents') == 1
+ \ ? readfile(l:filename)[l:read_line]
+ \ : '',
+ \ }
call add(l:item_list,
- \ ale#references#FormatLSPResponseItem(l:response_item, l:options)
+ \ ale#references#FormatResponseItem(l:format_response_item, l:options)
\)
endfor
endif
- if empty(l:item_list)
- call ale#util#Execute('echom ''No references found.''')
- else
- if get(l:options, 'use_fzf') == 1
- if !exists('*fzf#run')
- throw 'fzf#run function not found. You also need Vim plugin from the main fzf repository (i.e. junegunn/fzf *and* junegunn/fzf.vim)'
- endif
-
- call ale#fzf#ShowReferences(l:item_list, l:options)
- elseif get(l:options, 'open_in') is# 'quickfix'
- call setqflist([], 'r')
- call setqflist(l:item_list, 'a')
- call ale#util#Execute('cc 1')
- else
- call ale#preview#ShowSelection(l:item_list, l:options)
- endif
- endif
+ call ale#references#DisplayReferences(l:item_list, l:options)
endfunction
function! s:OnReady(line, column, options, linter, lsp_details) abort