FindBacktrace.cmake 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #.rst:
  2. # FindBacktrace
  3. # -------------
  4. #
  5. # Find provider for backtrace(3).
  6. #
  7. # Checks if OS supports backtrace(3) via either libc or custom library.
  8. # This module defines the following variables::
  9. #
  10. # Backtrace_HEADER - The header file needed for backtrace(3). Cached.
  11. # Could be forcibly set by user.
  12. # Backtrace_INCLUDE_DIRS - The include directories needed to use backtrace(3) header.
  13. # Backtrace_LIBRARIES - The libraries (linker flags) needed to use backtrace(3), if any.
  14. # Backtrace_FOUND - Is set if and only if backtrace(3) support detected.
  15. #
  16. # The following cache variables are also available to set or use::
  17. #
  18. # Backtrace_LIBRARY - The external library providing backtrace, if any.
  19. # Backtrace_INCLUDE_DIR - The directory holding the backtrace(3) header.
  20. #
  21. # Typical usage is to generate of header file using configure_file() with the
  22. # contents like the following::
  23. #
  24. # #cmakedefine01 Backtrace_FOUND
  25. # #if Backtrace_FOUND
  26. # # include <${Backtrace_HEADER}>
  27. # #endif
  28. #
  29. # And then reference that generated header file in actual source.
  30. #=============================================================================
  31. # Copyright 2013 Vadim Zhukov
  32. #
  33. # Distributed under the OSI-approved BSD License (the "License");
  34. # see accompanying file Copyright.txt for details.
  35. #
  36. # This software is distributed WITHOUT ANY WARRANTY; without even the
  37. # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  38. # See the License for more information.
  39. #=============================================================================
  40. # (To distribute this file outside of CMake, substitute the full
  41. # License text for the above reference.)
  42. include(CMakePushCheckState)
  43. include(CheckSymbolExists)
  44. include(FindPackageHandleStandardArgs)
  45. # List of variables to be provided to find_package_handle_standard_args()
  46. set(_Backtrace_STD_ARGS Backtrace_INCLUDE_DIR)
  47. if(Backtrace_HEADER)
  48. set(_Backtrace_HEADER_TRY "${Backtrace_HEADER}")
  49. else(Backtrace_HEADER)
  50. set(_Backtrace_HEADER_TRY "execinfo.h")
  51. endif(Backtrace_HEADER)
  52. find_path(Backtrace_INCLUDE_DIR "${_Backtrace_HEADER_TRY}")
  53. set(Backtrace_INCLUDE_DIRS ${Backtrace_INCLUDE_DIR})
  54. # First, check if we already have backtrace(), e.g., in libc
  55. cmake_push_check_state(RESET)
  56. set(CMAKE_REQUIRED_INCLUDES ${Backtrace_INCLUDE_DIRS})
  57. check_symbol_exists("backtrace" "${_Backtrace_HEADER_TRY}" _Backtrace_SYM_FOUND)
  58. cmake_pop_check_state()
  59. if(_Backtrace_SYM_FOUND)
  60. set(Backtrace_LIBRARY)
  61. if(NOT Backtrace_FIND_QUIETLY)
  62. message(STATUS "backtrace facility detected in default set of libraries")
  63. endif()
  64. else()
  65. # Check for external library, for non-glibc systems
  66. if(Backtrace_INCLUDE_DIR)
  67. # OpenBSD has libbacktrace renamed to libexecinfo
  68. find_library(Backtrace_LIBRARY "execinfo")
  69. elseif() # respect user wishes
  70. set(_Backtrace_HEADER_TRY "backtrace.h")
  71. find_path(Backtrace_INCLUDE_DIR ${_Backtrace_HEADER_TRY})
  72. find_library(Backtrace_LIBRARY "backtrace")
  73. endif()
  74. # Prepend list with library path as it's more common practice
  75. set(_Backtrace_STD_ARGS Backtrace_LIBRARY ${_Backtrace_STD_ARGS})
  76. endif()
  77. set(Backtrace_LIBRARIES ${Backtrace_LIBRARY})
  78. set(Backtrace_HEADER "${_Backtrace_HEADER_TRY}" CACHE STRING "Header providing backtrace(3) facility")
  79. find_package_handle_standard_args(Backtrace FOUND_VAR Backtrace_FOUND REQUIRED_VARS ${_Backtrace_STD_ARGS})
  80. mark_as_advanced(Backtrace_HEADER Backtrace_INCLUDE_DIR Backtrace_LIBRARY)