Async fixes
This commit is contained in:
parent
04ac2060e9
commit
02862ee691
11 changed files with 37 additions and 61 deletions
|
|
@ -8,17 +8,11 @@ let s:DefinitionImpl = {}
|
|||
|
||||
|
||||
function! s:DefinitionImpl.run(data)
|
||||
if len(a:data.lines) > 0
|
||||
let res = util#ParseV1(a:data.lines[0])
|
||||
call util#JumpToLocation(res.file, res.line, res.col + 1)
|
||||
else
|
||||
echohl Comment | echo "Not found"
|
||||
endif
|
||||
let res = util#ParseV1(a:data.lines[0])
|
||||
call util#JumpToLocation(res.file, res.line, res.col + 1)
|
||||
endfunction
|
||||
|
||||
|
||||
function! features#definition#run()
|
||||
call suggest#New("def", 1, 0, s:DefinitionImpl)
|
||||
call suggest#New("def", 0, 0, s:DefinitionImpl)
|
||||
endfunction
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -49,10 +49,10 @@ endfunction
|
|||
|
||||
|
||||
function! features#info#web()
|
||||
call suggest#New("def", 1, 0, s:New(1))
|
||||
call suggest#New("def", 0, 0, s:New(1))
|
||||
endfunction
|
||||
|
||||
|
||||
function! features#info#run()
|
||||
call suggest#New("def", 1, 0, s:New(0))
|
||||
call suggest#New("def", 0, 0, s:New(0))
|
||||
endfunction
|
||||
|
|
|
|||
|
|
@ -191,7 +191,7 @@ endfunction
|
|||
|
||||
function! features#outline#run(isUpdating)
|
||||
if !a:isUpdating || s:IsOpen()
|
||||
call suggest#New("outline", 1, 1, s:OutlineImpl)
|
||||
call suggest#New("outline", 0, 1, s:OutlineImpl)
|
||||
endif
|
||||
endfunction
|
||||
|
||||
|
|
|
|||
|
|
@ -7,19 +7,10 @@ let s:RenameImpl = {}
|
|||
|
||||
|
||||
function! s:RenameImpl.run(data)
|
||||
if len(a:data.lines) == 1
|
||||
return
|
||||
endif
|
||||
|
||||
let oldName = split(split(util#FirstNonEmpty(a:data.lines), " ")[2], "\\.")[-1]
|
||||
let newName = input("Rename symbol: ", oldName)
|
||||
|
||||
for line in a:data.lines
|
||||
if len(line) == 0
|
||||
continue
|
||||
endif
|
||||
|
||||
|
||||
let res = util#ParseV2(line)
|
||||
if !s:findInProject && res.file != expand("%:p")
|
||||
continue
|
||||
|
|
@ -42,6 +33,6 @@ endfunction
|
|||
|
||||
function! features#rename#run(inProject)
|
||||
let s:findInProject = a:inProject
|
||||
call suggest#New("use", 1, 1, s:RenameImpl)
|
||||
call suggest#New("use", 0, 1, s:RenameImpl)
|
||||
endfunction
|
||||
|
||||
|
|
|
|||
|
|
@ -46,15 +46,13 @@ endfunction
|
|||
|
||||
let s:UsagesDefinitionImpl = {}
|
||||
function! s:UsagesDefinitionImpl.run(data)
|
||||
" let res = util#ParseV1(a:data.lines[0])
|
||||
" call suggest#NewKnown("use", 1, res.file, res.line, res.col + 1, s:UsagesImpl)
|
||||
call suggest#New("use", 1, 1, s:UsagesImpl)
|
||||
call suggest#NewKnown("use", 0, 1, a:data.file, a:data.line, a:data.col, s:UsagesImpl)
|
||||
endfunction
|
||||
|
||||
function! features#usages#run(findInProject)
|
||||
cclose
|
||||
call setqflist([])
|
||||
let s:findInProject = a:findInProject
|
||||
call suggest#New("def", 1, 1, s:UsagesDefinitionImpl)
|
||||
call suggest#New("def", 0, 1, s:UsagesDefinitionImpl)
|
||||
endfunction
|
||||
|
||||
|
|
|
|||
|
|
@ -97,11 +97,12 @@ endfunction
|
|||
function highlighter#New()
|
||||
let result = copy(s:NimHighlighter)
|
||||
let result.lines = []
|
||||
let result.job = jobstart([g:nvim_nim_exec_nimsuggest, '--v2', '--stdin', expand("%:p")], result)
|
||||
let result.file = expand("%:p")
|
||||
let result.tempfile = util#WriteMemfile()
|
||||
let result.job = jobstart([g:nvim_nim_exec_nimsuggest, '--v2', '--stdin', result.file], result)
|
||||
|
||||
call jobsend(result.job, "highlight " . result.file . ";" . result.tempfile . ":1:1\nquit\n")
|
||||
|
||||
if !exists("b:highlights")
|
||||
let b:highlights = []
|
||||
endif
|
||||
|
|
|
|||
|
|
@ -5,25 +5,8 @@ let s:loaded = 1
|
|||
|
||||
|
||||
let s:findInProject = 1
|
||||
let s:NimSuggestServer = {
|
||||
\ 'pty': 1,
|
||||
\ }
|
||||
|
||||
function! s:NimSuggestServer.on_stdout(job, chunk)
|
||||
" echoerr join(a:chunk, "\n")
|
||||
endfunction
|
||||
function! s:NimSuggestServer.on_stderr(job, chunk)
|
||||
" echoerr join(a:chunk, "\n")
|
||||
endfunction
|
||||
function! s:NimSuggestServer.on_exit()
|
||||
" call jobstop(self.job_server)
|
||||
endfunction
|
||||
|
||||
|
||||
|
||||
" NimSuggest
|
||||
let s:NimSuggest = {
|
||||
\ 'pty': 1,
|
||||
\ 'pty': 0,
|
||||
\ }
|
||||
|
||||
function! s:NimSuggest.on_stdout(job, chunk)
|
||||
|
|
@ -33,15 +16,23 @@ endfunction
|
|||
function! s:NimSuggest.on_stderr(job, chunk)
|
||||
endfunction
|
||||
|
||||
|
||||
function! s:NimSuggest.on_exit()
|
||||
echo ""
|
||||
let self.lines = util#FilterCompletions(self.lines)
|
||||
if len(self.lines) > 0
|
||||
call self.handler.run(self)
|
||||
else
|
||||
echo ""
|
||||
echohl Comment | echo "Got nothing" | echohl Normal
|
||||
endif
|
||||
endfunction
|
||||
|
||||
|
||||
function! suggest#CreateJob(useV2, file, callbacks)
|
||||
return jobstart([g:nvim_nim_exec_nimsuggest, '--stdin', (a:useV2 ? '--v2' : ''), a:file], a:callbacks)
|
||||
endfunction
|
||||
|
||||
|
||||
function! suggest#NewKnown(command, sync, useV2, file, line, col, handler)
|
||||
let result = copy(s:NimSuggest)
|
||||
let result.lines = []
|
||||
|
|
@ -59,16 +50,16 @@ function! suggest#NewKnown(command, sync, useV2, file, line, col, handler)
|
|||
let result.lines = util#FilterCompletions(split(system(fullcmd), "\n"))
|
||||
if len(result.lines) > 0
|
||||
call a:handler.run(result)
|
||||
else
|
||||
echohl Comment | echo "Got nothing" | echohl Normal
|
||||
endif
|
||||
else
|
||||
call util#StartQuery()
|
||||
let result.job_server = jobstart([g:nvim_nim_exec_nimsuggest, '--port:5999', '--address:localhost', (a:useV2 ? '--v2' : ''), result.file], s:NimSuggestServer)
|
||||
if result.job_server < 1
|
||||
echoerr "Unable to start server"
|
||||
let result.job = suggest#CreateJob(a:useV2, result.file, result)
|
||||
if result.job > 0
|
||||
call jobsend(result.job, query . "\nquit\n")
|
||||
else
|
||||
" FIXME: Telnet is not possibly the best way to communicate :S
|
||||
let result.job_suggest = jobstart(['telnet', 'localhost', '5999'], result)
|
||||
call jobsend(result.job_suggest, query . "\n")
|
||||
echoerr "Unable to start server"
|
||||
endif
|
||||
endif
|
||||
return result
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue