WriteBasicConfigVersionFile.cmake 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # WRITE_BASIC_CONFIG_VERSION_FILE( filename VERSION major.minor.patch COMPATIBILITY (AnyNewerVersion|SameMajorVersion) )
  2. #
  3. # Writes a file for use as <package>ConfigVersion.cmake file to <filename>.
  4. # See the documentation of FIND_PACKAGE() for details on this.
  5. # filename is the output filename, it should be in the build tree.
  6. # major.minor.patch is the version number of the project to be installed
  7. # The COMPATIBILITY mode AnyNewerVersion means that the installed package version
  8. # will be considered compatible if it is newer or exactly the same as the requested version.
  9. # If SameMajorVersion is used instead, then the behaviour differs from AnyNewerVersion
  10. # in that the major version number must be the same as requested, e.g. version 2.0 will
  11. # not be considered compatible if 1.0 is requested.
  12. # If your project has more elaborated version matching rules, you will need to write your
  13. # own custom ConfigVersion.cmake file instead of using this macro.
  14. #
  15. # Example:
  16. # write_basic_config_version_file(${CMAKE_CURRENT_BINARY_DIR}/FooConfigVersion.cmake
  17. # VERSION 1.2.3
  18. # COMPATIBILITY SameMajorVersion )
  19. # install(FILES ${CMAKE_CURRENT_BINARY_DIR}/FooConfigVersion.cmake
  20. # ${CMAKE_CURRENT_BINARY_DIR}/FooConfig.cmake
  21. # DESTINATION lib/cmake/Foo )
  22. #
  23. # Internally, this macro executes configure_file() to create the resulting
  24. # version file. Depending on the COMPATIBLITY, either the file
  25. # BasicConfigVersion-SameMajorVersion.cmake.in or BasicConfigVersion-AnyNewerVersion.cmake.in
  26. # is used. Please note that these two files are internal to CMake and you should
  27. # not call configure_file() on them yourself, but they can be used as starting
  28. # point to create more sophisticted custom ConfigVersion.cmake files.
  29. #=============================================================================
  30. # Copyright 2008-2011 Alexander Neundorf, <[email protected]>
  31. # Copyright 2004-2009 Kitware, Inc.
  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(CMakeParseArguments)
  43. function(WRITE_BASIC_CONFIG_VERSION_FILE _filename)
  44. set(options )
  45. set(oneValueArgs VERSION COMPATIBILITY )
  46. set(multiValueArgs )
  47. cmake_parse_arguments(CVF "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
  48. if(CVF_UNPARSED_ARGUMENTS)
  49. message(FATAL_ERROR "Unknown keywords given to WRITE_BASIC_CONFIG_VERSION_FILE(): \"${CVF_UNPARSED_ARGUMENTS}\"")
  50. endif(CVF_UNPARSED_ARGUMENTS)
  51. set(versionTemplateFile "${CMAKE_ROOT}/Modules/BasicConfigVersion-${CVF_COMPATIBILITY}.cmake.in")
  52. if(NOT EXISTS "${versionTemplateFile}")
  53. message(FATAL_ERROR "Bad COMPATIBILITY value used for WRITE_BASIC_CONFIG_VERSION_FILE(): \"${CVF_COMPATIBILITY}\"")
  54. endif()
  55. if("${CVF_VERSION}" STREQUAL "")
  56. message(FATAL_ERROR "No VERSION specified for WRITE_BASIC_CONFIG_VERSION_FILE()")
  57. endif()
  58. configure_file("${versionTemplateFile}" "${_filename}" @ONLY)
  59. endfunction(WRITE_BASIC_CONFIG_VERSION_FILE)