diff options
author | Adam Stankiewicz <sheerun@sher.pl> | 2014-12-11 22:58:14 +0100 |
---|---|---|
committer | Adam Stankiewicz <sheerun@sher.pl> | 2014-12-11 22:58:14 +0100 |
commit | 7f2e3663341d725b073857fcd3b2f5868ce85248 (patch) | |
tree | 34c4063119045da0824d46b6c1f8fc8fc0b9c2b4 /autoload | |
parent | 04f868b94aad9ef31d3cd1adc526d720808f7837 (diff) | |
download | vim-polyglot-7f2e3663341d725b073857fcd3b2f5868ce85248.tar.gz vim-polyglot-7f2e3663341d725b073857fcd3b2f5868ce85248.zip |
Change erlang provider to hcs42/vim-erlang-runtime
Diffstat (limited to 'autoload')
-rw-r--r-- | autoload/erlangcomplete.vim | 161 |
1 files changed, 0 insertions, 161 deletions
diff --git a/autoload/erlangcomplete.vim b/autoload/erlangcomplete.vim deleted file mode 100644 index 3e4208e8..00000000 --- a/autoload/erlangcomplete.vim +++ /dev/null @@ -1,161 +0,0 @@ -" ------------------------------------------------------------------------------ -" Vim omni-completion script -" Author: Oscar Hellström -" Email: oscar@oscarh.net -" Version: 2010-08-10 -" Contributors: kTT (http://github.com/kTT) -" Ricardo Catalinas Jiménez <jimenezrick@gmail.com> -" ------------------------------------------------------------------------------ - -" Patterns for completions {{{1 -let s:erlangLocalFuncBeg = '\(\<[0-9A-Za-z_-]*\|\s*\)$' -let s:erlangExternalFuncBeg = '\<[0-9A-Za-z_-]\+:[0-9A-Za-z_-]*$' -let s:ErlangBlankLine = '^\s*\(%.*\)\?$' -let s:erlangCompletionPath = expand('<sfile>:p:h') . '/erlang_completion.erl' - -if !exists('g:erlangCompletionGrep') - let g:erlangCompletionGrep = 'grep' -endif - -if !exists('g:erlangManSuffix') - let g:erlangManSuffix = '' -endif - -if !exists('g:erlangManPath') - let g:erlangManPath = '/usr/lib/erlang/man' -endif - -if !exists('g:erlangCompletionDisplayDoc') - let g:erlangCompletionDisplayDoc = 1 -endif - -" Main function for completion {{{1 -function! erlangcomplete#Complete(findstart, base) - " 0) Init {{{2 - let lnum = line('.') - let column = col('.') - let line = strpart(getline('.'), 0, column - 1) - - " 1) First, check if completion is impossible {{{2 - if line =~ '[^~\\]%' - return -1 - endif - - "echo "line[col - 1]:" . line[column - 1] . " line[col - 2]:" . line[column - 2] . "\n" . line . "\n" - - " 2) Check if the char to the left of us are part of a function call {{{2 - " - " Nothing interesting is written at the char just before the cursor - " This means _anything_ could be started here - " In this case, keyword completion should probably be used, - " for now we'll only try and complete local functions. - " TODO: Examine if we can stare Identifiers end complete on them - " Is this worth it? Is /completion/ of a "blank" wanted? Can we consider ( - " interesting and check if we are in a function call etc.? - if line[column - 2] !~ '[0-9A-Za-z:_-]' - if a:findstart - return column - else - return s:erlangFindLocalFunc(a:base) - endif - endif - - - " 3) Function in external module {{{2 - if line =~ s:erlangExternalFuncBeg - let delimiter = match(line, ':[0-9A-Za-z_-]*$') + 1 - if a:findstart - return delimiter - else - let module = matchstr(line[:-2], '\<\k*\>$') - return s:erlangFindExternalFunc(module, a:base) - endif - endif - - " 4) Local function {{{2 - if line =~ s:erlangLocalFuncBeg - let funcstart = match(line, ':\@<![0-9A-Za-z_-]*$') - if a:findstart - return funcstart - else - return s:erlangFindLocalFunc(a:base) - endif - endif - - " 5) Unhandled situation {{{2 - if a:findstart - return -1 - else - return [] - endif -endfunction - -" Auxiliary functions for completion {{{1 -" Find the next non-blank line {{{2 -function s:erlangFindNextNonBlank(lnum) - let lnum = nextnonblank(a:lnum + 1) - let line = getline(lnum) - while line =~ s:ErlangBlankLine && 0 != lnum - let lnum = nextnonblank(lnum + 1) - let line = getline(lnum) - endwhile - return lnum -endfunction - -" vim: foldmethod=marker: -" Find external function names {{{2 -function s:erlangFindExternalFunc(module, base) - " If it's a local module, try to compile it - if filereadable(a:module . '.erl') && !filereadable(a:module . '.beam') - silent execute '!erlc' a:module . '.erl' '>/dev/null' '2>/dev/null' - redraw! - endif - let functions = system(s:erlangCompletionPath . ' ' . a:module) - for element in sort(split(functions, '\n')) - if match(element, a:base) == 0 - let function_name = matchstr(element, a:base . '\w\+') - let number_of_args = matchstr(element, '\d\+', len(function_name)) - let number_of_comma = max([number_of_args - 1, 0]) - let file_path = g:erlangManPath . '/man?/' . a:module . '\.?' . g:erlangManSuffix - " [:-2] cutting some weird characters at the end - " becouse grep doesn't support multilines, we have to filter - " first by .B and next by looking via function name - " if someone have better idea, please change it - let description = '' - " Don't look man pages if the module is present in the current directory - if g:erlangCompletionDisplayDoc != 0 && !filereadable(a:module . '.erl') - let system_command = g:erlangCompletionGrep . ' -A 1 "\.B" ' . file_path . ' | grep -EZo "\<' . -\ function_name . '\>\((\w+, ){' . number_of_comma . '}[^),]*\) -> .*"' - let description = system(system_command) - let description = description[:-2] - endif - if description == '' - let description = element " if function doesn't have description e.g. lists:rmerge, put rmerge/2 instead - endif - let field = {'word': function_name . '(', 'abbr': description, 'kind': 'f', 'dup': 1} " always duplicate functions - call complete_add(field) - endif - endfor - return [] -endfunction - -" Find local function names {{{2 -function s:erlangFindLocalFunc(base) - " begin at line 1 - let lnum = s:erlangFindNextNonBlank(1) - if "" == a:base - let base = '\w' " used to match against word symbol - else - let base = a:base - endif - while 0 != lnum && !complete_check() - let line = getline(lnum) - let function_name = matchstr(line, '^' . base . '[0-9A-Za-z_-]\+(\@=') - if function_name != "" - call complete_add(function_name) - endif - let lnum = s:erlangFindNextNonBlank(lnum) - endwhile - return [] -endfunction - |