diff options
author | w0rp <w0rp@users.noreply.github.com> | 2018-05-09 09:14:38 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-09 09:14:38 +0100 |
commit | 38c66d33fe8022803497c49239b06112ccbd0a83 (patch) | |
tree | de361946a2b9a4ee06c51cd79bd2bf5e9c07c494 | |
parent | f7ecf3f47a22de588c241cd17d75331875097110 (diff) | |
parent | 5fe74c7dc85952a4d902ec73ae1624c6940a995c (diff) | |
download | ale-38c66d33fe8022803497c49239b06112ccbd0a83.zip |
Merge pull request #1563 from IngoHeimbach/fix/gcc-fatal-error
Fatal GCC errors are handled as errors not warnings
-rw-r--r-- | autoload/ale/handlers/gcc.vim | 2 | ||||
-rw-r--r-- | test/handler/test_gcc_handler.vader | 14 |
2 files changed, 15 insertions, 1 deletions
diff --git a/autoload/ale/handlers/gcc.vim b/autoload/ale/handlers/gcc.vim index 9ec7b110..4b53652a 100644 --- a/autoload/ale/handlers/gcc.vim +++ b/autoload/ale/handlers/gcc.vim @@ -48,7 +48,7 @@ function! ale#handlers#gcc#HandleGCCFormat(buffer, lines) abort let l:item = { \ 'lnum': str2nr(l:match[2]), - \ 'type': l:match[4] is# 'error' ? 'E' : 'W', + \ 'type': (l:match[4] is# 'error' || l:match[4] is# 'fatal error') ? 'E' : 'W', \ 'text': s:RemoveUnicodeQuotes(l:match[5]), \} diff --git a/test/handler/test_gcc_handler.vader b/test/handler/test_gcc_handler.vader index 79f17899..678d3f42 100644 --- a/test/handler/test_gcc_handler.vader +++ b/test/handler/test_gcc_handler.vader @@ -148,3 +148,17 @@ Execute(The GCC handler should interpret - as being the current file): \ ale#handlers#gcc#HandleGCCFormat(347, [ \ '-:6:12: error: Some error', \ ]) + +Execute(The GCC handler should handle fatal error messages due to missing files): + AssertEqual + \ [ + \ { + \ 'lnum': 3, + \ 'col': 12, + \ 'type': 'E', + \ 'text': 'foo.h: No such file or directory' + \ }, + \ ], + \ ale#handlers#gcc#HandleGCCFormat(347, [ + \ '<stdin>:3:12: fatal error: foo.h: No such file or directory', + \ ]) |