| | #[=============================================================================[.rst |
| |
|
| | pybind11Config.cmake |
| | |
| |
|
| | PYBIND11 cmake module. |
| | This module sets the following variables in your project:: |
| |
|
| | pybind11_FOUND - true if pybind11 and all required components found on the system |
| | pybind11_VERSION - pybind11 version in format Major.Minor.Release |
| | pybind11_VERSION_TYPE - pybind11 version type (dev, release) |
| | pybind11_INCLUDE_DIRS - Directories where pybind11 and python headers are located. |
| | pybind11_INCLUDE_DIR - Directory where pybind11 headers are located. |
| | pybind11_DEFINITIONS - Definitions necessary to use pybind11, namely USING_pybind11. |
| | pybind11_LIBRARIES - compile flags and python libraries (as needed) to link against. |
| | pybind11_LIBRARY - empty. |
| |
|
| |
|
| | Available components: None |
| |
|
| |
|
| | Exported targets:: |
| |
|
| | If pybind11 is found, this module defines the following :prop_tgt:`IMPORTED` |
| | interface library targets:: |
| |
|
| | pybind11::module - for extension modules |
| | pybind11::embed - for embedding the Python interpreter |
| |
|
| | Python headers, libraries (as needed by platform), and the C++ standard |
| | are attached to the target. |
| |
|
| | Advanced targets are also supplied - these are primary for users building |
| | complex applications, and they are available in all modes:: |
| |
|
| | pybind11::headers - Just the pybind11 headers and minimum compile requirements |
| | pybind11::pybind11 - Python headers too |
| | pybind11::python_link_helper - Just the "linking" part of pybind11:module, for CMake < 3.15 |
| | pybind11::python2_no_register - Quiets the warning/error when mixing C++14+ and Python 2, also included in pybind11::module |
| | pybind11::thin_lto - An alternative to INTERPROCEDURAL_OPTIMIZATION |
| | pybind11::lto - An alternative to INTERPROCEDURAL_OPTIMIZATION (also avoids thin LTO on clang) |
| | pybind11::windows_extras - Adds bigobj and mp for MSVC |
| |
|
| | Modes:: |
| |
|
| | There are two modes provided; classic, which is built on the old Python |
| | discovery packages in CMake, or the new FindPython mode, which uses FindPython |
| | from 3.12+ forward (3.15+ _highly_ recommended). |
| |
|
| | New FindPython mode:: |
| |
|
| | To activate this mode, either call ``find_package(Python COMPONENTS Interpreter Development)`` |
| | before finding this package, or set the ``PYBIND11_FINDPYTHON`` variable to ON. In this mode, |
| | you can either use the basic targets, or use the FindPython tools:: |
| |
|
| | find_package(Python COMPONENTS Interpreter Development) |
| | find_package(pybind11 CONFIG) |
| |
|
| | # pybind11 method: |
| | pybind11_add_module(MyModule1 src1.cpp) |
| |
|
| | # Python method: |
| | Python_add_library(MyModule2 src2.cpp) |
| | target_link_libraries(MyModule2 pybind11::headers) |
| | set_target_properties(MyModule2 PROPERTIES |
| | INTERPROCEDURAL_OPTIMIZATION ON |
| | CXX__VISIBILITY_PRESET ON |
| | VISIBLITY_INLINES_HIDDEN ON) |
| |
|
| | If you build targets yourself, you may be interested in stripping the output |
| | for reduced size; this is the one other feature that the helper function gives you. |
| |
|
| | Classic mode:: |
| |
|
| | Set PythonLibsNew variables to influence python detection and |
| | CMAKE_CXX_STANDARD to influence standard setting. :: |
| |
|
| | find_package(pybind11 CONFIG REQUIRED) |
| |
|
| | # Create an extension module |
| | add_library(mylib MODULE main.cpp) |
| | target_link_libraries(mylib PUBLIC pybind11::module) |
| |
|
| | # Or embed the Python interpreter into an executable |
| | add_executable(myexe main.cpp) |
| | target_link_libraries(myexe PUBLIC pybind11::embed) |
| |
|
| | Suggested usage:: |
| |
|
| | find_package with version info is not recommended except for release versions. :: |
| |
|
| | find_package(pybind11 CONFIG) |
| | find_package(pybind11 2.0 EXACT CONFIG REQUIRED) |
| |
|
| |
|
| | The following variables can be set to guide the search for this package:: |
| |
|
| | pybind11_DIR - CMake variable, set to directory containing this Config file |
| | CMAKE_PREFIX_PATH - CMake variable, set to root directory of this package |
| | PATH - environment variable, set to bin directory of this package |
| | CMAKE_DISABLE_FIND_PACKAGE_pybind11 - CMake variable, disables |
| | find_package(pybind11) when not REQUIRED, perhaps to force internal build |
| |
|
| | Helper functions:: |
| |
|
| | pybind11_add_module(...) - Add a library and setup all helpers |
| | pybind11_strip(target) - Strip a target after building it (linux/macOS) |
| | pybind11_extension(target) - Injects the Python extension name |
| |
|
| | See ``pybind11Tools.cmake`` or ``pybind11NewTools.cmake`` for details on |
| | ``pybind11_add_module``. |
| |
|
| | #]=============================================================================] |
| | @PACKAGE_INIT@ |
| |
|
| | # Location of pybind11/pybind11.h |
| | set(pybind11_INCLUDE_DIR "${PACKAGE_PREFIX_DIR}/@CMAKE_INSTALL_INCLUDEDIR@") |
| |
|
| | set(pybind11_LIBRARY "") |
| | set(pybind11_DEFINITIONS USING_pybind11) |
| | set(pybind11_VERSION_TYPE "@pybind11_VERSION_TYPE@") |
| |
|
| | check_required_components(pybind11) |
| |
|
| | if(TARGET pybind11::python_link_helper) |
| | # This has already been setup elsewhere, such as with a previous call or |
| | # add_subdirectory |
| | return() |
| | endif() |
| |
|
| | include("${CMAKE_CURRENT_LIST_DIR}/pybind11Targets.cmake") |
| |
|
| | # Easier to use / remember |
| | add_library(pybind11::headers IMPORTED INTERFACE) |
| | set_target_properties(pybind11::headers PROPERTIES INTERFACE_LINK_LIBRARIES |
| | pybind11::pybind11_headers) |
| |
|
| | include("${CMAKE_CURRENT_LIST_DIR}/pybind11Common.cmake") |
| |
|
| | if(NOT pybind11_FIND_QUIETLY) |
| | message( |
| | STATUS |
| | "Found pybind11: ${pybind11_INCLUDE_DIR} (found version \"${pybind11_VERSION}\" ${pybind11_VERSION_TYPE})" |
| | ) |
| | endif() |
| |
|