summaryrefslogtreecommitdiff
path: root/doc/ale.txt
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2020-08-29 20:40:50 +0100
committerw0rp <devw0rp@gmail.com>2020-08-29 20:40:50 +0100
commit303bed6ec131f4046980f0508355d0f4043c9e3a (patch)
treebe3cca61d938608e9b260c338662b3c60e5ea132 /doc/ale.txt
parent25b572b3bf3cc0229ed836eb3fa80c4c74f2c247 (diff)
downloadale-303bed6ec131f4046980f0508355d0f4043c9e3a.zip
#2107 - Document completion fallbacks and insert-completion trick
Diffstat (limited to 'doc/ale.txt')
-rw-r--r--doc/ale.txt41
1 files changed, 41 insertions, 0 deletions
diff --git a/doc/ale.txt b/doc/ale.txt
index be49b6e9..f7fae380 100644
--- a/doc/ale.txt
+++ b/doc/ale.txt
@@ -466,12 +466,53 @@ use ALE as a completion source for other plugins.
ALE automatic completion will not work when 'paste' is active. Only set
'paste' when you are copy and pasting text into your buffers.
+ALE automatic completion will interfere with default insert completion with
+`CTRL-N` and so on (|compl-vim|). You can write your own keybinds and a
+function in your |vimrc| file to force insert completion instead, like so: >
+
+ function! SmartInsertCompletion() abort
+ " Use the default CTRL-N in completion menus
+ if pumvisible()
+ return "\<C-n>"
+ endif
+
+ " Exit and re-enter insert mode, and use insert completion
+ return "\<Esc>a\<C-n>"
+ endfunction
+
+ inoremap <silent> <C-n> <C-R>=SmartInsertCompletion()<CR>
+<
ALE provides an 'omnifunc' function |ale#completion#OmniFunc| for triggering
completion manually with CTRL-X CTRL-O. |i_CTRL-X_CTRL-O| >
" Use ALE's function for omnicompletion.
set omnifunc=ale#completion#OmniFunc
<
+ *ale-completion-fallback*
+
+You can write your own completion function and fallback on other methods of
+completion by checking if there are no results that ALE can determine. For
+example, for Python code, you could fall back on the `python3complete`
+function. >
+
+ function! TestCompletionFunc(findstart, base) abort
+ let l:result = ale#completion#OmniFunc(a:findstart, a:base)
+
+ " Check if ALE couldn't find anything.
+ if (a:findstart && l:result is -3)
+ \|| (!a:findstart && empty(l:result))
+ " Defer to another omnifunc if ALE couldn't find anything.
+ return python3complete#Complete(a:findstart, a:base)
+ endif
+
+ return l:result
+ endfunction
+
+ set omnifunc=TestCompletionFunc
+<
+See |complete-functions| for documentation on how to write completion
+functions.
+
ALE will only suggest so many possible matches for completion. The maximum
number of items can be controlled with |g:ale_completion_max_suggestions|.