Skip to content

Commit

Permalink
Merge pull request #671 from LLNL/feature/dayton8/system_includes
Browse files Browse the repository at this point in the history
Revamp blt_convert_to_system_includes
  • Loading branch information
kennyweiss authored Sep 4, 2024
2 parents eb0acb3 + b647cd8 commit 45494b6
Show file tree
Hide file tree
Showing 5 changed files with 177 additions and 83 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
*.code-workspace
*.swp
3 changes: 3 additions & 0 deletions RELEASE-NOTES.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ The project release numbers follow [Semantic Versioning](http://semver.org/spec/

## [Unreleased] - Release date yyyy-mm-dd

### Changed
- Modified `blt_convert_to_system_includes` to handle multiple targets and recursively update includes for dependencies

### Fixed
- Removed GoogleTest, GoogleMock, and GoogleBenchmarks calling CMake's `GNUInstallDirs`
which was causing non-deterministic install variables depending on your combination of
Expand Down
165 changes: 147 additions & 18 deletions cmake/BLTInstallableMacros.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -428,37 +428,166 @@ endmacro(blt_add_target_compile_flags)


##------------------------------------------------------------------------------
## blt_convert_to_system_includes(TARGET <target>)
## blt_find_target_dependencies(TARGET <target> TLIST <list name>)
##
## Converts existing interface includes to system interface includes.
## Store all target's dependencies (link libraries and interface link libraries)
## recursively in the variable name TLIST holds.
##------------------------------------------------------------------------------
macro(blt_convert_to_system_includes)
macro(blt_find_target_dependencies)
set(options)
set(singleValuedArgs TARGET)
set(singleValuedArgs TARGET TLIST)
set(multiValuedArgs)

## parse the arguments to the macro
# parse the arguments to the macro
cmake_parse_arguments(arg
"${options}" "${singleValuedArgs}" "${multiValuedArgs}" ${ARGN})

# check for required arguments
if(NOT DEFINED arg_TARGET)
message(FATAL_ERROR "TARGET is a required parameter for the blt_convert_to_system_includes macro.")
message(FATAL_ERROR "TARGET is a required parameter for the blt_find_target_dependencies macro")
endif()

# PGI does not support -isystem
if(NOT "${CMAKE_CXX_COMPILER_ID}" STREQUAL "PGI")
get_target_property(_include_dirs ${arg_TARGET} INTERFACE_INCLUDE_DIRECTORIES)
# Don't copy if the target had no include directories
if(_include_dirs)
# Clear previous value in INTERFACE_INCLUDE_DIRECTORIES so it is not doubled
# by target_include_directories
set_property(TARGET ${arg_TARGET} PROPERTY INTERFACE_INCLUDE_DIRECTORIES)
target_include_directories(${arg_TARGET} SYSTEM INTERFACE ${_include_dirs})
if(NOT DEFINED arg_TLIST OR NOT DEFINED ${arg_TLIST})
message(FATAL_ERROR "TLIST is a required parameter for the blt_find_target_dependencies macro")
endif()

set(_depends_on "")

# Get dependencies if BLT registered library
string(TOUPPER ${arg_TARGET} _target_upper)
if(_BLT_${_target_upper}_IS_REGISTERED_LIBRARY)
list(APPEND _depends_on "${_BLT_${_target_upper}_DEPENDS_ON}")
endif()
unset(_target_upper)

# Get dependencies if CMake target
if(TARGET ${arg_TARGET})
get_property(_target_type TARGET ${arg_TARGET} PROPERTY TYPE)
if(NOT "${_target_type}" STREQUAL "INTERFACE_LIBRARY")
get_target_property(_propval ${arg_TARGET} LINK_LIBRARIES)
if(_propval)
list(APPEND _depends_on ${_propval})
endif()
endif()

# get interface link libraries
get_target_property(_propval ${arg_TARGET} INTERFACE_LINK_LIBRARIES)
if (_propval)
list(APPEND _depends_on ${_propval})
endif()
endif()

blt_list_remove_duplicates(TO _depends_on)
foreach(t ${_depends_on})
if (NOT "${t}" IN_LIST ${arg_TLIST})
list(APPEND ${arg_TLIST} ${t})
blt_find_target_dependencies(TARGET ${t} TLIST ${arg_TLIST})
endif()
endforeach()

unset(_depends_on)
endmacro(blt_find_target_dependencies)


##------------------------------------------------------------------------------
## blt_convert_to_system_includes(TARGET <target>
## TARGETS [<target>...]
## CHILDREN [TRUE|FALSE]
## [QUIET])
##
## Converts existing interface includes to system interface includes.
##
## Note: The argument ``TARGET`` will be deprecated in the near future. Until then,
## if both ``TARGET`` and ``TARGETS`` is given, all given target include
## directories will be converted.
##
##------------------------------------------------------------------------------
function(blt_convert_to_system_includes)
set(options QUIET)
set(singleValuedArgs CHILDREN TARGET)
set(multiValuedArgs TARGETS)

## parse the arguments to the macro
cmake_parse_arguments(arg
"${options}" "${singleValuedArgs}" "${multiValuedArgs}" ${ARGN})

if(NOT DEFINED arg_TARGET AND NOT DEFINED arg_TARGETS)
message(FATAL_ERROR "Neither required TARGET or TARGETS parameters for the blt_convert_to_system_includes macro were provided.")
endif()

if(DEFINED arg_TARGET)
list(APPEND arg_TARGETS ${arg_TARGET})
endif()

if(NOT DEFINED arg_TARGETS)
message(FATAL_ERROR "TARGETS is a required parameter for the blt_convert_to_system_includes macro.")
endif()

if(NOT DEFINED arg_CHILDREN)
set(arg_CHILDREN FALSE)
endif()

unset(_include_dirs)
endmacro()
# PGI does not support -isystem
if(NOT "${CMAKE_CXX_COMPILER_ID}" STREQUAL "PGI")
set(_target_list "")

foreach(_target ${arg_TARGETS})
string(TOUPPER ${_target} _target_upper)

if(TARGET ${_target} OR _BLT_${_target_upper}_IS_REGISTERED_LIBRARY)
if(${arg_CHILDREN})
blt_find_target_dependencies(TARGET ${_target} TLIST _target_list)
endif()

list(APPEND _target_list ${_target})
elseif(NOT ${arg_QUIET)
message(WARNING "${_target} does not exist!")
endif()

unset(_target_upper)
endforeach()

blt_list_remove_duplicates(TO _target_list)

foreach(_target ${_target_list})
if(TARGET ${_target})
# Handle CMake target
get_target_property(_interface_include_dirs
${_target}
INTERFACE_INCLUDE_DIRECTORIES)

# Don't update properties if the target had no interface include directories
if(_interface_include_dirs)
# Clear previous value in INTERFACE_INCLUDE_DIRECTORIES
# so it is not doubled by target_include_directories
set_target_properties(${_target}
PROPERTIES
INTERFACE_INCLUDE_DIRECTORIES "")

target_include_directories(${_target}
SYSTEM
INTERFACE
${_interface_include_dirs})
endif()

unset(_interface_include_dirs)
else()
string(TOUPPER ${_target} _target_upper)

if(_BLT_${_target_upper}_IS_REGISTERED_LIBRARY)
# Handle BLT registered target
set(_BLT_${_target_upper}_TREAT_INCLUDES_AS_SYSTEM TRUE)
endif()

unset(_target_upper)
endif()
endforeach()

unset(_target_list)
elseif(NOT ${arg_QUIET})
message(WARNING "PGI compiler does not support system includes")
endif()
endfunction(blt_convert_to_system_includes)


##------------------------------------------------------------------------------
Expand Down Expand Up @@ -541,7 +670,7 @@ macro(blt_patch_target)
endif()

if(${arg_TREAT_INCLUDES_AS_SYSTEM})
blt_convert_to_system_includes(TARGET ${arg_NAME})
blt_convert_to_system_includes(TARGETS ${arg_NAME})
endif()

# FIXME: Is this all that's needed?
Expand Down
62 changes: 0 additions & 62 deletions cmake/BLTPrivateMacros.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -678,65 +678,3 @@ macro(blt_print_target_properties_private)
unset(_is_blt_registered_target)
unset(_is_cmake_target)
endmacro(blt_print_target_properties_private)

##------------------------------------------------------------------------------
## blt_find_target_dependencies(TARGET <target> TLIST <list name>)
##
## Store all target's dependencies (link libraries and interface link libraries)
## recursively in the variable name TLIST holds.
##------------------------------------------------------------------------------
macro(blt_find_target_dependencies)

set(options)
set(singleValuedArgs TARGET TLIST)
set(multiValuedArgs)

# parse the arguments to the macro
cmake_parse_arguments(arg
"${options}" "${singleValuedArgs}" "${multiValuedArgs}" ${ARGN})

# check for required arguments
if(NOT DEFINED arg_TARGET)
message(FATAL_ERROR "TARGET is a required parameter for the blt_find_target_dependencies macro")
endif()

if(NOT DEFINED arg_TLIST OR NOT DEFINED ${arg_TLIST})
message(FATAL_ERROR "TLIST is a required parameter for the blt_find_target_dependencies macro")
endif()

set(_depends_on "")

# Get dependencies if BLT registered library
string(TOUPPER ${arg_TARGET} _target_upper)
if(_BLT_${_target_upper}_IS_REGISTERED_LIBRARY)
list(APPEND _depends_on "${_BLT_${_target_upper}_DEPENDS_ON}")
endif()

# Get dependencies if CMake target
if(TARGET ${arg_TARGET})
get_property(_target_type TARGET ${arg_TARGET} PROPERTY TYPE)
if(NOT "${_target_type}" STREQUAL "INTERFACE_LIBRARY")
get_target_property(_propval ${arg_TARGET} LINK_LIBRARIES)
if(_propval)
list(APPEND _depends_on ${_propval})
endif()
endif()

# get interface link libraries
get_target_property(_propval ${arg_TARGET} INTERFACE_LINK_LIBRARIES)
if (_propval)
list(APPEND _depends_on ${_propval})
endif()
endif()

blt_list_remove_duplicates(TO _depends_on)
foreach(t ${_depends_on})
if (NOT "${t}" IN_LIST ${arg_TLIST})
list(APPEND ${arg_TLIST} ${t})
blt_find_target_dependencies(TARGET ${t} TLIST ${arg_TLIST})
endif()
endforeach()

unset(_depends_on)

endmacro(blt_find_target_dependencies)
29 changes: 26 additions & 3 deletions docs/api/utility.rst
Original file line number Diff line number Diff line change
Expand Up @@ -215,21 +215,44 @@ command but doesn't throw an error if the list is empty or not defined.
set(mylist A B A)
blt_list_remove_duplicates( TO mylist )
.. _blt_find_target_dependencies:

blt_find_target_dependencies
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

.. code-block:: cmake
set(_target_list "")
blt_find_target_dependencies(TARGET <target> TLIST _target_list)
Recursively adds all link libraries and interface link libraries of the given
target to the given list. Handles CMake targets and BLT registered libraries.

.. _blt_convert_to_system_includes:

blt_convert_to_system_includes
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

.. code-block:: cmake
blt_convert_to_system_includes(TARGET <target>)
blt_convert_to_system_includes(TARGET <target>
TARGETS [<target>...]
CHILDREN [TRUE | FALSE (default)]
[QUIET])
Converts existing interface includes to system interface includes.
Warns if a target does not exist unless ``QUIET`` is specified.
Recurses through link libraries and interface link libraries if
``CHILDREN TRUE`` is specified.

.. note::
The argument ``TARGET`` will be deprecated in the near future. Until then,
if both ``TARGET`` and ``TARGETS`` is given, all given target include
directories will be converted.

.. code-block:: cmake
:caption: **Example**
:linenos:
## convert to system includes for the foo target
blt_convert_to_system_includes(TARGET foo)
blt_convert_to_system_includes(TARGETS foo)

0 comments on commit 45494b6

Please sign in to comment.