diff options
| author | Marc Chevrier <marc.chevrier@gmail.com> | 2025-01-05 16:27:42 (GMT) |
|---|---|---|
| committer | Marc Chevrier <marc.chevrier@gmail.com> | 2025-01-11 14:47:06 (GMT) |
| commit | 9b0510fa57ccace72de1147e0908c033e37b4fb1 (patch) | |
| tree | d0329b4210e017a710ba2bcdfad132b4f0e3c498 /Tests/FindPython/Python3 | |
| parent | ef6f5774fa07c36f799533202a790b9648c0648a (diff) | |
| download | CMake-9b0510fa57ccace72de1147e0908c033e37b4fb1.zip CMake-9b0510fa57ccace72de1147e0908c033e37b4fb1.tar.gz CMake-9b0510fa57ccace72de1147e0908c033e37b4fb1.tar.bz2 | |
FindPython: add support for multiple searches in same directory
In some situations, like cross-compilation, it can be required to search for
the host python interpreter as well as the cross-compilation development
artifacts.
By managing different prefixes for the artifacts, multiple and independent
searches can be achieved.
Diffstat (limited to 'Tests/FindPython/Python3')
| -rw-r--r-- | Tests/FindPython/Python3/CMakeLists.txt | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/Tests/FindPython/Python3/CMakeLists.txt b/Tests/FindPython/Python3/CMakeLists.txt index 28f68e1..bac6ed5 100644 --- a/Tests/FindPython/Python3/CMakeLists.txt +++ b/Tests/FindPython/Python3/CMakeLists.txt @@ -102,3 +102,44 @@ add_test(NAME python3_find_invalid_abi -DPython3_FIND_STRATEGY=${Python3_FIND_STRATEGY} "-DPython3_FIND_ABI=${Python3_INVALID_ABI}" -P "${CMAKE_CURRENT_LIST_DIR}/../FindPythonScript.cmake") + + +# +# New search with user's prefix +# +foreach(item IN ITEMS FOUND Development_FOUND Development.Module_FOUND Development.Embed_FOUND) + unset(Python3_${item}) +endforeach() + +set(Python3_ARTIFACTS_PREFIX "_TEST") +find_package(Python3 REQUIRED COMPONENTS Interpreter Development) +if (NOT Python3_TEST_FOUND OR NOT Python3_FOUND) + message (FATAL_ERROR "Failed to find Python 3 (TEST prefix)") +endif() +if (NOT Python3_TEST_Development_FOUND OR NOT Python3_Development_FOUND) + message (FATAL_ERROR "Failed to find Python 3 'Development' component (TEST prefix)") +endif() +if (NOT Python3_TEST_Development.Module_FOUND OR NOT Python3_Development.Module_FOUND) + message (FATAL_ERROR "Failed to find Python 3 'Development.Module' component (TEST prefix)") +endif() +if (NOT Python3_TEST_Development.Embed_FOUND OR NOT Python3_Development.Embed_FOUND) + message (FATAL_ERROR "Failed to find Python 3 'Development.Embed' component (TEST prefix)") +endif() + +if(NOT TARGET Python3_TEST::Interpreter) + message(SEND_ERROR "Python3_TEST::Interpreter not found") +endif() + +if(NOT TARGET Python3_TEST::Python) + message(SEND_ERROR "Python3_TEST::Python not found") +endif() +if(NOT TARGET Python3_TEST::Module) + message(SEND_ERROR "Python3_TEST::Module not found") +endif() + +Python3_TEST_add_library (TEST_spam3 MODULE ../TEST_spam.c) +target_compile_definitions (TEST_spam3 PRIVATE PYTHON3) + +add_test (NAME python3_TEST_spam3 + COMMAND "${CMAKE_COMMAND}" -E env "PYTHONPATH=$<TARGET_FILE_DIR:TEST_spam3>" + "${Python3_TEST_INTERPRETER}" -c "import TEST_spam3; TEST_spam3.system(\"cd\")") |
