File: StyleCheck.cmake

package info (click to toggle)
innoextract 1.2%2Bgit20120504-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 752 kB
  • sloc: cpp: 7,096; python: 1,542; makefile: 4
file content (54 lines) | stat: -rw-r--r-- 1,498 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54

find_package(PythonInterp)

unset(STYLE_FILTER)

# Complains about any c-style cast -> too annoying.
set(STYLE_FILTER ${STYLE_FILTER},-readability/casting)

# Insists on including evrything in the .cpp file even if it is included in the header.
# This behaviour conflicts with orther tools.
set(STYLE_FILTER ${STYLE_FILTER},-build/include_what_you_use)

# Too many false positives and not very helpful error messages.
set(STYLE_FILTER ${STYLE_FILTER},-build/include_order)

# No thanks.
set(STYLE_FILTER ${STYLE_FILTER},-readability/streams)

# Ugh!
set(STYLE_FILTER ${STYLE_FILTER},-whitespace/tab)

# Yes it is!
set(STYLE_FILTER ${STYLE_FILTER},-whitespace/blank_line)

# Suggessts excessive indentation.
set(STYLE_FILTER ${STYLE_FILTER},-whitespace/labels)

# Don't tell me how to name my variables.
set(STYLE_FILTER ${STYLE_FILTER},-runtime/arrays)

# Why?
set(STYLE_FILTER ${STYLE_FILTER},-whitespace/todo)
set(STYLE_FILTER ${STYLE_FILTER},-readability/todo)

# Annoyting to use with boost::program_options
set(STYLE_FILTER ${STYLE_FILTER},-whitespace/semicolon)

function(add_style_check_target TARGET_NAME SOURCES_LIST INCLUDES_LIST)
	
	if(PYTHONINTERP_FOUND)
		
		add_custom_target(${TARGET_NAME}
			COMMAND cmake -E chdir
				"${CMAKE_SOURCE_DIR}"
				"${PYTHON_EXECUTABLE}"
				"${CMAKE_MODULE_PATH}/cpplint.py"
				"--filter=${STYLE_FILTER}"
				${SOURCES_LIST} ${INCLUDES_LIST}
			DEPENDS ${SOURCES_LIST} ${INCLUDES_LIST} VERBATIM
		)
		
	endif()
	
endfunction(add_style_check_target)