[cfe-commits] [PATCH] New clang-check vim integration script

Alexander Kornienko reviews at llvm-reviews.chandlerc.com
Wed Sep 5 04:12:43 PDT 2012


  Auto save buffers before running clang-check if autowrite option is set.

Hi klimek,

http://llvm-reviews.chandlerc.com/D35

CHANGE SINCE LAST DIFF
  http://llvm-reviews.chandlerc.com/D35?vs=94&id=95#toc

Files:
  tools/clang/docs/HowToSetupToolingForLLVM.html

Index: tools/clang/docs/HowToSetupToolingForLLVM.html
===================================================================
--- tools/clang/docs/HowToSetupToolingForLLVM.html
+++ tools/clang/docs/HowToSetupToolingForLLVM.html
@@ -77,12 +77,38 @@
 <p>If you're using vim, it's convenient to have clang-check integrated. Put this
 into your .vimrc:</p>
 <pre>
-  set makeprg=clang-check\ %
-  map <F5> :make<CR><CR>
-</pre>
-
-<p>When editing C++ code, hit F5 to reparse the current buffer. The output will
-go into the error window, which you can enable with <code>:cope</code>.</p>
+function! ClangCheckImpl(cmd)
+  if &autowrite | wall | endif
+  echo "Running " . a:cmd . " ..."
+  let l:output = system(a:cmd)
+  cexpr l:output
+  cwindow
+  let w:quickfix_title = a:cmd
+  if v:shell_error != 0
+    cc
+  endif
+  let g:clang_check_last_cmd = a:cmd
+endfunction
+
+function! ClangCheck()
+  let l:filename = expand('%')
+  if l:filename =~ '\.\(cpp\|cxx\|cc\|c\)$'
+    call ClangCheckImpl("clang-check " . l:filename)
+  elseif exists("g:clang_check_last_cmd")
+    call ClangCheckImpl(g:clang_check_last_cmd)
+  else
+    echo "Can't detect file's compilation arguments and no previous clang-check invocation!"
+  endif
+endfunction
+
+nmap <silent> <F5> :call ClangCheck()<CR><CR>
+</pre>
+
+<p>When editing a .cpp/.cxx/.cc/.c file, hit F5 to reparse the file. In case
+the current file has a different extension (for example, .h), F5 will re-run
+the last clang-check invocation made from this vim instance (if any). The
+output will go into the error window, which is opened automatically when
+clang-check finds errors, and can be re-opened with <code>:cope</code>.</p>
 
 <p>Other <code>clang-check</code> options that can be useful when working with
 clang AST:</p>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D35.4.patch
Type: text/x-patch
Size: 1823 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20120905/55d42b24/attachment.bin>


More information about the cfe-commits mailing list