diff options
| author | Brad King <brad.king@kitware.com> | 2022-11-30 12:26:59 (GMT) |
|---|---|---|
| committer | Kitware Robot <kwrobot@kitware.com> | 2022-11-30 12:27:06 (GMT) |
| commit | d871fad90241df2b58b55c816554a1ef2ccf6a79 (patch) | |
| tree | 9176c071571d5d26e02d9e393bc0117004d1b8ce /Tests/FindPython/Python3SABIModule/CMakeLists.txt | |
| parent | 7fd42381495b7bc974c4c08f6623fb5070cf0067 (diff) | |
| parent | 77d734aede807a038ab10520620cfbb24e84e76e (diff) | |
| download | CMake-d871fad90241df2b58b55c816554a1ef2ccf6a79.zip CMake-d871fad90241df2b58b55c816554a1ef2ccf6a79.tar.gz CMake-d871fad90241df2b58b55c816554a1ef2ccf6a79.tar.bz2 | |
Merge topic 'FindPython-ABI3-support'
77d734aede FindPython: add support for Stable ABI
Acked-by: Kitware Robot <kwrobot@kitware.com>
Acked-by: buildbot <buildbot@kitware.com>
Merge-request: !7967
Diffstat (limited to 'Tests/FindPython/Python3SABIModule/CMakeLists.txt')
| -rw-r--r-- | Tests/FindPython/Python3SABIModule/CMakeLists.txt | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/Tests/FindPython/Python3SABIModule/CMakeLists.txt b/Tests/FindPython/Python3SABIModule/CMakeLists.txt new file mode 100644 index 0000000..2a067d0 --- /dev/null +++ b/Tests/FindPython/Python3SABIModule/CMakeLists.txt @@ -0,0 +1,51 @@ +cmake_minimum_required(VERSION 3.1) + +project(TestPython3SABIModule LANGUAGES C) + +include(CTest) + +find_package(Python3 REQUIRED COMPONENTS Interpreter Development.SABIModule) +if (NOT Python3_FOUND) + message (FATAL_ERROR "Failed to find Python 3") +endif() +if (Python3_Development_FOUND) + message (FATAL_ERROR "Python 3, COMPONENT 'Development' unexpectedly found") +endif() +if (Python3_Development.Embed_FOUND) + message (FATAL_ERROR "Python 3, COMPONENT 'Development.Embed' unexpectedly found") +endif() +if (Python3_Development.Module_FOUND) + message (FATAL_ERROR "Python 3, COMPONENT 'Development.Module' unexpectedly found") +endif() +if (NOT Python3_Development.SABIModule_FOUND) + message (FATAL_ERROR "Python 3, COMPONENT 'Development.SABIModule' not found") +endif() + +if(NOT TARGET Python3::Interpreter) + message(SEND_ERROR "Python3::Interpreter not found") +endif() + +if(TARGET Python3::Python) + message(SEND_ERROR "Python3::Python unexpectedly found") +endif() +if(TARGET Python3::Module) + message(SEND_ERROR "Python3::Module unexpectedly found") +endif() +if(NOT TARGET Python3::SABIModule) + message(SEND_ERROR "Python3::SABIModule not found") +endif() + +Python3_add_library (spam3 MODULE USE_SABI 3 WITH_SOABI ../spam.c) +target_compile_definitions (spam3 PRIVATE PYTHON3) + +if (Python3_SOSABI) + get_property (suffix TARGET spam3 PROPERTY SUFFIX) + if (NOT suffix MATCHES "^.${Python3_SOSABI}") + message(FATAL_ERROR "Module suffix do not include Python3_SOSABI") + endif() +endif() + + +add_test (NAME python3_spam3 + COMMAND "${CMAKE_COMMAND}" -E env "PYTHONPATH=$<TARGET_FILE_DIR:spam3>" + "${Python3_EXECUTABLE}" -c "import spam3; spam3.system(\"cd\")") |
