Skip to content
Snippets Groups Projects
Commit d579c415 authored by Brad King's avatar Brad King Committed by Kitware Robot
Browse files

Merge topic 'FindPython-version-range-fix-tests' into release-3.19


a00603af FindPython: Fix version range tests

Acked-by: default avatarKitware Robot <kwrobot@kitware.com>
Merge-request: !5497
parents d8aaa06b a00603af
No related branches found
No related tags found
No related merge requests found
......@@ -16,40 +16,49 @@ else()
set (OUT_VERSION_RANGE 3.0...<${${Python}_VERSION})
endif()
function (FIND_PYTHON EXPECTED_VERSION)
unset (_${Python}_EXECUTABLE CACHE)
unset (_${Python}_LIBRARY_RELEASE CACHE)
unset (_${Python}_INCLUDE_DIR CACHE)
unset (${Python}_FOUND)
function (FIND_PYTHON EXPECTED_VERSION RANGE)
macro (FIND_PYTHON_PACKAGE)
unset (_${Python}_EXECUTABLE CACHE)
unset (_${Python}_LIBRARY_RELEASE CACHE)
unset (_${Python}_INCLUDE_DIR CACHE)
unset (${Python}_FOUND)
find_package (${ARGN})
find_package (${Python} ${ARGV})
endmacro()
find_python_package(${RANGE} ${ARGN})
if (EXPECTED_VERSION STREQUAL "NONE")
while (${Python}_FOUND AND ${Python}_VERSION VERSION_GREATER ${Python_REQUESTED_VERSION})
# Possible if multiple versions are installed
# Try with a different range
find_python_package(${Python_REQUESTED_VERSION}.0...<${${Python}_VERSION} ${ARGN})
endwhile()
if (${Python}_FOUND)
message (SEND_ERROR "Unexpectedly found version: ${${Python}_VERSION} for ${ARGN}")
message (SEND_ERROR "Unexpectedly found version: ${${Python}_VERSION} for '${Python} ${Python_REQUESTED_VERSION}.0...<${${Python}_VERSION} ${ARGN}'")
endif()
return()
endif()
if (NOT ${Python}_FOUND)
message (SEND_ERROR "Not found: ${ARGN}")
message (SEND_ERROR "Not found: ${Python} ${RANGE} ${ARGN}")
elseif (NOT ${Python}_VERSION VERSION_EQUAL EXPECTED_VERSION)
message (SEND_ERROR "Wrong version: ${${Python}_VERSION} for ${ARGN}")
message (SEND_ERROR "Wrong version: ${${Python}_VERSION} for '${Python} ${RANGE} ${ARGN}'")
endif()
endfunction()
find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Interpreter)
find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Interpreter)
if (${Python}_FIND_IMPLEMENTATIONS STREQUAL "IronPython")
find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Compiler)
find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Compiler)
else()
find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Development)
find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Development)
endif()
find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Interpreter)
find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Interpreter)
if (${Python}_FIND_IMPLEMENTATIONS STREQUAL "IronPython")
find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Compiler)
find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Compiler)
else()
find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Development)
find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Development)
endif()
find_python ("NONE" ${Python} 5...6 COMPONENTS Interpreter)
find_python ("NONE" 5...6 COMPONENTS Interpreter)
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment