99c5b7e678
Echo supported switches are not well defined, so echo usage that directly pass a shell variable as parameter may not have the expected behaviour. Using printf %s should be safer.
45 lines
1.7 KiB
Plaintext
45 lines
1.7 KiB
Plaintext
decl -hidden str jedi_tmp_dir
|
|
decl -hidden str-list jedi_completions
|
|
|
|
def jedi-complete -docstring "Complete the current selection with jedi" %{
|
|
%sh{
|
|
dir=$(mktemp -d -t kak-jedi.XXXXXXXX)
|
|
mkfifo ${dir}/fifo
|
|
echo "set buffer jedi_tmp_dir ${dir}"
|
|
echo "write ${dir}/buf"
|
|
}
|
|
%sh{
|
|
dir=${kak_opt_jedi_tmp_dir}
|
|
echo "eval -draft %{ edit! -fifo ${dir}/fifo *jedi-output* }"
|
|
(
|
|
cd $(dirname ${kak_buffile})
|
|
header="${kak_cursor_line}.${kak_cursor_column}@${kak_timestamp}"
|
|
|
|
compl=$(python 2> "${dir}/fifo" <<-END
|
|
import jedi
|
|
script=jedi.Script(open('$dir/buf', 'r').read(), $kak_cursor_line, $kak_cursor_column - 1, '$kak_buffile')
|
|
print ':'.join([str(c.name) + "@" + str(c.docstring()).replace(":", "\\:") for c in script.completions()])
|
|
END
|
|
)
|
|
echo "eval -client ${kak_client} %[ echo completed; set 'buffer=${kak_buffile}' jedi_completions %[${header}:${compl}] ]" | kak -p ${kak_session}
|
|
rm -r ${dir}
|
|
) > /dev/null 2>&1 < /dev/null &
|
|
}
|
|
}
|
|
|
|
def jedi-enable-autocomplete -docstring "Add jedi completion candidates to the completer" %{
|
|
set window completers "option=jedi_completions:%opt{completers}"
|
|
hook window -group jedi-autocomplete InsertIdle .* %{ try %{
|
|
exec -draft <a-h><a-k>\..\'<ret>
|
|
echo 'completing...'
|
|
jedi-complete
|
|
} }
|
|
alias window complete jedi-complete
|
|
}
|
|
|
|
def jedi-disable-autocomplete -docstring "Disable jedi completion" %{
|
|
set window completers %sh{ printf %s "'${kak_opt_completers}'" | sed -e 's/option=jedi_completions://g' }
|
|
rmhooks window jedi-autocomplete
|
|
unalias window complete jedi-complete
|
|
}
|