Async fixes

This commit is contained in:
baabelfish 2016-02-10 02:55:18 +02:00
commit 02862ee691
11 changed files with 37 additions and 61 deletions

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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