Pybind11 Versions Save

Seamless operability between C++11 and Python

v2.12.0

1 month ago

New Features:

  • pybind11 now supports compiling for NumPy 2. Most code shouldn't change (see upgrade-guide-2.12 for details). However, if you experience issues you can define PYBIND11_NUMPY_1_ONLY to disable the new support for now, but this will be removed in the future. #5050
  • pybind11/gil_safe_call_once.h was added (it needs to be included explicitly). The primary use case is GIL-safe initialization of C++ static variables. #4877
  • Support move-only iterators in py::make_iterator, py::make_key_iterator, py::make_value_iterator. #4834
  • Two simple py::set_error() functions were added and the documentation was updated accordingly. In particular, py::exception<>::operator() was deprecated (use one of the new functions instead). The documentation for py::exception<> was further updated to not suggest code that may result in undefined behavior. #4772

Bug fixes:

  • Removes potential for Undefined Behavior during process teardown. #4897
  • Improve compatibility with the nvcc compiler (especially CUDA 12.1/12.2). #4893
  • pybind11/numpy.h now imports NumPy's multiarray and _internal submodules with paths depending on the installed version of NumPy (for compatibility with NumPy 2). #4857
  • Builtins collections names in docstrings are now consistently rendered in lowercase (list, set, dict, tuple), in accordance with PEP 585. #4833
  • Added py::typing::Iterator<T>, py::typing::Iterable<T>. #4832
  • Render py::function as Callable in docstring. #4829
  • Also bump PYBIND11_INTERNALS_VERSION for MSVC, which unlocks two new features without creating additional incompatibilities. #4819
  • Guard against crashes/corruptions caused by modules built with different MSVC versions. #4779
  • A long-standing bug in the handling of Python multiple inheritance was fixed. See PR #4762 for the rather complex details. #4762
  • Fix bind_map with using declarations. #4952
  • Qualify py::detail::concat usage to avoid ADL selecting one from somewhere else, such as modernjson's concat. #4955
  • Use new PyCode API on Python 3.12+. #4916
  • Minor cleanup from warnings reported by Clazy. #4988
  • Remove typing and duplicate class_ for KeysView/ValuesView/ItemsView. #4985
  • Use PyObject_VisitManagedDict() and PyObject_ClearManagedDict() on Python 3.13 and newer. #4973
  • Update make_static_property_type() to make it compatible with Python 3.13. #4971
  • Render typed iterators for make_iterator, make_key_iterator, make_value_iterator. #4876
  • Add several missing type name specializations. #5073
  • Change docstring render for py::buffer, py::sequence and py::handle (to Buffer, Sequence, Any). #4831
  • Fixed base_enum.__str__ docstring. #4827
  • Enforce single line docstring signatures. #4735
  • Special 'typed' wrappers now available in typing.h to annotate tuple, dict, list, set, and function. #4259
  • Create handle_type_name specialization to type-hint variable length tuples. #5051
  • Setting PYBIND11_FINDPYTHON to OFF will force the old FindPythonLibs mechanism to be used. #5042
  • Skip empty PYBIND11_PYTHON_EXECUTABLE_LAST for the first cmake run. #4856
  • Fix FindPython mode exports & avoid pkg_resources if importlib.metadata available. #4941
  • Python_ADDITIONAL_VERSIONS (classic search) now includes 3.12. #4909
  • pybind11.pc is now relocatable by default as long as install destinations are not absolute paths. #4830
  • Correctly detect CMake FindPython removal when used as a subdirectory. #4806
  • Don't require the libs component on CMake 3.18+ when using PYBIND11_FINDPYTHON (fixes manylinux builds). #4805
  • pybind11_strip is no longer automatically applied when CMAKE_BUILD_TYPE is unset. #4780
  • Support DEBUG_POSFIX correctly for debug builds. #4761
  • Hardcode lto/thin lto for Emscripten cross-compiles. #4642
  • Upgrade maximum supported CMake version to 3.27 to fix CMP0148 warnings. #4786

Documentation:

  • Small fix to grammar in functions.rst. #4791
  • Remove upper bound in example pyproject.toml for setuptools. #4774

CI:

  • CI: Update NVHPC to 23.5 and Ubuntu 20.04. #4764
  • Test on PyPy 3.10. #4714

Other:

  • Use Ruff formatter instead of Black. #4912
  • An assert() was added to help Coverty avoid generating a false positive. #4817

v2.11.1

9 months ago

Changes:

  • PYBIND11_NO_ASSERT_GIL_HELD_INCREF_DECREF is now provided as an option for disabling the default-on PyGILState_Check()'s in pybind11::handle's inc_ref() & dec_ref(). #4753

  • PYBIND11_ASSERT_GIL_HELD_INCREF_DECREF was disabled for PyPy in general (not just PyPy Windows). #4751


NOTE: There was a version number mishap in the first attempt making this release. It was fixed within minutes with #4756 and the stable branch was re-tagged. The upload to PyPI only succeeded for the corrected release.

v2.11.0

9 months ago

New features:

  • The newly added pybind11::detail::is_move_constructible trait can be specialized for cases in which std::is_move_constructible does not work as needed. This is very similar to the long-established pybind11::detail::is_copy_constructible. #4631
  • Introduce recursive_container_traits. #4623
  • pybind11/type_caster_pyobject_ptr.h was added to support automatic wrapping of APIs that make use of PyObject *. This header needs to included explicitly (i.e. it is not included implicitly with pybind/pybind11.h). #4601
  • format_descriptor<> & npy_format_descriptor<> PyObject * specializations were added. The latter enables py::array_t<PyObject *> to/from-python conversions. #4674
  • buffer_info gained an item_type_is_equivalent_to<T>() member function. #4674
  • The capsule API gained a user-friendly constructor (py::capsule(ptr, "name", dtor)). #4720

Changes:

  • PyGILState_Check()'s in pybind11::handle's inc_ref() & dec_ref() are now enabled by default again. #4246
  • py::initialize_interpreter() using PyConfig_InitPythonConfig() instead of PyConfig_InitIsolatedConfig(), to obtain complete sys.path. #4473
  • Cast errors now always include Python type information, even if PYBIND11_DETAILED_ERROR_MESSAGES is not defined. This increases binary sizes slightly (~1.5%) but the error messages are much more informative. #4463
  • The docstring generation for the std::array-list caster was fixed. Previously, signatures included the size of the list in a non-standard, non-spec compliant way. The new format conforms to PEP 593. Tooling for processing the docstrings may need to be updated accordingly. #4679
  • Setter return values (which are inaccessible for all practical purposes) are no longer converted to Python (only to be discarded). #4621
  • Allow lambda specified to function definition to be noexcept(true) in C++17. #4593
  • Get rid of recursive template instantiations for concatenating type signatures on C++17 and higher. #4587
  • Compatibility with Python 3.12 (beta). Note that the minimum pybind11 ABI version for Python 3.12 is version 5. (The default ABI version for Python versions up to and including 3.11 is still version 4.). #4570
  • With PYBIND11_INTERNALS_VERSION 5 (default for Python 3.12+), MSVC builds use std::hash<std::type_index> and std::equal_to<std::type_index> instead of string-based type comparisons. This resolves issues when binding types defined in the unnamed namespace. #4319
  • Python exception __notes__ (introduced with Python 3.11) are now added to the error_already_set::what() output. #4678

Build system improvements:

  • CMake 3.27 support was added, CMake 3.4 support was dropped. FindPython will be used if FindPythonInterp is not present. #4719
  • Update clang-tidy to 15 in CI. #4387
  • Moved the linting framework over to Ruff. #4483
  • Skip lto checks and target generation when CMAKE_INTERPROCEDURAL_OPTIMIZATION is defined. #4643
  • No longer inject -stdlib=libc++, not needed for modern Pythons (macOS 10.9+). #4639
  • PyPy 3.10 support was added, PyPy 3.7 support was dropped. #4728
  • Testing with Python 3.12 beta releases was added. #4713

v2.10.4

1 year ago

Changes:

  • python3 -m pybind11 gained a --version option (prints the version and exits). #4526

Bug Fixes:

  • Fix a warning when pydebug is enabled on Python 3.11. #4461
  • Ensure gil_scoped_release RAII is non-copyable. #4490
  • Ensure the tests dir does not show up with new versions of setuptools. #4510
  • Better stacklevel for a warning in setuptools helpers. #4516

v2.10.3

1 year ago

Changes:

  • Temporarily made our GIL status assertions (added in 2.10.2) disabled by default (re-enable manually by defining PYBIND11_ASSERT_GIL_HELD_INCREF_DECREF, will be enabled in 2.11). #4432
  • Improved error messages when inc_ref/dec_ref are called with an invalid GIL state. #4427 #4436

Bug Fixes:

  • Some minor touchups found by static analyzers. #4440

v2.10.2

1 year ago

Changes:

  • scoped_interpreter constructor taking PyConfig. #4372
  • pybind11/eigen/tensor.h adds converters to and from Eigen::Tensor and Eigen::TensorMap #4201
  • PyGILState_Check()'s were integrated to pybind11::handle inc_ref() & dec_ref(). The added GIL checks are guarded by PYBIND11_ASSERT_GIL_HELD_INCREF_DECREF, which is the default only if NDEBUG is not defined. #4246
  • Add option for enable/disable enum members in docstring. #2768
  • Fixed typing of KeysView, ValuesView and ItemsView in bind_map. #4353

Bug fixes:

  • Bug fix affecting only Python 3.6 under very specific, uncommon conditions: move PyEval_InitThreads() call to the correct location. #4350
  • Fix segfault bug when passing foreign native functions to functional.h. #4254

Build system improvements:

  • Support setting PYTHON_LIBRARIES manually for Windows ARM cross-compilation (classic mode). #4406
  • Extend IPO/LTO detection for ICX (a.k.a IntelLLVM) compiler. #4402
  • Allow calling find_package(pybind11 CONFIG) multiple times from separate directories in the same CMake project and properly link Python (new mode). #4401
  • multiprocessing_set_spawn in pytest fixture for added safety. #4377
  • Fixed a bug in two pybind11/tools cmake scripts causing "Unknown arguments specified" errors. #4327

v2.10.1

1 year ago

This is the first version to fully support embedding the newly released Python 3.11.

Changes:

  • Allow pybind11::capsule constructor to take null destructor pointers. #4221
  • embed.h was changed so that PYTHONPATH is used also with Python 3.11 (established behavior). #4119
  • A PYBIND11_SIMPLE_GIL_MANAGEMENT option was added (cmake, C++ define), along with many additional tests in test_gil_scoped.py. The option may be useful to try when debugging GIL-related issues, to determine if the more complex default implementation is or is not to blame. See #4216 for background. WARNING: Please be careful to not create ODR violations when using the option: everything that is linked together with mutual symbol visibility needs to be rebuilt. #4216
  • PYBIND11_EXPORT_EXCEPTION was made non-empty only under macOS. This makes Linux builds safer, and enables the removal of warning suppression pragmas for Windows. #4298

Bug fixes:

  • Fixed a bug where UnicodeDecodeError was not propagated from various py::str ctors when decoding surrogate utf characters. #4294
  • Revert perfect forwarding for make_iterator. This broke at least one valid use case. May revisit later. #4234
  • Fix support for safe casts to void* (regression in 2.10.0). #4275
  • Fix char8_t support (regression in 2.9). #4278
  • Unicode surrogate character in Python exception message leads to process termination in error_already_set::what(). #4297
  • Fix MSVC 2019 v.1924 & C++14 mode error for overload_cast. #4188
  • Make augmented assignment operators non-const for the object-api. Behavior was previously broken for augmented assignment operators. #4065
  • Add proper error checking to C++ bindings for Python list append and insert. #4208
  • Work-around for Nvidia's CUDA nvcc compiler in versions 11.4.0 - 11.8.0. #4220
  • A workaround for PyPy was added in the py::error_already_set implementation, related to PR #1895 released with v2.10.0. #4079
  • Fixed compiler errors when C++23 std::forward_like is available. #4136
  • Properly raise exceptions in contains methods (like when an object in unhashable). #4209
  • Further improve another error in exception handling. #4232
  • get_local_internals() was made compatible with finalize_interpreter(), fixing potential freezes during interpreter finalization. #4192

Performance and style:

  • Reserve space in set and STL map casters if possible. This will prevent unnecessary rehashing / resizing by knowing the number of keys ahead of time for Python to C++ casting. This improvement will greatly speed up the casting of large unordered maps and sets. #4194
  • GIL RAII scopes are non-copyable to avoid potential bugs. #4183
  • Explicitly default all relevant ctors for pytypes in the PYBIND11_OBJECT macros and enforce the clang-tidy checks modernize-use-equals-default in macros as well. #4017
  • Optimize iterator advancement in C++ bindings. #4237
  • Use the modern PyObject_GenericGetDict and PyObject_GenericSetDict for handling dynamic attribute dictionaries. #4106
  • Document that users should use PYBIND11_NAMESPACE instead of using pybind11 when opening namespaces. Using namespace declarations and namespace qualification remain the same as pybind11. This is done to ensure consistent symbol visibility. #4098
  • Mark detail::forward_like as constexpr. #4147
  • Optimize unpacking_collector when processing arg_v arguments. #4219
  • Optimize casting C++ object to None. #4269

Build system improvements:

  • CMake: revert overwrite behavior, now opt-in with PYBIND11_PYTHONLIBS_OVERRWRITE OFF. #4195
  • Include a pkg-config file when installing pybind11, such as in the Python package. #4077
  • Avoid stripping debug symbols when CMAKE_BUILD_TYPE is set to DEBUG instead of Debug. #4078
  • Followup to #3948, fixing vcpkg again. #4123

v2.10.0

1 year ago

Removed support for Python 2.7, Python 3.5, and MSVC 2015. Support for MSVC 2017 is limited due to availability of CI runners; we highly recommend MSVC 2019 or 2022 be used. Initial support added for Python 3.11.

New features:

  • py::anyset & py::frozenset were added, with copying (cast) to std::set (similar to set). #3901
  • Support bytearray casting to string. #3707
  • type_caster<std::monostate> was added. std::monostate is a tag type that allows std::variant to act as an optional, or allows default construction of a std::variant holding a non-default constructible type. #3818
  • pybind11::capsule::set_name added to mutate the name of the capsule instance. #3866
  • NumPy: dtype constructor from type number added, accessors corresponding to Python API dtype.num, dtype.byteorder, dtype.flags and dtype.alignment added. #3868

Changes:

  • Python 3.6 is now the minimum supported version. #3688 #3719
  • The minimum version for MSVC is now 2017. #3722
  • Fix issues with CPython 3.11 betas and add to supported test matrix. #3923
  • error_already_set is now safer and more performant, especially for exceptions with long tracebacks, by delaying computation. #1895
  • Improve exception handling in python str bindings. #3826
  • The bindings for capsules now have more consistent exception handling. #3825
  • PYBIND11_OBJECT_CVT and PYBIND11_OBJECT_CVT_DEFAULT macro can now be used to define classes in namespaces other than pybind11. #3797
  • Error printing code now uses PYBIND11_DETAILED_ERROR_MESSAGES instead of requiring NDEBUG, allowing use with release builds if desired. #3913
  • Implicit conversion of the literal 0 to pybind11::handle is now disabled. #4008

Bug fixes:

  • Fix exception handling when pybind11::weakref() fails. #3739
  • module_::def_submodule was missing proper error handling. This is fixed now. #3973
  • The behavior or error_already_set was made safer and the highly opaque "Unknown internal error occurred" message was replaced with a more helpful message. #3982
  • error_already_set::what() now handles non-normalized exceptions correctly. #3971
  • Support older C++ compilers where filesystem is not yet part of the standard library and is instead included in std::experimental::filesystem. #3840
  • Fix -Wfree-nonheap-object warnings produced by GCC by avoiding returning pointers to static objects with return_value_policy::take_ownership. #3946
  • Fix cast from pytype rvalue to another pytype. #3949
  • Ensure proper behavior when garbage collecting classes with dynamic attributes in Python >=3.9. #4051
  • A couple long-standing PYBIND11_NAMESPACE __attribute__((visibility("hidden"))) inconsistencies are now fixed (affects only unusual environments). #4043
  • pybind11::detail::get_internals() is now resilient to in-flight Python exceptions. #3981
  • Arrays with a dimension of size 0 are now properly converted to dynamic Eigen matrices (more common in NumPy 1.23). #4038
  • Avoid catching unrelated errors when importing NumPy. #3974

Performance and style:

  • Added an accessor overload of (object &&key) to reference steal the object when using python types as keys. This prevents unnecessary reference count overhead for attr, dictionary, tuple, and sequence look ups. Added additional regression tests. Fixed a performance bug the caused accessor assignments to potentially perform unnecessary copies. #3970
  • Perfect forward all args of make_iterator. #3980
  • Avoid potential bug in pycapsule destructor by adding an error_guard to one of the dtors. #3958
  • Optimize dictionary access in strip_padding for numpy. #3994
  • stl_bind.h bindings now take slice args as a const-ref. #3852
  • Made slice constructor more consistent, and improve performance of some casters by allowing reference stealing. #3845
  • Change numpy dtype from_args method to use const ref. #3878
  • Follow rule of three to ensure PyErr_Restore is called only once. #3872
  • Added missing perfect forwarding for make_iterator functions. #3860
  • Optimize c++ to python function casting by using the rvalue caster. #3966
  • Optimize Eigen sparse matrix casting by removing unnecessary temporary. #4064
  • Avoid potential implicit copy/assignment constructors causing double free in strdup_gaurd. #3905
  • Enable clang-tidy checks misc-definitions-in-headers, modernize-loop-convert, and modernize-use-nullptr. #3881 #3988

Build system improvements:

  • CMake: Fix file extension on Windows with cp36 and cp37 using FindPython. #3919
  • CMake: Support multiple Python targets (such as on vcpkg). #3948
  • CMake: Fix issue with NVCC on Windows. #3947
  • CMake: Drop the bitness check on cross compiles (like targeting WebAssembly via Emscripten). #3959
  • Add MSVC builds in debug mode to CI. #3784
  • MSVC 2022 C++20 coverage was added to GitHub Actions, including Eigen. #3732, #3741

Backend and tidying up:

  • New theme for the documentation. #3109
  • Remove idioms in code comments. Use more inclusive language. #3809
  • #include <iostream> was removed from the pybind11/stl.h header. Your project may break if it has a transitive dependency on this include. The fix is to "Include What You Use". #3928
  • Avoid setup.py <command> usage in internal tests. #3734

v2.9.2

2 years ago

Changes:

  • Enum now has an __index__ method on Python <3.8 too. #3700
  • Local internals are now cleared after finalizing the interpreter. #3744

Bug fixes:

  • Better support for Python 3.11 alphas. #3694
  • PYBIND11_TYPE_CASTER now uses fully qualified symbols, so it can be used outside of pybind11::detail. #3758
  • Some fixes for PyPy 3.9. #3768
  • Fixed a potential memleak in PyPy in get_type_override. #3774
  • Fix usage of VISIBILITY_INLINES_HIDDEN. #3721

Build system improvements:

  • Uses sysconfig module to determine installation locations on Python >= 3.10, instead of distutils which has been deprecated. #3764
  • Support Catch 2.13.5+ (supporting GLIBC 2.34+). #3679
  • Fix test failures with numpy 1.22 by ignoring whitespace when comparing str() of dtypes. #3682

Backend and tidying up:

  • clang-tidy: added readability-qualified-auto, readability-braces-around-statements, cppcoreguidelines-prefer-member-initializer, clang-analyzer-optin.performance.Padding, cppcoreguidelines-pro-type-static-cast-downcast, and readability-inconsistent-declaration-parameter-name. #3702, #3699, #3716, #3709
  • clang-format was added to the pre-commit actions, and the entire code base automatically reformatted (after several iterations preparing for this leap). #3713

v2.9.1

2 years ago

Changes:

  • If possible, attach Python exception with py::raise_from to TypeError when casting from C++ to Python. This will give additional info if Python exceptions occur in the caster. Adds a test case of trying to convert a set from C++ to Python when the hash function is not defined in Python. #3605
  • Add a mapping of C++11 nested exceptions to their Python exception equivalent using py::raise_from. This attaches the nested exceptions in Python using the __cause__ field. #3608
  • Propagate Python exception traceback using raise_from if a pybind11 function runs out of overloads. #3671
  • py::multiple_inheritance is now only needed when C++ bases are hidden from pybind11. #3650 and #3659

Bug fixes:

  • Remove a boolean cast in numpy.h that causes MSVC C4800 warnings when compiling against Python 3.10 or newer. #3669
  • Render py::bool_ and py::float_ as bool and float respectively. #3622

Build system improvements:

  • Fix CMake extension suffix computation on Python 3.10+. #3663
  • Allow CMAKE_ARGS to override CMake args in pybind11's own setup.py. #3577
  • Remove a few deprecated c-headers. #3610
  • More uniform handling of test targets. #3590
  • Add clang-tidy readability check to catch potentially swapped function args. #3611