diff options
author | Dimitri John Ledkov <xnox@ubuntu.com> | 2019-12-03 18:23:53 +0000 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2019-12-05 15:06:44 +0100 |
commit | 110faf3a34f50ca9bc4a736688dda3ea5c931655 (patch) | |
tree | 2509d7acae1ed6796ddda155c339bd9e08256d20 /cmake/FindPackageMessage.cmake | |
parent | 95237941b66931978953fadb390e1b442ed63175 (diff) | |
download | fork-ledger-110faf3a34f50ca9bc4a736688dda3ea5c931655.tar.gz fork-ledger-110faf3a34f50ca9bc4a736688dda3ea5c931655.tar.bz2 fork-ledger-110faf3a34f50ca9bc4a736688dda3ea5c931655.zip |
Cherrypick FindPython module from cmake 3.15, introduced in 3.12.
Diffstat (limited to 'cmake/FindPackageMessage.cmake')
-rw-r--r-- | cmake/FindPackageMessage.cmake | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/cmake/FindPackageMessage.cmake b/cmake/FindPackageMessage.cmake new file mode 100644 index 00000000..0628b981 --- /dev/null +++ b/cmake/FindPackageMessage.cmake @@ -0,0 +1,48 @@ +# Distributed under the OSI-approved BSD 3-Clause License. See accompanying +# file Copyright.txt or https://cmake.org/licensing for details. + +#[=======================================================================[.rst: +FindPackageMessage +------------------ + +.. code-block:: cmake + + find_package_message(<name> "message for user" "find result details") + +This function is intended to be used in FindXXX.cmake modules files. +It will print a message once for each unique find result. This is +useful for telling the user where a package was found. The first +argument specifies the name (XXX) of the package. The second argument +specifies the message to display. The third argument lists details +about the find result so that if they change the message will be +displayed again. The macro also obeys the QUIET argument to the +find_package command. + +Example: + +.. code-block:: cmake + + if(X11_FOUND) + find_package_message(X11 "Found X11: ${X11_X11_LIB}" + "[${X11_X11_LIB}][${X11_INCLUDE_DIR}]") + else() + ... + endif() +#]=======================================================================] + +function(find_package_message pkg msg details) + # Avoid printing a message repeatedly for the same find result. + if(NOT ${pkg}_FIND_QUIETLY) + string(REPLACE "\n" "" details "${details}") + set(DETAILS_VAR FIND_PACKAGE_MESSAGE_DETAILS_${pkg}) + if(NOT "${details}" STREQUAL "${${DETAILS_VAR}}") + # The message has not yet been printed. + message(STATUS "${msg}") + + # Save the find details in the cache to avoid printing the same + # message again. + set("${DETAILS_VAR}" "${details}" + CACHE INTERNAL "Details about finding ${pkg}") + endif() + endif() +endfunction() |