From de4a9e7263f3c044d264627df86b9f1f986de639 Mon Sep 17 00:00:00 2001 From: marcmo Date: Fri, 28 Sep 2012 13:34:18 +0200 Subject: [PATCH] make parsing more robust (fixes #19) if the output of ghc-mod cannot be parsed try to display what we got and indicate to the user that there was a parse problem --- autoload/ghcmod.vim | 31 +++++++++++++++++++++++++------ 1 file changed, 25 insertions(+), 6 deletions(-) diff --git a/autoload/ghcmod.vim b/autoload/ghcmod.vim index 40df6f7..8b39568 100644 --- a/autoload/ghcmod.vim +++ b/autoload/ghcmod.vim @@ -156,6 +156,13 @@ function! ghcmod#parse_make(lines, basedir)"{{{ for l:output in a:lines let l:qf = {} let l:m = matchlist(l:output, '^\(\f\+\):\(\d\+\):\(\d\+\):\s*\(.*\)$') + if len(l:m) < 4 + let l:qf.bufnr = 0 + let l:qf.type = 'E' + let l:qf.text = 'parse error in ghcmod! Could not parse the following ghc-mod output:' . l:output + call add(l:qflist, l:qf) + break + end let [l:qf.filename, l:qf.lnum, l:qf.col, l:rest] = l:m[1 : 4] let l:qf.filename = s:join_path(a:basedir, l:qf.filename) if l:rest =~# '^Warning:' @@ -168,12 +175,24 @@ function! ghcmod#parse_make(lines, basedir)"{{{ let l:qf.type = 'E' endif let l:texts = split(l:rest, '\n') - let l:qf.text = l:texts[0] - call add(l:qflist, l:qf) - - for l:text in l:texts[1 :] - call add(l:qflist, {'text': l:text}) - endfor + if len(l:texts) > 0 + let l:qf.text = l:texts[0] + call add(l:qflist, l:qf) + for l:text in l:texts[1 :] + call add(l:qflist, {'text': l:text}) + endfor + else + let l:qf.filename = '' + let l:errortext = join(a:lines, "\n") + let l:qf.bufnr = 0 + let l:qf.type = 'E' + let l:qf.text = 'parse error in ghcmod! Could not parse the following ghc-mod output:' + call add(l:qflist, l:qf) + for l:text in a:lines + call add(l:qflist, {'text': l:text}) + endfor + break + endif endfor return l:qflist endfunction"}}}