mirror of
https://github.com/Kitware/CMake.git
synced 2025-12-30 10:20:56 -06:00
- Added intro code block showing how to include this module. - Used "commands" instead of "functions". - Reworded descriptions a bit.
213 lines
5.3 KiB
CMake
213 lines
5.3 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
CMakePrintHelpers
|
|
-----------------
|
|
|
|
This module provides convenience commands, primarily intended for debugging,
|
|
to print the values of properties and variables.
|
|
|
|
Load this module in CMake with:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CMakePrintHelpers)
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following commands:
|
|
|
|
.. command:: cmake_print_properties
|
|
|
|
Prints the values of properties for the specified targets, source files,
|
|
directories, tests, or cache entries:
|
|
|
|
.. code-block:: cmake
|
|
|
|
cmake_print_properties(
|
|
<TARGETS [<targets>...] |
|
|
SOURCES [<sources>...] |
|
|
DIRECTORIES [<dirs>...] |
|
|
TESTS [<tests>...] |
|
|
CACHE_ENTRIES [<entries>...] >
|
|
PROPERTIES [<properties>...]
|
|
)
|
|
|
|
Exactly one of the scope keywords must be specified. The scope keyword
|
|
and its arguments must appear before the ``PROPERTIES`` keyword in the
|
|
argument list.
|
|
|
|
.. command:: cmake_print_variables
|
|
|
|
Prints each variable name followed by its value:
|
|
|
|
.. code-block:: cmake
|
|
|
|
cmake_print_variables([<vars>...])
|
|
|
|
Examples
|
|
^^^^^^^^
|
|
|
|
Printing the ``LOCATION`` and ``INTERFACE_INCLUDE_DIRECTORIES`` properties for
|
|
both targets ``foo`` and ``bar``:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CMakePrintHelpers)
|
|
|
|
cmake_print_properties(
|
|
TARGETS foo bar
|
|
PROPERTIES LOCATION INTERFACE_INCLUDE_DIRECTORIES
|
|
)
|
|
|
|
Gives::
|
|
|
|
--
|
|
Properties for TARGET foo:
|
|
foo.LOCATION = "/usr/lib/libfoo.so"
|
|
foo.INTERFACE_INCLUDE_DIRECTORIES = "/usr/include;/usr/include/foo"
|
|
Properties for TARGET bar:
|
|
bar.LOCATION = "/usr/lib/libbar.so"
|
|
bar.INTERFACE_INCLUDE_DIRECTORIES = "/usr/include;/usr/include/bar"
|
|
|
|
Printing given variables:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CMakePrintHelpers)
|
|
|
|
cmake_print_variables(CMAKE_C_COMPILER CMAKE_MAJOR_VERSION NOT_EXISTS)
|
|
|
|
Gives::
|
|
|
|
-- CMAKE_C_COMPILER="/usr/bin/cc" ; CMAKE_MAJOR_VERSION="3" ; NOT_EXISTS=""
|
|
#]=======================================================================]
|
|
|
|
function(cmake_print_variables)
|
|
set(msg "")
|
|
foreach(var ${ARGN})
|
|
if(msg)
|
|
string(APPEND msg " ; ")
|
|
endif()
|
|
string(APPEND msg "${var}=\"${${var}}\"")
|
|
endforeach()
|
|
message(STATUS "${msg}")
|
|
endfunction()
|
|
|
|
|
|
function(cmake_print_properties)
|
|
set(options )
|
|
set(oneValueArgs )
|
|
set(cpp_multiValueArgs PROPERTIES )
|
|
set(cppmode_multiValueArgs TARGETS SOURCES TESTS DIRECTORIES CACHE_ENTRIES )
|
|
|
|
string(JOIN " " _mode_names ${cppmode_multiValueArgs})
|
|
set(_missing_mode_message
|
|
"Mode keyword missing in cmake_print_properties() call, there must be exactly one of ${_mode_names}")
|
|
|
|
cmake_parse_arguments(
|
|
CPP "${options}" "${oneValueArgs}" "${cpp_multiValueArgs}" ${ARGN})
|
|
|
|
if(NOT CPP_PROPERTIES)
|
|
message(FATAL_ERROR
|
|
"Required argument PROPERTIES missing in cmake_print_properties() call")
|
|
return()
|
|
endif()
|
|
|
|
if(NOT CPP_UNPARSED_ARGUMENTS)
|
|
message(FATAL_ERROR "${_missing_mode_message}")
|
|
return()
|
|
endif()
|
|
|
|
cmake_parse_arguments(
|
|
CPPMODE "${options}" "${oneValueArgs}" "${cppmode_multiValueArgs}"
|
|
${CPP_UNPARSED_ARGUMENTS})
|
|
|
|
if(CPPMODE_UNPARSED_ARGUMENTS)
|
|
message(FATAL_ERROR
|
|
"Unknown keywords given to cmake_print_properties(): \"${CPPMODE_UNPARSED_ARGUMENTS}\"")
|
|
return()
|
|
endif()
|
|
|
|
set(mode)
|
|
set(items)
|
|
set(keyword)
|
|
|
|
if(CPPMODE_TARGETS)
|
|
set(items ${CPPMODE_TARGETS})
|
|
set(mode ${mode} TARGETS)
|
|
set(keyword TARGET)
|
|
endif()
|
|
|
|
if(CPPMODE_SOURCES)
|
|
set(items ${CPPMODE_SOURCES})
|
|
set(mode ${mode} SOURCES)
|
|
set(keyword SOURCE)
|
|
endif()
|
|
|
|
if(CPPMODE_TESTS)
|
|
set(items ${CPPMODE_TESTS})
|
|
set(mode ${mode} TESTS)
|
|
set(keyword TEST)
|
|
endif()
|
|
|
|
if(CPPMODE_DIRECTORIES)
|
|
set(items ${CPPMODE_DIRECTORIES})
|
|
set(mode ${mode} DIRECTORIES)
|
|
set(keyword DIRECTORY)
|
|
endif()
|
|
|
|
if(CPPMODE_CACHE_ENTRIES)
|
|
set(items ${CPPMODE_CACHE_ENTRIES})
|
|
set(mode ${mode} CACHE_ENTRIES)
|
|
# This is a workaround for the fact that passing `CACHE` as an argument to
|
|
# set() causes a cache variable to be set.
|
|
set(keyword "")
|
|
string(APPEND keyword CACHE)
|
|
endif()
|
|
|
|
if(NOT mode)
|
|
message(FATAL_ERROR "${_missing_mode_message}")
|
|
return()
|
|
endif()
|
|
|
|
list(LENGTH mode modeLength)
|
|
if("${modeLength}" GREATER 1)
|
|
message(FATAL_ERROR
|
|
"Multiple mode keywords used in cmake_print_properties() call, there must be exactly one of ${_mode_names}.")
|
|
return()
|
|
endif()
|
|
|
|
set(msg "\n")
|
|
foreach(item ${items})
|
|
|
|
set(itemExists TRUE)
|
|
if(keyword STREQUAL "TARGET")
|
|
if(NOT TARGET ${item})
|
|
set(itemExists FALSE)
|
|
string(APPEND msg "\n No such TARGET \"${item}\" !\n\n")
|
|
endif()
|
|
endif()
|
|
|
|
if (itemExists)
|
|
string(APPEND msg " Properties for ${keyword} ${item}:\n")
|
|
foreach(prop ${CPP_PROPERTIES})
|
|
|
|
get_property(propertySet ${keyword} ${item} PROPERTY "${prop}" SET)
|
|
|
|
if(propertySet)
|
|
get_property(property ${keyword} ${item} PROPERTY "${prop}")
|
|
string(APPEND msg " ${item}.${prop} = \"${property}\"\n")
|
|
else()
|
|
string(APPEND msg " ${item}.${prop} = <NOTFOUND>\n")
|
|
endif()
|
|
endforeach()
|
|
endif()
|
|
|
|
endforeach()
|
|
message(STATUS "${msg}")
|
|
|
|
endfunction()
|