summaryrefslogtreecommitdiffstats
path: root/Modules/Internal/CPack/CPackExternal.cmake
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2018-11-06 16:29:46 (GMT)
committerKitware Robot <kwrobot@kitware.com>2018-11-06 16:30:27 (GMT)
commit1674a5b0a4c2432b9fe7c8ceb4287312c46ad763 (patch)
tree49c6b4abf6224454d36a56f90f82901209dfe81a /Modules/Internal/CPack/CPackExternal.cmake
parentc752edfcb39e53edb972374eff795f027f85b4c7 (diff)
parent20d5e77a270639a124fea587bb68b2fb6a5356fc (diff)
downloadCMake-1674a5b0a4c2432b9fe7c8ceb4287312c46ad763.zip
CMake-1674a5b0a4c2432b9fe7c8ceb4287312c46ad763.tar.gz
CMake-1674a5b0a4c2432b9fe7c8ceb4287312c46ad763.tar.bz2
Merge topic 'rename-cpack-ext-generator'
20d5e77a27 CPack: Rename Ext generator to External Acked-by: Kitware Robot <kwrobot@kitware.com> Merge-request: !2566
Diffstat (limited to 'Modules/Internal/CPack/CPackExternal.cmake')
-rw-r--r--Modules/Internal/CPack/CPackExternal.cmake53
1 files changed, 53 insertions, 0 deletions
diff --git a/Modules/Internal/CPack/CPackExternal.cmake b/Modules/Internal/CPack/CPackExternal.cmake
new file mode 100644
index 0000000..e4d055a
--- /dev/null
+++ b/Modules/Internal/CPack/CPackExternal.cmake
@@ -0,0 +1,53 @@
+# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
+# file Copyright.txt or https://cmake.org/licensing for details.
+
+if(NOT "${CPACK_EXTERNAL_REQUESTED_VERSIONS}" STREQUAL "")
+ unset(_found_major)
+
+ foreach(_req_version IN LISTS CPACK_EXTERNAL_REQUESTED_VERSIONS)
+ if(_req_version MATCHES "^([0-9]+)\\.([0-9]+)$")
+ set(_req_major "${CMAKE_MATCH_1}")
+ set(_req_minor "${CMAKE_MATCH_2}")
+
+ foreach(_known_version IN LISTS CPACK_EXTERNAL_KNOWN_VERSIONS)
+ string(REGEX MATCH
+ "^([0-9]+)\\.([0-9]+)$"
+ _known_version_dummy
+ "${_known_version}"
+ )
+
+ set(_known_major "${CMAKE_MATCH_1}")
+ set(_known_minor "${CMAKE_MATCH_2}")
+
+ if(_req_major EQUAL _known_major AND NOT _known_minor LESS _req_minor)
+ set(_found_major "${_known_major}")
+ set(_found_minor "${_known_minor}")
+ break()
+ endif()
+ endforeach()
+
+ if(DEFINED _found_major)
+ break()
+ endif()
+ endif()
+ endforeach()
+
+ if(DEFINED _found_major)
+ set(CPACK_EXTERNAL_SELECTED_MAJOR "${_found_major}")
+ set(CPACK_EXTERNAL_SELECTED_MINOR "${_found_minor}")
+ set(CPACK_EXTERNAL_SELECTED_VERSION "${_found_major}.${_found_minor}")
+ else()
+ message(FATAL_ERROR
+ "Could not find a suitable version in CPACK_EXTERNAL_REQUESTED_VERSIONS"
+ )
+ endif()
+else()
+ list(GET CPACK_EXTERNAL_KNOWN_VERSIONS 0 CPACK_EXTERNAL_SELECTED_VERSION)
+ string(REGEX MATCH
+ "^([0-9]+)\\.([0-9]+)$"
+ _dummy
+ "${CPACK_EXTERNAL_SELECTED_VERSION}"
+ )
+ set(CPACK_EXTERNAL_SELECTED_MAJOR "${CMAKE_MATCH_1}")
+ set(CPACK_EXTERNAL_SELECTED_MINOR "${CMAKE_MATCH_2}")
+endif()