Merge branch 'c-clang-tidy'
This commit is contained in:
		
						commit
						33278f0fce
					
				@ -73,7 +73,7 @@ formatting.
 | 
			
		||||
| Awk | [gawk](https://www.gnu.org/software/gawk/)|
 | 
			
		||||
| Bash | shell [-n flag](https://www.gnu.org/software/bash/manual/bash.html#index-set), [shellcheck](https://www.shellcheck.net/) |
 | 
			
		||||
| Bourne Shell | shell [-n flag](http://linux.die.net/man/1/sh), [shellcheck](https://www.shellcheck.net/) |
 | 
			
		||||
| C | [cppcheck](http://cppcheck.sourceforge.net), [cpplint](https://github.com/google/styleguide/tree/gh-pages/cpplint), [gcc](https://gcc.gnu.org/), [clang](http://clang.llvm.org/), [clang-format](https://clang.llvm.org/docs/ClangFormat.html)|
 | 
			
		||||
| C | [cppcheck](http://cppcheck.sourceforge.net), [cpplint](https://github.com/google/styleguide/tree/gh-pages/cpplint), [gcc](https://gcc.gnu.org/), [clang](http://clang.llvm.org/), [clangtidy](http://clang.llvm.org/extra/clang-tidy/) !!, [clang-format](https://clang.llvm.org/docs/ClangFormat.html)|
 | 
			
		||||
| C++ (filetype cpp) | [clang](http://clang.llvm.org/), [clangcheck](http://clang.llvm.org/docs/ClangCheck.html) !!, [clangtidy](http://clang.llvm.org/extra/clang-tidy/) !!, [cppcheck](http://cppcheck.sourceforge.net), [cpplint](https://github.com/google/styleguide/tree/gh-pages/cpplint) !!, [gcc](https://gcc.gnu.org/), [clang-format](https://clang.llvm.org/docs/ClangFormat.html)|
 | 
			
		||||
| C# | [mcs](http://www.mono-project.com/docs/about-mono/languages/csharp/) |
 | 
			
		||||
| Chef | [foodcritic](http://www.foodcritic.io/) |
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										64
									
								
								ale_linters/c/clangtidy.vim
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								ale_linters/c/clangtidy.vim
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,64 @@
 | 
			
		||||
" Author: vdeurzen <tim@kompiler.org>, w0rp <devw0rp@gmail.com>,
 | 
			
		||||
" gagbo <gagbobada@gmail.com>, Andrej Radovic <r.andrej@gmail.com>
 | 
			
		||||
" Description: clang-tidy linter for c files
 | 
			
		||||
 | 
			
		||||
call ale#Set('c_clangtidy_executable', 'clang-tidy')
 | 
			
		||||
" Set this option to check the checks clang-tidy will apply.
 | 
			
		||||
" The number of checks that can be applied to C files is limited in contrast to
 | 
			
		||||
" C++
 | 
			
		||||
"
 | 
			
		||||
" Consult the check list in clang-tidy's documentation:
 | 
			
		||||
" http://clang.llvm.org/extra/clang-tidy/checks/list.html
 | 
			
		||||
 | 
			
		||||
call ale#Set('c_clangtidy_checks', ['*'])
 | 
			
		||||
" Set this option to manually set some options for clang-tidy.
 | 
			
		||||
" This will disable compile_commands.json detection.
 | 
			
		||||
call ale#Set('c_clangtidy_options', '')
 | 
			
		||||
call ale#Set('c_build_dir', '')
 | 
			
		||||
 | 
			
		||||
function! ale_linters#c#clangtidy#GetExecutable(buffer) abort
 | 
			
		||||
    return ale#Var(a:buffer, 'c_clangtidy_executable')
 | 
			
		||||
endfunction
 | 
			
		||||
 | 
			
		||||
function! s:GetBuildDirectory(buffer) abort
 | 
			
		||||
    " Don't include build directory for header files, as compile_commands.json
 | 
			
		||||
    " files don't consider headers to be translation units, and provide no
 | 
			
		||||
    " commands for compiling header files.
 | 
			
		||||
    if expand('#' . a:buffer) =~# '\v\.(h|hpp)$'
 | 
			
		||||
        return ''
 | 
			
		||||
    endif
 | 
			
		||||
 | 
			
		||||
    let l:build_dir = ale#Var(a:buffer, 'c_build_dir')
 | 
			
		||||
 | 
			
		||||
    " c_build_dir has the priority if defined
 | 
			
		||||
    if !empty(l:build_dir)
 | 
			
		||||
        return l:build_dir
 | 
			
		||||
    endif
 | 
			
		||||
 | 
			
		||||
    return ale#c#FindCompileCommands(a:buffer)
 | 
			
		||||
endfunction
 | 
			
		||||
 | 
			
		||||
function! ale_linters#c#clangtidy#GetCommand(buffer) abort
 | 
			
		||||
    let l:checks = join(ale#Var(a:buffer, 'c_clangtidy_checks'), ',')
 | 
			
		||||
    let l:build_dir = s:GetBuildDirectory(a:buffer)
 | 
			
		||||
 | 
			
		||||
    " Get the extra options if we couldn't find a build directory.
 | 
			
		||||
    let l:options = empty(l:build_dir)
 | 
			
		||||
    \   ? ale#Var(a:buffer, 'c_clangtidy_options')
 | 
			
		||||
    \   : ''
 | 
			
		||||
 | 
			
		||||
    return ale#Escape(ale_linters#c#clangtidy#GetExecutable(a:buffer))
 | 
			
		||||
    \   . (!empty(l:checks) ? ' -checks=' . ale#Escape(l:checks) : '')
 | 
			
		||||
    \   . ' %s'
 | 
			
		||||
    \   . (!empty(l:build_dir) ? ' -p ' . ale#Escape(l:build_dir) : '')
 | 
			
		||||
    \   . (!empty(l:options) ? ' -- ' . l:options : '')
 | 
			
		||||
endfunction
 | 
			
		||||
 | 
			
		||||
call ale#linter#Define('c', {
 | 
			
		||||
\   'name': 'clangtidy',
 | 
			
		||||
\   'output_stream': 'stdout',
 | 
			
		||||
\   'executable_callback': 'ale_linters#c#clangtidy#GetExecutable',
 | 
			
		||||
\   'command_callback': 'ale_linters#c#clangtidy#GetCommand',
 | 
			
		||||
\   'callback': 'ale#handlers#gcc#HandleGCCFormat',
 | 
			
		||||
\   'lint_file': 1,
 | 
			
		||||
\})
 | 
			
		||||
@ -2,6 +2,37 @@
 | 
			
		||||
ALE C Integration                                               *ale-c-options*
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
Global Options
 | 
			
		||||
 | 
			
		||||
g:ale_c_build_dir_names                               *g:ale_c_build_dir_names*
 | 
			
		||||
                                                      *b:ale_c_build_dir_names*
 | 
			
		||||
 | 
			
		||||
  Type: |List|
 | 
			
		||||
  Default: `['build', 'bin']`
 | 
			
		||||
 | 
			
		||||
  A list of directory names to be used when searching upwards from cpp
 | 
			
		||||
  files to discover compilation databases with. For directory named `'foo'`,
 | 
			
		||||
  ALE will search for `'foo/compile_commands.json'` in all directories on and above
 | 
			
		||||
  the directory containing the cpp file to find path to compilation database.
 | 
			
		||||
  This feature is useful for the clang tools wrapped around LibTooling (namely
 | 
			
		||||
  here, clang-tidy)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
g:ale_c_build_dir                                           *g:ale_c_build_dir*
 | 
			
		||||
                                                            *b:ale_c_build_dir*
 | 
			
		||||
 | 
			
		||||
  Type: |String|
 | 
			
		||||
  Default: `''`
 | 
			
		||||
 | 
			
		||||
  A path to the directory containing the `compile_commands.json` file to use
 | 
			
		||||
  with c-family linters. Usually setting this option to a non-empty string
 | 
			
		||||
  will override the |g:ale_c_build_dir_names| option to impose a compilation
 | 
			
		||||
  database (it can be useful if multiple builds are in multiple build
 | 
			
		||||
  subdirectories in the project tree).
 | 
			
		||||
  This feature is also most useful for the clang tools linters, wrapped
 | 
			
		||||
  aroung LibTooling (namely clang-tidy here)
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
clang                                                             *ale-c-clang*
 | 
			
		||||
 | 
			
		||||
@ -21,6 +52,59 @@ g:ale_c_clang_options                                   *g:ale_c_clang_options*
 | 
			
		||||
  This variable can be changed to modify flags given to clang.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
clangtidy                                                     *ale-c-clangtidy*
 | 
			
		||||
 | 
			
		||||
`clang-tidy` will be run only when files are saved to disk, so that
 | 
			
		||||
`compile_commands.json` files can be used. It is recommended to use this
 | 
			
		||||
linter in combination with `compile_commands.json` files.
 | 
			
		||||
Therefore, `clang-tidy` linter reads the options |g:ale_c_build_dir| and
 | 
			
		||||
|g:ale_c_build_dir_names|. Also, setting |g:ale_c_build_dir| actually
 | 
			
		||||
overrides |g:ale_c_build_dir_names|.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
g:ale_c_clangtidy_checks                             *g:ale_c_clangtidy_checks*
 | 
			
		||||
                                                     *b:ale_c_clangtidy_checks*
 | 
			
		||||
  Type: |List|
 | 
			
		||||
  Default: `['*']`
 | 
			
		||||
 | 
			
		||||
  The checks to enable for clang-tidy with the `-checks` argument.
 | 
			
		||||
 | 
			
		||||
  All options will be joined with commas, and escaped appropriately for
 | 
			
		||||
  the shell. The `-checks` flag can be removed entirely by setting this
 | 
			
		||||
  option to an empty List.
 | 
			
		||||
 | 
			
		||||
  Not all of clangtidy checks are applicable for C. You should consult the
 | 
			
		||||
  clang documentation for an up-to-date list of compatible checks:
 | 
			
		||||
  http://clang.llvm.org/extra/clang-tidy/checks/list.html
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
g:ale_c_clangtidy_executable                     *g:ale_c_clangtidy_executable*
 | 
			
		||||
                                                 *b:ale_c_clangtidy_executable*
 | 
			
		||||
  Type: |String|
 | 
			
		||||
  Default: `'clang-tidy'`
 | 
			
		||||
 | 
			
		||||
  This variable can be changed to use a different executable for clangtidy.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
g:ale_c_clangtidy_options                           *g:ale_c_clangtidy_options*
 | 
			
		||||
                                                    *b:ale_c_clangtidy_options*
 | 
			
		||||
  Type: |String|
 | 
			
		||||
  Default: `''`
 | 
			
		||||
 | 
			
		||||
  This variable can be changed to modify flags given to clang-tidy.
 | 
			
		||||
 | 
			
		||||
  - Setting this variable to a non-empty string,
 | 
			
		||||
  - and working in a buffer where no compilation database is found using
 | 
			
		||||
    |g:ale_c_build_dir_names| or |g:ale_c_build_dir|,
 | 
			
		||||
  will cause the `--` argument to be passed to `clang-tidy`, which will mean
 | 
			
		||||
  that detection of `compile_commands.json` files for compile command
 | 
			
		||||
  databases will be disabled.
 | 
			
		||||
  Only set this option if you want to control compiler flags
 | 
			
		||||
  entirely manually, and no `compile_commands.json` file is in one
 | 
			
		||||
  of the |g:ale_c_build_dir_names| directories of the project tree.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
cppcheck                                                       *ale-c-cppcheck*
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -5,33 +5,9 @@ ALE C++ Integration                                           *ale-cpp-options*
 | 
			
		||||
===============================================================================
 | 
			
		||||
Global Options
 | 
			
		||||
 | 
			
		||||
g:ale_c_build_dir_names                               *g:ale_c_build_dir_names*
 | 
			
		||||
                                                      *b:ale_c_build_dir_names*
 | 
			
		||||
The |g:ale_c_build_dir_names| and |g:ale_c_build_dir| also apply to some C++
 | 
			
		||||
linters too.
 | 
			
		||||
 | 
			
		||||
  Type: |List|
 | 
			
		||||
  Default: `['build', 'bin']`
 | 
			
		||||
 | 
			
		||||
  A list of directory names to be used when searching upwards from cpp
 | 
			
		||||
  files to discover compilation databases with. For directory named `'foo'`,
 | 
			
		||||
  ALE will search for `'foo/compile_commands.json'` in all directories on and above
 | 
			
		||||
  the directory containing the cpp file to find path to compilation database.
 | 
			
		||||
  This feature is useful for the clang tools wrapped around LibTooling (namely
 | 
			
		||||
  here, clang-tidy)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
g:ale_c_build_dir                                           *g:ale_c_build_dir*
 | 
			
		||||
                                                            *b:ale_c_build_dir*
 | 
			
		||||
 | 
			
		||||
  Type: |String|
 | 
			
		||||
  Default: `''`
 | 
			
		||||
 | 
			
		||||
  A path to the directory containing the `compile_commands.json` file to use
 | 
			
		||||
  with c-family linters. Usually setting this option to a non-empty string
 | 
			
		||||
  will override the |g:ale_c_build_dir_names| option to impose a compilation
 | 
			
		||||
  database (it can be useful if multiple builds are in multiple build
 | 
			
		||||
  subdirectories in the project tree).
 | 
			
		||||
  This feature is also most useful for the clang tools linters, wrapped
 | 
			
		||||
  aroung LibTooling (namely clang-tidy here)
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
clang                                                           *ale-cpp-clang*
 | 
			
		||||
 | 
			
		||||
@ -18,6 +18,7 @@ CONTENTS                                                         *ale-contents*
 | 
			
		||||
      gcc.................................|ale-asm-gcc|
 | 
			
		||||
    c.....................................|ale-c-options|
 | 
			
		||||
      clang...............................|ale-c-clang|
 | 
			
		||||
      clangtidy...........................|ale-c-clangtidy|
 | 
			
		||||
      cppcheck............................|ale-c-cppcheck|
 | 
			
		||||
      gcc.................................|ale-c-gcc|
 | 
			
		||||
      clang-format........................|ale-c-clangformat|
 | 
			
		||||
@ -188,7 +189,7 @@ Notes:
 | 
			
		||||
* Awk: `gawk`
 | 
			
		||||
* Bash: `shell` (-n flag), `shellcheck`
 | 
			
		||||
* Bourne Shell: `shell` (-n flag), `shellcheck`
 | 
			
		||||
* C: `cppcheck`, `cpplint`!!, `gcc`, `clang`, `clang-format`
 | 
			
		||||
* C: `cppcheck`, `cpplint`!!, `gcc`, `clang`, `clangtidy`!!, `clang-format`
 | 
			
		||||
* C++ (filetype cpp): `clang`, `clangcheck`!!, `clangtidy`!!, `cppcheck`, `cpplint`!!, `gcc`, `clang-format`
 | 
			
		||||
* C#: `mcs`
 | 
			
		||||
* Chef: `foodcritic`
 | 
			
		||||
 | 
			
		||||
@ -0,0 +1,97 @@
 | 
			
		||||
Before:
 | 
			
		||||
  Save g:ale_c_clangtidy_checks
 | 
			
		||||
  Save g:ale_c_clangtidy_options
 | 
			
		||||
  Save g:ale_c_build_dir
 | 
			
		||||
 | 
			
		||||
  unlet! g:ale_c_build_dir
 | 
			
		||||
  unlet! b:ale_c_build_dir
 | 
			
		||||
  unlet! g:ale_c_clangtidy_checks
 | 
			
		||||
  unlet! b:ale_c_clangtidy_checks
 | 
			
		||||
  unlet! g:ale_c_clangtidy_options
 | 
			
		||||
  unlet! b:ale_c_clangtidy_options
 | 
			
		||||
 | 
			
		||||
  runtime ale_linters/c/clangtidy.vim
 | 
			
		||||
 | 
			
		||||
  call ale#test#SetFilename('test.c')
 | 
			
		||||
 | 
			
		||||
After:
 | 
			
		||||
  unlet! b:ale_c_build_dir
 | 
			
		||||
  unlet! b:ale_c_clangtidy_checks
 | 
			
		||||
  unlet! b:ale_c_clangtidy_options
 | 
			
		||||
  unlet! b:ale_c_clangtidy_executable
 | 
			
		||||
 | 
			
		||||
  Restore
 | 
			
		||||
  call ale#linter#Reset()
 | 
			
		||||
 | 
			
		||||
Execute(The clangtidy command default should be correct):
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(You should be able to remove the -checks option for clang-tidy):
 | 
			
		||||
  let b:ale_c_clangtidy_checks = []
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' %s',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(You should be able to set other checks for clang-tidy):
 | 
			
		||||
  let b:ale_c_clangtidy_checks = ['-*', 'clang-analyzer-*']
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''-*,clang-analyzer-*'' %s',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(You should be able to manually set compiler flags for clang-tidy):
 | 
			
		||||
  let b:ale_c_clangtidy_options = '-Wall'
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s -- -Wall',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
  \
 | 
			
		||||
Execute(The build directory should be configurable):
 | 
			
		||||
  let b:ale_c_build_dir = '/foo/bar'
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s -p ' . ale#Escape('/foo/bar'),
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(The build directory setting should override the options):
 | 
			
		||||
  let b:ale_c_build_dir = '/foo/bar'
 | 
			
		||||
  let b:ale_c_clangtidy_options = '-Wall'
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s -p ' . ale#Escape('/foo/bar'),
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(The build directory should be ignored for header files):
 | 
			
		||||
  call ale#test#SetFilename('test.h')
 | 
			
		||||
 | 
			
		||||
  let b:ale_c_build_dir = '/foo/bar'
 | 
			
		||||
  let b:ale_c_clangtidy_options = '-Wall'
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s -- -Wall',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
  \
 | 
			
		||||
  call ale#test#SetFilename('test.h')
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('clang-tidy')
 | 
			
		||||
  \   . ' -checks=''*'' %s -- -Wall',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
 | 
			
		||||
Execute(The executable should be configurable):
 | 
			
		||||
  let b:ale_c_clangtidy_executable = 'foobar'
 | 
			
		||||
 | 
			
		||||
  AssertEqual
 | 
			
		||||
  \ ale#Escape('foobar')
 | 
			
		||||
  \   . ' -checks=''*'' %s',
 | 
			
		||||
  \ ale_linters#c#clangtidy#GetCommand(bufnr(''))
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user