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

@ -1,9 +1,9 @@
# nvim-nim [![Build Status](https://travis-ci.org/baabelfish/nvim-nim.svg?branch=master)](https://travis-ci.org/baabelfish/nvim-nim)
Nim support for vim and advanced support for neovim.
Nim support for vim and advanced support for neovim. Still in heavy development.
DON'T INSTALL YET, STILL UNDER VERY HEAVY DEVELOPMENT.
## Features
- Asynchronous
- Syntax highlighting
- Normal vim highlight
- More intelligent highlight with nimsuggest
@ -17,7 +17,7 @@ DON'T INSTALL YET, STILL UNDER VERY HEAVY DEVELOPMENT.
- Get symbol information (type, module, file, signature, etc...)
- Find usages (file and/or project)
- Autocompletion
- Nimsuggest autocompletion
- Nimsuggest omnicompletion
- Autocomplete module names
- IDE like stuff
- Outline listing all symbols in the module (like tagbar)
@ -29,9 +29,10 @@ DON'T INSTALL YET, STILL UNDER VERY HEAVY DEVELOPMENT.
- Send current buffer
- Send selection
![something](https://raw.githubusercontent.com/baabelfish/nvim-nim/master/other/pic1.png)
## Planned features
- Debugger support
- All features will work asynchronously
- Async autocomplete with deoplete (maybe a seperate plugin)

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

View file

@ -1,7 +1,7 @@
if exists("s:loaded")
if exists("g:nvim_nim_ftdetect_loaded")
finish
endif
let s:loaded = 1
let g:nvim_nim_ftdetect_loaded = 1
au BufNewFile,BufRead *.nim setlocal filetype=nim
au BufNewFile,BufRead *.nims setlocal filetype=nims

View file

@ -51,6 +51,6 @@ vnoremap <silent>af :<C-U>call util#SelectNimProc(0)<CR><Esc>gv
vnoremap <silent>if :<C-U>call util#SelectNimProc(1)<CR><Esc>gv
autocmd! BufReadPost,BufWritePost,CursorHold,InsertLeave,TextChanged,InsertEnter *.nim call highlighter#guard()
autocmd! BufWinEnter,BufWritePost,FileWritePost *.nim call features#outline#run(1)
autocmd! CursorHold,BufWritePost,FileWritePost *.nim call features#outline#run(1)
autocmd! VimResized,WinEnter * call features#outline#render()
call highlighter#guard()

View file

@ -1,7 +1,7 @@
if exists("s:loaded")
if exists("g:nvim_nim_loaded")
finish
endif
let s:loaded = 1
let g:nvim_nim_loaded = 1
function! CheckDependency(command)