FindBacktrace.cmake 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. # Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. # file Copyright.txt or https://cmake.org/licensing for details.
  3. #[=======================================================================[.rst:
  4. FindBacktrace
  5. -------------
  6. Find provider for `backtrace(3) <https://man7.org/linux/man-pages/man3/backtrace.3.html>`__.
  7. Checks if OS supports ``backtrace(3)`` via either ``libc`` or custom library.
  8. This module defines the following variables:
  9. ``Backtrace_HEADER``
  10. The header file needed for ``backtrace(3)``. Cached.
  11. Could be forcibly set by user.
  12. ``Backtrace_INCLUDE_DIRS``
  13. The include directories needed to use ``backtrace(3)`` header.
  14. ``Backtrace_LIBRARIES``
  15. The libraries (linker flags) needed to use ``backtrace(3)``, if any.
  16. ``Backtrace_FOUND``
  17. Is set if and only if ``backtrace(3)`` support detected.
  18. The following cache variables are also available to set or use:
  19. ``Backtrace_LIBRARY``
  20. The external library providing backtrace, if any.
  21. ``Backtrace_INCLUDE_DIR``
  22. The directory holding the ``backtrace(3)`` header.
  23. Typical usage is to generate of header file using :command:`configure_file`
  24. with the contents like the following::
  25. #cmakedefine01 Backtrace_FOUND
  26. #if Backtrace_FOUND
  27. # include <${Backtrace_HEADER}>
  28. #endif
  29. And then reference that generated header file in actual source.
  30. Imported Targets
  31. ^^^^^^^^^^^^^^^^
  32. .. versionadded:: 3.30
  33. This module defines the following :prop_tgt:`IMPORTED` targets:
  34. ``Backtrace::Backtrace``
  35. An interface library providing usage requirements for the found components.
  36. #]=======================================================================]
  37. include(CMakePushCheckState)
  38. include(CheckSymbolExists)
  39. include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake)
  40. # List of variables to be provided to find_package_handle_standard_args()
  41. set(_Backtrace_STD_ARGS Backtrace_INCLUDE_DIR)
  42. if(Backtrace_HEADER)
  43. set(_Backtrace_HEADER_TRY "${Backtrace_HEADER}")
  44. else(Backtrace_HEADER)
  45. set(_Backtrace_HEADER_TRY "execinfo.h")
  46. endif(Backtrace_HEADER)
  47. find_path(Backtrace_INCLUDE_DIR "${_Backtrace_HEADER_TRY}")
  48. set(Backtrace_INCLUDE_DIRS ${Backtrace_INCLUDE_DIR})
  49. if (NOT DEFINED Backtrace_LIBRARY)
  50. # First, check if we already have backtrace(), e.g., in libc
  51. cmake_push_check_state(RESET)
  52. set(CMAKE_REQUIRED_INCLUDES ${Backtrace_INCLUDE_DIRS})
  53. set(CMAKE_REQUIRED_QUIET ${Backtrace_FIND_QUIETLY})
  54. check_symbol_exists("backtrace" "${_Backtrace_HEADER_TRY}" _Backtrace_SYM_FOUND)
  55. cmake_pop_check_state()
  56. endif()
  57. if(_Backtrace_SYM_FOUND)
  58. # Avoid repeating the message() call below each time CMake is run.
  59. if(NOT Backtrace_FIND_QUIETLY AND NOT DEFINED Backtrace_LIBRARY)
  60. message(STATUS "backtrace facility detected in default set of libraries")
  61. endif()
  62. set(Backtrace_LIBRARY "" CACHE FILEPATH "Library providing backtrace(3), empty for default set of libraries")
  63. else()
  64. # Check for external library, for non-glibc systems
  65. if(Backtrace_INCLUDE_DIR)
  66. # OpenBSD has libbacktrace renamed to libexecinfo
  67. find_library(Backtrace_LIBRARY "execinfo")
  68. else() # respect user wishes
  69. set(_Backtrace_HEADER_TRY "backtrace.h")
  70. find_path(Backtrace_INCLUDE_DIR ${_Backtrace_HEADER_TRY})
  71. find_library(Backtrace_LIBRARY "backtrace")
  72. endif()
  73. # Prepend list with library path as it's more common practice
  74. set(_Backtrace_STD_ARGS Backtrace_LIBRARY ${_Backtrace_STD_ARGS})
  75. endif()
  76. set(Backtrace_LIBRARIES ${Backtrace_LIBRARY})
  77. set(Backtrace_HEADER "${_Backtrace_HEADER_TRY}" CACHE STRING "Header providing backtrace(3) facility")
  78. find_package_handle_standard_args(Backtrace REQUIRED_VARS ${_Backtrace_STD_ARGS})
  79. mark_as_advanced(Backtrace_HEADER Backtrace_INCLUDE_DIR Backtrace_LIBRARY)
  80. if(Backtrace_FOUND AND NOT TARGET Backtrace::Backtrace)
  81. if(Backtrace_LIBRARY)
  82. add_library(Backtrace::Backtrace UNKNOWN IMPORTED)
  83. set_property(TARGET Backtrace::Backtrace PROPERTY IMPORTED_LOCATION "${Backtrace_LIBRARY}")
  84. else()
  85. add_library(Backtrace::Backtrace INTERFACE IMPORTED)
  86. target_link_libraries(Backtrace::Backtrace INTERFACE ${Backtrace_LIBRARIES})
  87. endif()
  88. target_include_directories(Backtrace::Backtrace INTERFACE ${Backtrace_INCLUDE_DIRS})
  89. endif()