Fix and improve various things

- Fixed malformed regular expression for filtering files.
- Fixed incorrect C++/C standard detection.
- Add FOLDER and PROJECT_LABEL support.
- Fix order of flags, includes and defines causing issues.
- Fix multiple spaces causing flags to be treated as files.
- Upgrade to string(JSON) in many places.
- Make GLOBAL the default and remove the option.
This commit is contained in:
Michael Fabian 'Xaymar' Dirks
2023-04-22 23:47:24 +02:00
parent f249747ff0
commit 7e577af2e9
+212 -224
View File
@@ -43,8 +43,8 @@ function(get_target_include_directories)
foreach(_tmp ${gtid})
list(APPEND ignore "${_tmp}")
if((NOT "${_tmp}" IN_LIST _ARGS_IGNORE) AND (NOT "${_tmp}" STREQUAL "${_ARGS_TARGET}") AND (TARGET "${_tmp}"))
get_target_include_directories(INTERFACE OUTPUT _tmp2 TARGET "${_tmp}" IGNORE ${ignore})
foreach(_tmp3 ${_tmp2})
get_target_include_directories(INTERFACE OUTPUT cc_src_command TARGET "${_tmp}" IGNORE ${ignore})
foreach(_tmp3 ${cc_src_command})
list(APPEND out "${_tmp3}")
endforeach()
endif()
@@ -102,8 +102,8 @@ function(get_target_definitions)
foreach(_tmp ${gtd})
list(APPEND ignore "${_tmp}")
if((NOT "${_tmp}" IN_LIST _ARGS_IGNORE) AND (NOT "${_tmp}" STREQUAL "${_ARGS_TARGET}") AND (TARGET "${_tmp}"))
get_target_definitions(INTERFACE OUTPUT _tmp2 TARGET "${_tmp}" IGNORE ${ignore})
foreach(_tmp3 ${_tmp2})
get_target_definitions(INTERFACE OUTPUT cc_src_command TARGET "${_tmp}" IGNORE ${ignore})
foreach(_tmp3 ${cc_src_command})
list(APPEND out "${_tmp3}")
endforeach()
endif()
@@ -122,6 +122,58 @@ function(get_target_definitions)
set(${_ARGS_OUTPUT} "${out}" PARENT_SCOPE)
endfunction()
macro(cstd_to_flag output version default)
set(${output} "${default}")
if(MSVC)
if("${version}" GREATER_EQUAL 17)
set(${output} "/std:c17")
elseif("${version}" GREATER_EQUAL 11)
set(${output} "/std:c11")
endif()
else()
if("${version}" GREATER_EQUAL 23)
set(${output} "-std=c2x")
elseif("${version}" GREATER_EQUAL 17)
set(${output} "-std=c17")
elseif("${version}" GREATER_EQUAL 11)
set(${output} "-std=c11")
elseif("${version}" GREATER_EQUAL 99)
set(${output} "-std=c99")
elseif("${version}" GREATER_EQUAL 90)
set(${output} "-std=c90")
endif()
endif()
endmacro()
macro(cxxstd_to_flag output version default)
set(${output} "${default}")
if(MSVC)
if("${version}" GREATER_EQUAL 23)
set(${output} "/std:c++latest")
elseif("${version}" GREATER_EQUAL 20)
set(${output} "/std:c++20")
elseif("${version}" GREATER_EQUAL 17)
set(${output} "/std:c++17")
elseif("${version}" GREATER_EQUAL 14)
set(${output} "/std:c++14")
endif()
else()
if("${version}" GREATER_EQUAL 23)
set(${output} "-std=c++23")
elseif("${version}" GREATER_EQUAL 20)
set(${output} "-std=c++20")
elseif("${version}" GREATER_EQUAL 17)
set(${output} "-std=c++17")
elseif("${version}" GREATER_EQUAL 14)
set(${output} "-std=c++14")
elseif("${version}" GREATER_EQUAL 11)
set(${output} "-std=c++11")
elseif("${version}" GREATER_EQUAL 98)
set(${output} "-std=c++98")
endif()
endif()
endmacro()
function(generate_compile_commands_json)
cmake_parse_arguments(
PARSE_ARGV 0
@@ -131,7 +183,7 @@ function(generate_compile_commands_json)
"TARGETS"
)
if(NOT _ARGS_REGEX)
set(_ARGS_REGEX "\.(h|hpp|c|cpp)$")
set(_ARGS_REGEX "\\.(h|c)(|pp)$")
endif()
# If the generator itself can create the compile_commands.json file, don't create our own.
@@ -155,6 +207,14 @@ function(generate_compile_commands_json)
return()
endif()
if(MSVC)
set(_define_prefix "/D")
set(_include_prefix "/I")
else()
set(_define_prefix "-D")
set(_include_prefix "-I")
endif()
# Is this generator able to have multiple configurations?
get_property(cc_multiconfig GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG)
if(NOT cc_multiconfig)
@@ -163,7 +223,6 @@ function(generate_compile_commands_json)
set(cc_configurations ${CMAKE_CONFIGURATION_TYPES})
endif()
foreach(current_target ${_ARGS_TARGETS})
# For each target, generate a compile_commands.json file with all files.
@@ -175,67 +234,17 @@ function(generate_compile_commands_json)
# C++ Standard
get_property(cc_tgt_std_CXX TARGET ${current_target} PROPERTY CXX_STANDARD)
if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
if(cc_tgt_std_CXX EQUAL 23)
set(cc_tgt_std_CXX "/std:c++latest")
elseif(cc_tgt_std_CXX EQUAL 20)
set(cc_tgt_std_CXX "/std:c++20")
elseif(cc_tgt_std_CXX EQUAL 17)
set(cc_tgt_std_CXX "/std:c++17")
elseif(cc_tgt_std_CXX EQUAL 14)
set(cc_tgt_std_CXX "/std:c++14")
else()
set(cc_tgt_std_CXX "")
endif()
else()
if(cc_tgt_std_CXX EQUAL 23)
set(cc_tgt_std_CXX "-std=c++23")
elseif(cc_tgt_std_CXX EQUAL 20)
set(cc_tgt_std_CXX "-std=c++20")
elseif(cc_tgt_std_CXX EQUAL 17)
set(cc_tgt_std_CXX "-std=c++17")
elseif(cc_tgt_std_CXX EQUAL 14)
set(cc_tgt_std_CXX "-std=c++14")
elseif(cc_tgt_std_CXX EQUAL 11)
set(cc_tgt_std_CXX "-std=c++11")
elseif(cc_tgt_std_CXX EQUAL 98)
set(cc_tgt_std_CXX "-std=c++98")
else()
set(cc_tgt_std_CXX "")
endif()
endif()
cxxstd_to_flag(cc_tgt_std_CXX "${cc_tgt_std_CXX}" "")
# C standard
get_property(cc_tgt_std_C TARGET ${current_target} PROPERTY C_STANDARD)
if(CMAKE_C_COMPILER_ID STREQUAL "MSVC")
if(cc_tgt_std_C EQUAL 17)
set(cc_tgt_std_C "/std:c17")
elseif(cc_tgt_std_C EQUAL 11)
set(cc_tgt_std_C "/std:c11")
else()
set(cc_tgt_std_C "")
endif()
else()
if(cc_tgt_std_C EQUAL 23)
set(cc_tgt_std_C "-std=c2x")
elseif(cc_tgt_std_C EQUAL 17)
set(cc_tgt_std_C "-std=c17")
elseif(cc_tgt_std_C EQUAL 11)
set(cc_tgt_std_C "-std=c11")
elseif(cc_tgt_std_C EQUAL 99)
set(cc_tgt_std_C "-std=c99")
elseif(cc_tgt_std_C EQUAL 90)
set(cc_tgt_std_C "-std=c90")
else()
set(cc_tgt_std_C "")
endif()
endif()
cstd_to_flag(cc_tgt_std_C "${cc_tgt_std_C}" "")
# Include Directories
get_property(_tmp TARGET ${current_target} PROPERTY INCLUDE_DIRECTORIES)
foreach(_tmp2 ${_tmp})
cmake_path(ABSOLUTE_PATH _tmp2 BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${_tmp2}")
foreach(cc_src_command ${_tmp})
cmake_path(ABSOLUTE_PATH cc_src_command BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${cc_src_command}")
endforeach()
get_target_include_directories(OUTPUT _tmp TARGET ${current_target})
@@ -249,34 +258,34 @@ function(generate_compile_commands_json)
if(TARGET ${_tmp3})
# - Interface Include Directories
get_property(_tmp TARGET ${_tmp3} PROPERTY INTERFACE_INCLUDE_DIRECTORIES)
foreach(_tmp2 ${_tmp})
cmake_path(ABSOLUTE_PATH _tmp2 BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${_tmp2}")
foreach(cc_src_command ${_tmp})
cmake_path(ABSOLUTE_PATH cc_src_command BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${cc_src_command}")
endforeach()
get_property(_tmp TARGET ${_tmp3} PROPERTY INTERFACE_SYSTEM_INCLUDE_DIRECTORIES)
foreach(_tmp2 ${_tmp})
cmake_path(ABSOLUTE_PATH _tmp2 BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${_tmp2}")
foreach(cc_src_command ${_tmp})
cmake_path(ABSOLUTE_PATH cc_src_command BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_includes "${cc_src_command}")
endforeach()
# - Interface Defines, Options
get_property(_tmp TARGET ${current_target} PROPERTY INTERFACE_COMPILE_DEFINITIONS)
foreach(_tmp2 ${_tmp})
list(APPEND cc_tgt_definitions "${_tmp2}")
foreach(cc_src_command ${_tmp})
list(APPEND cc_tgt_definitions "${cc_src_command}")
endforeach()
get_property(_tmp TARGET ${current_target} PROPERTY INTERFACE_COMPILE_OPTIONS)
foreach(_tmp2 ${_tmp})
list(APPEND cc_tgt_options "${_tmp2}")
foreach(cc_src_command ${_tmp})
list(APPEND cc_tgt_options "${cc_src_command}")
endforeach()
endif()
endforeach()
# Figure out source files for this target.
set(cc_tgt_sources "")
get_target_property(_tmp ${current_target} SOURCES)
foreach(_tmp2 ${_tmp})
cmake_path(ABSOLUTE_PATH _tmp2 BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_sources "${_tmp2}")
get_target_property(cc_tgt_sources_raw ${current_target} SOURCES)
foreach(cc_tgt_source ${cc_tgt_sources_raw})
cmake_path(ABSOLUTE_PATH cc_tgt_source BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_tgt_sources "${cc_tgt_source}")
endforeach()
list(FILTER cc_tgt_sources INCLUDE REGEX "${_ARGS_REGEX}")
@@ -300,164 +309,125 @@ function(generate_compile_commands_json)
set(cc_src_language "C")
endif()
endif()
if(CMAKE_${cc_src_language}_COMPILER_ID STREQUAL "MSVC")
set(_define_prefix "/D")
set(_include_prefix "/I")
else()
set(_define_prefix "-D")
set(_include_prefix "-I")
endif()
if(cc_src_language STREQUAL "CXX")
# C++ Standard
get_property(cc_src_std_CXX SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY CXX_STANDARD)
if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
if(cc_src_std_CXX EQUAL 23)
set(cc_src_std "/std:c++latest")
elseif(cc_src_std_CXX EQUAL 20)
set(cc_src_std "/std:c++20")
elseif(cc_src_std_CXX EQUAL 17)
set(cc_src_std "/std:c++17")
elseif(cc_src_std_CXX EQUAL 14)
set(cc_src_std "/std:c++14")
else()
set(cc_src_std "${cc_tgt_std_CXX}")
endif()
else()
if(cc_src_std_CXX EQUAL 23)
set(cc_src_std "-std=c++23")
elseif(cc_src_std_CXX EQUAL 20)
set(cc_src_std "-std=c++20")
elseif(cc_src_std_CXX EQUAL 17)
set(cc_src_std "-std=c++17")
elseif(cc_src_std_CXX EQUAL 14)
set(cc_src_std "-std=c++14")
elseif(cc_src_std_CXX EQUAL 11)
set(cc_src_std "-std=c++11")
elseif(cc_src_std_CXX EQUAL 98)
set(cc_src_std "-std=c++98")
else()
set(cc_src_std "${cc_tgt_std_CXX}")
endif()
endif()
cxxstd_to_flag(cc_src_std "${cc_src_std_CXX}" "${cc_tgt_std_CXX}")
else()
# C standard
get_property(cc_src_std_C SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY C_STANDARD)
if(CMAKE_C_COMPILER_ID STREQUAL "MSVC")
if(cc_src_std_C EQUAL 17)
set(cc_src_std "/std:c17")
elseif(cc_src_std_C EQUAL 11)
set(cc_src_std "/std:c11")
else()
set(cc_src_std "${cc_tgt_std_C}")
endif()
else()
if(cc_src_std_C EQUAL 23)
set(cc_src_std "-std=c2x")
elseif(cc_src_std_C EQUAL 17)
set(cc_src_std "-std=c17")
elseif(cc_src_std_C EQUAL 11)
set(cc_src_std "-std=c11")
elseif(cc_src_std_C EQUAL 99)
set(cc_src_std "-std=c99")
elseif(cc_src_std_C EQUAL 90)
set(cc_src_std "-std=c90")
else()
set(cc_src_std "${cc_tgt_std_C}")
endif()
endif()
cstd_to_flag(cc_src_std "${cc_src_std_C}" "${cc_tgt_std_C}")
endif()
# Compile Options
set(cc_src_options "${cc_tgt_options}")
get_property(_tmp SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY COMPILE_OPTIONS)
foreach(cc_src_command ${_tmp})
list(APPEND cc_src_options "${cc_src_command}")
endforeach()
# Includes
set(cc_src_includex "${cc_tgt_includes}")
get_property(_tmp SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY INCLUDE_DIRECTORIES)
foreach(_tmp2 ${_tmp})
cmake_path(ABSOLUTE_PATH _tmp2 BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_src_includex "${_tmp2}")
foreach(cc_src_command ${_tmp})
cmake_path(ABSOLUTE_PATH cc_src_command BASE_DIRECTORY "${cc_tgt_source_dir}")
list(APPEND cc_src_includex "${cc_src_command}")
endforeach()
# Defines
set(cc_src_defines "${cc_tgt_defines}")
get_property(_tmp SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY COMPILE_DEFINITIONS)
foreach(_tmp2 ${_tmp})
list(APPEND cc_src_defines "${_tmp2}")
endforeach()
# Compile Options
set(cc_src_options "${cc_tgt_options}")
get_property(_tmp SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY COMPILE_OPTIONS)
foreach(_tmp2 ${_tmp})
list(APPEND cc_src_options "${_tmp2}")
foreach(cc_src_command ${_tmp})
list(APPEND cc_src_defines "${cc_src_command}")
endforeach()
#get_property(_ SOURCE ${current_source} TARGET_DIRECTORY ${current_target} PROPERTY _)
# Generate JSON content.
string(APPEND cc_json_content "\t{\n")
set(cc_json_content_entry "{}")
# Working Directory
json_escape_string(OUTPUT _tmp INPUT "${cc_tgt_source_dir}")
file(TO_CMAKE_PATH "${_tmp}" _tmp)
string(APPEND cc_json_content "\t\t\"directory\": \"${_tmp}\",\n")
file(TO_CMAKE_PATH "${cc_tgt_source_dir}" _tmp)
json_escape_string(OUTPUT _tmp INPUT "${_tmp}")
string(JSON cc_json_content_entry SET ${cc_json_content_entry} "directory" \"${_tmp}\")
# Target File
json_escape_string(OUTPUT _tmp INPUT "${cc_src_location}")
file(TO_CMAKE_PATH "${_tmp}" _tmp)
string(APPEND cc_json_content "\t\t\"file\": \"${_tmp}\",\n")
file(TO_CMAKE_PATH "${cc_src_location}" _tmp)
json_escape_string(OUTPUT _tmp INPUT "${_tmp}")
string(JSON cc_json_content_entry SET ${cc_json_content_entry} "file" \"${_tmp}\")
if(ON) # Command
set(_tmp2 "")
set(cc_src_command "")
# cl/cc difference
if(CMAKE_${cc_src_language}_COMPILER_ID STREQUAL "MSVC")
string(APPEND _tmp2 "cl ")
if(MSVC)
list(APPEND cc_src_command "cl")
else()
string(APPEND _tmp2 "cc ")
list(APPEND cc_src_command "cc")
endif()
# C/CXX Standard
string(APPEND _tmp2 "${cc_src_std} ")
if(NOT "${cc_src_std}" STREQUAL "")
list(APPEND cc_src_command "${cc_src_std}")
endif()
# Global Flags
string(APPEND _tmp2 "${CMAKE_${cc_src_language}_FLAGS} ")
if(MSVC)
separate_arguments(cc_src_flags WINDOWS_COMMAND ${CMAKE_${cc_src_language}_FLAGS})
else()
separate_arguments(cc_src_flags UNIX_COMMAND ${CMAKE_${cc_src_language}_FLAGS})
endif()
foreach(flag ${cc_src_flags})
if(NOT "${flag}" STREQUAL "")
list(APPEND cc_src_command "${flag}")
endif()
endforeach()
set(cc_src_command_config "")
foreach(current_config ${cc_configurations})
string(TOUPPER "${current_config}" _tmp)
string(APPEND _tmp2 "$<$<CONFIG:${current_config}>:${CMAKE_${cc_src_language}_FLAGS_${_tmp}}> ")
endforeach()
# Include Directories
foreach(_tmp ${cc_src_includex})
file(TO_CMAKE_PATH "${_tmp}" _tmp)
json_escape_string(OUTPUT _tmp INPUT "${_tmp}")
string(APPEND _tmp2 "\"${_include_prefix}${_tmp}\" ")
string(TOUPPER "${current_config}" current_config_upper)
list(APPEND cc_src_command_config "$<$<CONFIG:${current_config}>:${CMAKE_${cc_src_language}_FLAGS_${current_config_upper}}>")
endforeach()
list(JOIN cc_src_command_config "" cc_src_command_config)
list(APPEND cc_src_command "${cc_src_command_config}")
# Definitions
foreach(_tmp ${cc_src_defines})
json_escape_string(OUTPUT _tmp INPUT "${_tmp}")
string(APPEND _tmp2 "\"${_define_prefix}${_tmp}\" ")
foreach(define ${cc_src_defines})
if(NOT "${define}" STREQUAL "")
list(APPEND cc_src_command "${_define_prefix}${define}")
endif()
endforeach()
# Other Options
foreach(_tmp ${cc_src_options})
json_escape_string(OUTPUT _tmp INPUT "${_tmp}")
string(APPEND _tmp2 "\"${_tmp}\" ")
foreach(option ${cc_src_options})
if(NOT "${option}" STREQUAL "")
list(APPEND cc_src_command "${option}")
endif()
endforeach()
# Include Directories
foreach(include ${cc_src_includex})
if(NOT "${include}" STREQUAL "")
file(TO_CMAKE_PATH "${include}" _tmp)
list(APPEND cc_src_command "${_include_prefix}${include}")
endif()
endforeach()
# File to compile
json_escape_string(OUTPUT _tmp INPUT "${cc_src_location}")
if(CMAKE_${cc_src_language}_COMPILER_ID STREQUAL "MSVC")
string(APPEND _tmp2 "\"${_tmp}\"")
json_escape_string(OUTPUT cc_src_location INPUT "${cc_src_location}")
if(MSVC)
list(APPEND cc_src_command "\"${cc_src_location}\"")
else()
string(APPEND _tmp2 "-c \"${_tmp}\"")
list(APPEND cc_src_command "-c \"${cc_src_location}\"")
endif()
# Command
json_escape_string(OUTPUT _tmp INPUT "${_tmp2}")
string(APPEND cc_json_content "\t\t\"command\": \"${_tmp}\"\n")
# Build actual command entry.
list(JOIN cc_src_command " " cc_src_command)
json_escape_string(OUTPUT _tmp INPUT "${cc_src_command}")
string(JSON cc_json_content_entry SET ${cc_json_content_entry} "command" \"${_tmp}\")
endif()
string(APPEND cc_json_content "\t},\n")
string(APPEND cc_json_content "${cc_json_content_entry},\n")
endforeach()
# Close the array.
@@ -473,7 +443,7 @@ function(generate_compile_commands_json)
endforeach()
unset(_tmp)
unset(_tmp2)
unset(cc_src_command)
unset(current_target)
unset(current_source)
unset(current_config)
@@ -484,7 +454,7 @@ function(clang_format)
cmake_parse_arguments(
PARSE_ARGV 0
_ARGS
"DEPENDENCY;GLOBAL"
"DEPENDENCY"
"REGEX;VERSION"
"TARGETS"
)
@@ -538,11 +508,13 @@ function(clang_format)
# Default Filter
if(NOT _ARGS_REGEX)
set(_ARGS_REGEX "\.(h|hpp|c|cpp)$")
set(_ARGS_REGEX "\\.(h|hpp|c|cpp)$")
endif()
# Go through each target
foreach(current_target ${_ARGS_TARGETS})
set(designed_target "${current_target}_clang-format")
get_target_property(target_sources_rel ${current_target} SOURCES)
set(target_sources "")
foreach(_tmp ${target_sources_rel})
@@ -557,27 +529,34 @@ function(clang_format)
get_filename_component(target_source_dir ${target_source_dir_rel} ABSOLUTE)
unset(target_source_dir_rel)
add_custom_target(${current_target}_clang-format
add_custom_target(${designed_target}
COMMAND "${CLANG_FORMAT_BIN}" -style=file -i ${target_sources}
COMMENT "clang-format: Formatting ${current_target}..."
WORKING_DIRECTORY "${target_source_dir}"
)
# IDE Folder
get_property(folder TARGET ${current_target} PROPERTY FOLDER)
set_target_properties(${current_target} PROPERTIES FOLDER "${folder}")
if(_ARGS_DEPENDENCY)
add_dependencies(${current_target} ${current_target}_clang-format)
# IDE Folder & Label
get_target_property(folder ${current_target} FOLDER)
get_target_property(label ${current_target} PROJECT_LABEL)
if(folder)
set_target_properties(${designed_target} PROPERTIES FOLDER ${folder})
else()
set_target_properties(${designed_target} PROPERTIES FOLDER Clang)
endif()
if(label)
set_target_properties(${designed_target} PROPERTIES PROJECT_LABEL "${label} (clang-format)")
else()
set_target_properties(${designed_target} PROPERTIES PROJECT_LABEL "${current_target} (clang-format)")
endif()
if(_ARGS_GLOBAL)
if(TARGET clang-format)
add_dependencies(clang-format ${current_target}_clang-format)
else()
if(_ARGS_DEPENDENCY)
add_dependencies(${current_target} ${designed_target})
endif()
if(NOT TARGET clang-format)
add_custom_target(clang-format
DEPENDS
${current_target}_clang-format
${designed_target}
COMMENT
"clang-format: Formatting..."
)
@@ -585,7 +564,7 @@ function(clang_format)
FOLDER Clang
)
endif()
endif()
add_dependencies(clang-format ${designed_target})
endforeach()
list(POP_BACK CMAKE_MESSAGE_INDENT)
endfunction()
@@ -595,7 +574,7 @@ list(APPEND CMAKE_MESSAGE_INDENT "[clang-tidy] ")
cmake_parse_arguments(
PARSE_ARGV 0
_ARGS
"DEPENDENCY;GLOBAL"
"DEPENDENCY"
"REGEX;VERSION"
"TARGETS"
)
@@ -649,42 +628,44 @@ list(APPEND CMAKE_MESSAGE_INDENT "[clang-tidy] ")
# Default Filter
if(NOT _ARGS_REGEX)
set(_ARGS_REGEX "\.(h|hpp|c|cpp)$")
set(_ARGS_REGEX "\\.(h|hpp|c|cpp)$")
endif()
# Go through each target
foreach(current_target ${_ARGS_TARGETS})
set(designed_target "${current_target}_clang-tidy")
# Source Directory
get_target_property(_tmp2 ${current_target} SOURCE_DIR)
get_filename_component(target_source_dir ${_tmp2} ABSOLUTE)
get_target_property(cc_src_command ${current_target} SOURCE_DIR)
get_filename_component(target_source_dir ${cc_src_command} ABSOLUTE)
file(TO_CMAKE_PATH "${target_source_dir}" target_source_dir_nat)
unset(_tmp2)
unset(cc_src_command)
# Binary Directory
get_target_property(_tmp2 ${current_target} BINARY_DIR)
get_filename_component(target_binary_dir ${_tmp2} ABSOLUTE)
get_target_property(cc_src_command ${current_target} BINARY_DIR)
get_filename_component(target_binary_dir ${cc_src_command} ABSOLUTE)
file(TO_CMAKE_PATH "${target_binary_dir}" target_binary_dir_nat)
unset(_tmp2)
unset(cc_src_command)
# Sources
get_target_property(_tmp2 ${current_target} SOURCES)
get_target_property(cc_src_command ${current_target} SOURCES)
set(target_sources "")
foreach(_tmp ${_tmp2})
foreach(_tmp ${cc_src_command})
get_filename_component(_tmp ${_tmp} ABSOLUTE)
file(TO_CMAKE_PATH "${_tmp}" _tmp)
list(APPEND target_sources "${_tmp}")
endforeach()
list(FILTER target_sources INCLUDE REGEX "${_ARGS_REGEX}")
unset(_tmp2)
unset(cc_src_command)
add_custom_target(${current_target}_clang-tidy
COMMENT "clang-tiy: Tidying ${current_target}..."
add_custom_target(${designed_target}
COMMENT "clang-tidy: Tidying ${current_target}..."
WORKING_DIRECTORY "${target_binary_dir}"
VERBATIM
)
foreach(_tmp ${target_sources})
add_custom_command(
TARGET ${current_target}_clang-tidy
TARGET ${designed_target}
POST_BUILD
COMMAND "${CLANG_TIDY_BIN}"
ARGS --quiet -p="$<TARGET_PROPERTY:${current_target},BINARY_DIR>/$<CONFIG>" "${_tmp}"
@@ -693,21 +674,28 @@ list(APPEND CMAKE_MESSAGE_INDENT "[clang-tidy] ")
)
endforeach()
# IDE Folder
get_property(folder TARGET ${current_target} PROPERTY FOLDER)
set_target_properties(${current_target} PROPERTIES FOLDER "${folder}")
if(_ARGS_DEPENDENCY)
add_dependencies(${current_target} ${current_target}_clang-tidy)
# IDE Folder & Label
get_target_property(folder ${current_target} FOLDER)
get_target_property(label ${current_target} PROJECT_LABEL)
if(folder)
set_target_properties(${designed_target} PROPERTIES FOLDER ${folder})
else()
set_target_properties(${designed_target} PROPERTIES FOLDER Clang)
endif()
if(label)
set_target_properties(${designed_target} PROPERTIES PROJECT_LABEL "${label} (clang-tidy)")
else()
set_target_properties(${designed_target} PROPERTIES PROJECT_LABEL "${current_target} (clang-tidy)")
endif()
if(_ARGS_GLOBAL)
if(TARGET clang-tidy)
add_dependencies(clang-tidy ${current_target}_clang-format)
else()
if(_ARGS_DEPENDENCY)
add_dependencies(${current_target} ${designed_target})
endif()
if(NOT TARGET clang-tidy)
add_custom_target(clang-tidy
DEPENDS
${current_target}_clang-tidy
${designed_target}
COMMENT
"clang-tiy: Tidying..."
)
@@ -715,7 +703,7 @@ list(APPEND CMAKE_MESSAGE_INDENT "[clang-tidy] ")
FOLDER Clang
)
endif()
endif()
add_dependencies(clang-tidy ${designed_target})
endforeach()
list(POP_BACK CMAKE_MESSAGE_INDENT)
endfunction()