Use a line-specs for the clang_errors option in clang.kak

That way, we can have it updated when the buffer changes, and get
diagnostics on the correct lines.
This commit is contained in:
Maxime Coste 2017-05-25 12:17:22 +01:00
parent a84d7cf06b
commit 26298e8f7b

View File

@ -4,7 +4,7 @@ decl -docstring "options to pass to the `clang` shell command" \
decl -hidden str clang_tmp_dir decl -hidden str clang_tmp_dir
decl -hidden completions clang_completions decl -hidden completions clang_completions
decl -hidden line-specs clang_flags decl -hidden line-specs clang_flags
decl -hidden str clang_errors decl -hidden line-specs clang_errors
def -params ..1 \ def -params ..1 \
-docstring %{Parse the contents of the current buffer -docstring %{Parse the contents of the current buffer
@ -88,13 +88,15 @@ The syntaxic errors detected during parsing are shown when auto-diagnostics are
" | paste -s -d ':' -) " | paste -s -d ':' -)
errors=$(cat ${dir}/stderr | sed -rne " errors=$(cat ${dir}/stderr | sed -rne "
/^<stdin>:[0-9]+:([0-9]+:)? ((fatal )?error|warning)/ { s/^<stdin>:([0-9]+):([0-9]+:)? (.*)/\1,\3/; s/'/\\\\'/g; p } /^<stdin>:[0-9]+:([0-9]+:)? ((fatal )?error|warning)/ {
" | sort -n) s/^<stdin>:([0-9]+):([0-9]+:)? (.*)/\1|\3/
s/'/\\\\'/g; s/:/\\\\:/g; p
}" | sort -n | paste -s -d ':' -)
sed -e "s|<stdin>|${kak_bufname}|g" < ${dir}/stderr > ${dir}/fifo sed -e "s|<stdin>|${kak_bufname}|g" < ${dir}/stderr > ${dir}/fifo
printf %s\\n "set 'buffer=${kak_buffile}' clang_flags %{${kak_timestamp}:${flags}} printf %s\\n "set 'buffer=${kak_buffile}' clang_flags %{${kak_timestamp}:${flags}}
set 'buffer=${kak_buffile}' clang_errors '${errors}'" | kak -p ${kak_session} set 'buffer=${kak_buffile}' clang_errors '${kak_timestamp}:${errors}'" | kak -p ${kak_session}
) > /dev/null 2>&1 < /dev/null & ) > /dev/null 2>&1 < /dev/null &
} }
} }
@ -131,8 +133,12 @@ def clang-disable-autocomplete -docstring "Disable automatic clang completion" %
unalias window complete clang-complete unalias window complete clang-complete
} }
def -hidden clang-show-error-info %{ %sh{ def -hidden clang-show-error-info %{
desc=$(printf %s\\n "${kak_opt_clang_errors}" | sed -ne "/^${kak_cursor_line},.*/ { s/^[[:digit:]]\+,//g; s/'/\\\\'/g; p }") update-option buffer clang_errors # Ensure we are up to date with buffer changes
%sh{
desc=$(printf %s\\n "${kak_opt_clang_errors}" |
sed -e "s/\([^\\]\):/\1\n/g" |
sed -ne "/^${kak_cursor_line}|.*/ { s/^[[:digit:]]\+|//g; s/'/\\\\'/g; s/\\\\:/:/g; p }")
if [ -n "$desc" ]; then if [ -n "$desc" ]; then
printf %s\\n "info -anchor ${kak_cursor_line}.${kak_cursor_column} '${desc}'" printf %s\\n "info -anchor ${kak_cursor_line}.${kak_cursor_column} '${desc}'"
fi fi
@ -151,19 +157,19 @@ def clang-disable-diagnostics -docstring "Disable automatic error reporting and
remove-hooks window clang-diagnostics remove-hooks window clang-diagnostics
} }
def clang-diagnostics-next -docstring "Jump to the next line that contains an error" %{ %sh{ def clang-diagnostics-next -docstring "Jump to the next line that contains an error" %{
printf "%s\n" "${kak_opt_clang_errors}" | ( update-option buffer clang_errors # Ensure we are up to date with buffer changes
line=-1 %sh{
first_line=-1 printf "%s\n" "${kak_opt_clang_errors}" | sed -e 's/\([^\\]\):/\1\n/g' | tail -n +2 | (
while read line_content; do while IFS='|' read candidate rest; do
candidate=${line_content%%,*} first_line=${first_line-$candidate}
if [ -n "$candidate" ]; then if [ $candidate -gt $kak_cursor_line ]; then
first_line=$(( first_line == -1 ? candidate : first_line )) line=$candidate
line=$((candidate > kak_cursor_line && (candidate < line || line == -1) ? candidate : line )) break
fi fi
done done
line=$((line == -1 ? first_line : line)) line=${line-$first_line}
if [ ${line} -ne -1 ]; then if [ -n "$line" ]; then
printf %s\\n "exec ${line} g" printf %s\\n "exec ${line} g"
else else
echo 'echo -color Error no next clang diagnostic' echo 'echo -color Error no next clang diagnostic'