From dfe3eacfc9d868309322f8e98424d4388657b10a Mon Sep 17 00:00:00 2001 From: "Ralf W. Grosse-Kunstleve" Date: Thu, 1 Feb 2024 09:39:22 -0800 Subject: [PATCH] Add a note in docs/classes.rst --- docs/classes.rst | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/docs/classes.rst b/docs/classes.rst index 4f2167dac1d..82145a9a8b4 100644 --- a/docs/classes.rst +++ b/docs/classes.rst @@ -58,6 +58,17 @@ interactive Python session demonstrating this example is shown below: Static member functions can be bound in the same way using :func:`class_::def_static`. +.. note:: + + By default pybind11 uses a custom metaclass which is known to be + incompatible with + `abc.ABCMeta `_ + and can also lead to other surprising issues. In such cases, + using ``py::metaclass(PyType_Type)`` is often a good solution. + Please see + `#5015 `_ + for more background. + .. note:: Binding C++ types in unnamed namespaces (also known as anonymous namespaces)