1Functions 2######### 3 4Before proceeding with this section, make sure that you are already familiar 5with the basics of binding functions and classes, as explained in :doc:`/basics` 6and :doc:`/classes`. The following guide is applicable to both free and member 7functions, i.e. *methods* in Python. 8 9.. _return_value_policies: 10 11Return value policies 12===================== 13 14Python and C++ use fundamentally different ways of managing the memory and 15lifetime of objects managed by them. This can lead to issues when creating 16bindings for functions that return a non-trivial type. Just by looking at the 17type information, it is not clear whether Python should take charge of the 18returned value and eventually free its resources, or if this is handled on the 19C++ side. For this reason, pybind11 provides a several *return value policy* 20annotations that can be passed to the :func:`module_::def` and 21:func:`class_::def` functions. The default policy is 22:enum:`return_value_policy::automatic`. 23 24Return value policies are tricky, and it's very important to get them right. 25Just to illustrate what can go wrong, consider the following simple example: 26 27.. code-block:: cpp 28 29 /* Function declaration */ 30 Data *get_data() { return _data; /* (pointer to a static data structure) */ } 31 ... 32 33 /* Binding code */ 34 m.def("get_data", &get_data); // <-- KABOOM, will cause crash when called from Python 35 36What's going on here? When ``get_data()`` is called from Python, the return 37value (a native C++ type) must be wrapped to turn it into a usable Python type. 38In this case, the default return value policy (:enum:`return_value_policy::automatic`) 39causes pybind11 to assume ownership of the static ``_data`` instance. 40 41When Python's garbage collector eventually deletes the Python 42wrapper, pybind11 will also attempt to delete the C++ instance (via ``operator 43delete()``) due to the implied ownership. At this point, the entire application 44will come crashing down, though errors could also be more subtle and involve 45silent data corruption. 46 47In the above example, the policy :enum:`return_value_policy::reference` should have 48been specified so that the global data instance is only *referenced* without any 49implied transfer of ownership, i.e.: 50 51.. code-block:: cpp 52 53 m.def("get_data", &get_data, return_value_policy::reference); 54 55On the other hand, this is not the right policy for many other situations, 56where ignoring ownership could lead to resource leaks. 57As a developer using pybind11, it's important to be familiar with the different 58return value policies, including which situation calls for which one of them. 59The following table provides an overview of available policies: 60 61.. tabularcolumns:: |p{0.5\textwidth}|p{0.45\textwidth}| 62 63+--------------------------------------------------+----------------------------------------------------------------------------+ 64| Return value policy | Description | 65+==================================================+============================================================================+ 66| :enum:`return_value_policy::take_ownership` | Reference an existing object (i.e. do not create a new copy) and take | 67| | ownership. Python will call the destructor and delete operator when the | 68| | object's reference count reaches zero. Undefined behavior ensues when the | 69| | C++ side does the same, or when the data was not dynamically allocated. | 70+--------------------------------------------------+----------------------------------------------------------------------------+ 71| :enum:`return_value_policy::copy` | Create a new copy of the returned object, which will be owned by Python. | 72| | This policy is comparably safe because the lifetimes of the two instances | 73| | are decoupled. | 74+--------------------------------------------------+----------------------------------------------------------------------------+ 75| :enum:`return_value_policy::move` | Use ``std::move`` to move the return value contents into a new instance | 76| | that will be owned by Python. This policy is comparably safe because the | 77| | lifetimes of the two instances (move source and destination) are decoupled.| 78+--------------------------------------------------+----------------------------------------------------------------------------+ 79| :enum:`return_value_policy::reference` | Reference an existing object, but do not take ownership. The C++ side is | 80| | responsible for managing the object's lifetime and deallocating it when | 81| | it is no longer used. Warning: undefined behavior will ensue when the C++ | 82| | side deletes an object that is still referenced and used by Python. | 83+--------------------------------------------------+----------------------------------------------------------------------------+ 84| :enum:`return_value_policy::reference_internal` | Indicates that the lifetime of the return value is tied to the lifetime | 85| | of a parent object, namely the implicit ``this``, or ``self`` argument of | 86| | the called method or property. Internally, this policy works just like | 87| | :enum:`return_value_policy::reference` but additionally applies a | 88| | ``keep_alive<0, 1>`` *call policy* (described in the next section) that | 89| | prevents the parent object from being garbage collected as long as the | 90| | return value is referenced by Python. This is the default policy for | 91| | property getters created via ``def_property``, ``def_readwrite``, etc. | 92+--------------------------------------------------+----------------------------------------------------------------------------+ 93| :enum:`return_value_policy::automatic` | **Default policy.** This policy falls back to the policy | 94| | :enum:`return_value_policy::take_ownership` when the return value is a | 95| | pointer. Otherwise, it uses :enum:`return_value_policy::move` or | 96| | :enum:`return_value_policy::copy` for rvalue and lvalue references, | 97| | respectively. See above for a description of what all of these different | 98| | policies do. | 99+--------------------------------------------------+----------------------------------------------------------------------------+ 100| :enum:`return_value_policy::automatic_reference` | As above, but use policy :enum:`return_value_policy::reference` when the | 101| | return value is a pointer. This is the default conversion policy for | 102| | function arguments when calling Python functions manually from C++ code | 103| | (i.e. via handle::operator()). You probably won't need to use this. | 104+--------------------------------------------------+----------------------------------------------------------------------------+ 105 106Return value policies can also be applied to properties: 107 108.. code-block:: cpp 109 110 class_<MyClass>(m, "MyClass") 111 .def_property("data", &MyClass::getData, &MyClass::setData, 112 py::return_value_policy::copy); 113 114Technically, the code above applies the policy to both the getter and the 115setter function, however, the setter doesn't really care about *return* 116value policies which makes this a convenient terse syntax. Alternatively, 117targeted arguments can be passed through the :class:`cpp_function` constructor: 118 119.. code-block:: cpp 120 121 class_<MyClass>(m, "MyClass") 122 .def_property("data" 123 py::cpp_function(&MyClass::getData, py::return_value_policy::copy), 124 py::cpp_function(&MyClass::setData) 125 ); 126 127.. warning:: 128 129 Code with invalid return value policies might access uninitialized memory or 130 free data structures multiple times, which can lead to hard-to-debug 131 non-determinism and segmentation faults, hence it is worth spending the 132 time to understand all the different options in the table above. 133 134.. note:: 135 136 One important aspect of the above policies is that they only apply to 137 instances which pybind11 has *not* seen before, in which case the policy 138 clarifies essential questions about the return value's lifetime and 139 ownership. When pybind11 knows the instance already (as identified by its 140 type and address in memory), it will return the existing Python object 141 wrapper rather than creating a new copy. 142 143.. note:: 144 145 The next section on :ref:`call_policies` discusses *call policies* that can be 146 specified *in addition* to a return value policy from the list above. Call 147 policies indicate reference relationships that can involve both return values 148 and parameters of functions. 149 150.. note:: 151 152 As an alternative to elaborate call policies and lifetime management logic, 153 consider using smart pointers (see the section on :ref:`smart_pointers` for 154 details). Smart pointers can tell whether an object is still referenced from 155 C++ or Python, which generally eliminates the kinds of inconsistencies that 156 can lead to crashes or undefined behavior. For functions returning smart 157 pointers, it is not necessary to specify a return value policy. 158 159.. _call_policies: 160 161Additional call policies 162======================== 163 164In addition to the above return value policies, further *call policies* can be 165specified to indicate dependencies between parameters or ensure a certain state 166for the function call. 167 168Keep alive 169---------- 170 171In general, this policy is required when the C++ object is any kind of container 172and another object is being added to the container. ``keep_alive<Nurse, Patient>`` 173indicates that the argument with index ``Patient`` should be kept alive at least 174until the argument with index ``Nurse`` is freed by the garbage collector. Argument 175indices start at one, while zero refers to the return value. For methods, index 176``1`` refers to the implicit ``this`` pointer, while regular arguments begin at 177index ``2``. Arbitrarily many call policies can be specified. When a ``Nurse`` 178with value ``None`` is detected at runtime, the call policy does nothing. 179 180When the nurse is not a pybind11-registered type, the implementation internally 181relies on the ability to create a *weak reference* to the nurse object. When 182the nurse object is not a pybind11-registered type and does not support weak 183references, an exception will be thrown. 184 185Consider the following example: here, the binding code for a list append 186operation ties the lifetime of the newly added element to the underlying 187container: 188 189.. code-block:: cpp 190 191 py::class_<List>(m, "List") 192 .def("append", &List::append, py::keep_alive<1, 2>()); 193 194For consistency, the argument indexing is identical for constructors. Index 195``1`` still refers to the implicit ``this`` pointer, i.e. the object which is 196being constructed. Index ``0`` refers to the return type which is presumed to 197be ``void`` when a constructor is viewed like a function. The following example 198ties the lifetime of the constructor element to the constructed object: 199 200.. code-block:: cpp 201 202 py::class_<Nurse>(m, "Nurse") 203 .def(py::init<Patient &>(), py::keep_alive<1, 2>()); 204 205.. note:: 206 207 ``keep_alive`` is analogous to the ``with_custodian_and_ward`` (if Nurse, 208 Patient != 0) and ``with_custodian_and_ward_postcall`` (if Nurse/Patient == 209 0) policies from Boost.Python. 210 211Call guard 212---------- 213 214The ``call_guard<T>`` policy allows any scope guard type ``T`` to be placed 215around the function call. For example, this definition: 216 217.. code-block:: cpp 218 219 m.def("foo", foo, py::call_guard<T>()); 220 221is equivalent to the following pseudocode: 222 223.. code-block:: cpp 224 225 m.def("foo", [](args...) { 226 T scope_guard; 227 return foo(args...); // forwarded arguments 228 }); 229 230The only requirement is that ``T`` is default-constructible, but otherwise any 231scope guard will work. This is very useful in combination with `gil_scoped_release`. 232See :ref:`gil`. 233 234Multiple guards can also be specified as ``py::call_guard<T1, T2, T3...>``. The 235constructor order is left to right and destruction happens in reverse. 236 237.. seealso:: 238 239 The file :file:`tests/test_call_policies.cpp` contains a complete example 240 that demonstrates using `keep_alive` and `call_guard` in more detail. 241 242.. _python_objects_as_args: 243 244Python objects as arguments 245=========================== 246 247pybind11 exposes all major Python types using thin C++ wrapper classes. These 248wrapper classes can also be used as parameters of functions in bindings, which 249makes it possible to directly work with native Python types on the C++ side. 250For instance, the following statement iterates over a Python ``dict``: 251 252.. code-block:: cpp 253 254 void print_dict(py::dict dict) { 255 /* Easily interact with Python types */ 256 for (auto item : dict) 257 std::cout << "key=" << std::string(py::str(item.first)) << ", " 258 << "value=" << std::string(py::str(item.second)) << std::endl; 259 } 260 261It can be exported: 262 263.. code-block:: cpp 264 265 m.def("print_dict", &print_dict); 266 267And used in Python as usual: 268 269.. code-block:: pycon 270 271 >>> print_dict({'foo': 123, 'bar': 'hello'}) 272 key=foo, value=123 273 key=bar, value=hello 274 275For more information on using Python objects in C++, see :doc:`/advanced/pycpp/index`. 276 277Accepting \*args and \*\*kwargs 278=============================== 279 280Python provides a useful mechanism to define functions that accept arbitrary 281numbers of arguments and keyword arguments: 282 283.. code-block:: python 284 285 def generic(*args, **kwargs): 286 ... # do something with args and kwargs 287 288Such functions can also be created using pybind11: 289 290.. code-block:: cpp 291 292 void generic(py::args args, py::kwargs kwargs) { 293 /// .. do something with args 294 if (kwargs) 295 /// .. do something with kwargs 296 } 297 298 /// Binding code 299 m.def("generic", &generic); 300 301The class ``py::args`` derives from ``py::tuple`` and ``py::kwargs`` derives 302from ``py::dict``. 303 304You may also use just one or the other, and may combine these with other 305arguments as long as the ``py::args`` and ``py::kwargs`` arguments are the last 306arguments accepted by the function. 307 308Please refer to the other examples for details on how to iterate over these, 309and on how to cast their entries into C++ objects. A demonstration is also 310available in ``tests/test_kwargs_and_defaults.cpp``. 311 312.. note:: 313 314 When combining \*args or \*\*kwargs with :ref:`keyword_args` you should 315 *not* include ``py::arg`` tags for the ``py::args`` and ``py::kwargs`` 316 arguments. 317 318Default arguments revisited 319=========================== 320 321The section on :ref:`default_args` previously discussed basic usage of default 322arguments using pybind11. One noteworthy aspect of their implementation is that 323default arguments are converted to Python objects right at declaration time. 324Consider the following example: 325 326.. code-block:: cpp 327 328 py::class_<MyClass>("MyClass") 329 .def("myFunction", py::arg("arg") = SomeType(123)); 330 331In this case, pybind11 must already be set up to deal with values of the type 332``SomeType`` (via a prior instantiation of ``py::class_<SomeType>``), or an 333exception will be thrown. 334 335Another aspect worth highlighting is that the "preview" of the default argument 336in the function signature is generated using the object's ``__repr__`` method. 337If not available, the signature may not be very helpful, e.g.: 338 339.. code-block:: pycon 340 341 FUNCTIONS 342 ... 343 | myFunction(...) 344 | Signature : (MyClass, arg : SomeType = <SomeType object at 0x101b7b080>) -> NoneType 345 ... 346 347The first way of addressing this is by defining ``SomeType.__repr__``. 348Alternatively, it is possible to specify the human-readable preview of the 349default argument manually using the ``arg_v`` notation: 350 351.. code-block:: cpp 352 353 py::class_<MyClass>("MyClass") 354 .def("myFunction", py::arg_v("arg", SomeType(123), "SomeType(123)")); 355 356Sometimes it may be necessary to pass a null pointer value as a default 357argument. In this case, remember to cast it to the underlying type in question, 358like so: 359 360.. code-block:: cpp 361 362 py::class_<MyClass>("MyClass") 363 .def("myFunction", py::arg("arg") = static_cast<SomeType *>(nullptr)); 364 365Keyword-only arguments 366====================== 367 368Python 3 introduced keyword-only arguments by specifying an unnamed ``*`` 369argument in a function definition: 370 371.. code-block:: python 372 373 def f(a, *, b): # a can be positional or via keyword; b must be via keyword 374 pass 375 376 f(a=1, b=2) # good 377 f(b=2, a=1) # good 378 f(1, b=2) # good 379 f(1, 2) # TypeError: f() takes 1 positional argument but 2 were given 380 381Pybind11 provides a ``py::kw_only`` object that allows you to implement 382the same behaviour by specifying the object between positional and keyword-only 383argument annotations when registering the function: 384 385.. code-block:: cpp 386 387 m.def("f", [](int a, int b) { /* ... */ }, 388 py::arg("a"), py::kw_only(), py::arg("b")); 389 390Note that you currently cannot combine this with a ``py::args`` argument. This 391feature does *not* require Python 3 to work. 392 393.. versionadded:: 2.6 394 395Positional-only arguments 396========================= 397 398Python 3.8 introduced a new positional-only argument syntax, using ``/`` in the 399function definition (note that this has been a convention for CPython 400positional arguments, such as in ``pow()``, since Python 2). You can 401do the same thing in any version of Python using ``py::pos_only()``: 402 403.. code-block:: cpp 404 405 m.def("f", [](int a, int b) { /* ... */ }, 406 py::arg("a"), py::pos_only(), py::arg("b")); 407 408You now cannot give argument ``a`` by keyword. This can be combined with 409keyword-only arguments, as well. 410 411.. versionadded:: 2.6 412 413.. _nonconverting_arguments: 414 415Non-converting arguments 416======================== 417 418Certain argument types may support conversion from one type to another. Some 419examples of conversions are: 420 421* :ref:`implicit_conversions` declared using ``py::implicitly_convertible<A,B>()`` 422* Calling a method accepting a double with an integer argument 423* Calling a ``std::complex<float>`` argument with a non-complex python type 424 (for example, with a float). (Requires the optional ``pybind11/complex.h`` 425 header). 426* Calling a function taking an Eigen matrix reference with a numpy array of the 427 wrong type or of an incompatible data layout. (Requires the optional 428 ``pybind11/eigen.h`` header). 429 430This behaviour is sometimes undesirable: the binding code may prefer to raise 431an error rather than convert the argument. This behaviour can be obtained 432through ``py::arg`` by calling the ``.noconvert()`` method of the ``py::arg`` 433object, such as: 434 435.. code-block:: cpp 436 437 m.def("floats_only", [](double f) { return 0.5 * f; }, py::arg("f").noconvert()); 438 m.def("floats_preferred", [](double f) { return 0.5 * f; }, py::arg("f")); 439 440Attempting the call the second function (the one without ``.noconvert()``) with 441an integer will succeed, but attempting to call the ``.noconvert()`` version 442will fail with a ``TypeError``: 443 444.. code-block:: pycon 445 446 >>> floats_preferred(4) 447 2.0 448 >>> floats_only(4) 449 Traceback (most recent call last): 450 File "<stdin>", line 1, in <module> 451 TypeError: floats_only(): incompatible function arguments. The following argument types are supported: 452 1. (f: float) -> float 453 454 Invoked with: 4 455 456You may, of course, combine this with the :var:`_a` shorthand notation (see 457:ref:`keyword_args`) and/or :ref:`default_args`. It is also permitted to omit 458the argument name by using the ``py::arg()`` constructor without an argument 459name, i.e. by specifying ``py::arg().noconvert()``. 460 461.. note:: 462 463 When specifying ``py::arg`` options it is necessary to provide the same 464 number of options as the bound function has arguments. Thus if you want to 465 enable no-convert behaviour for just one of several arguments, you will 466 need to specify a ``py::arg()`` annotation for each argument with the 467 no-convert argument modified to ``py::arg().noconvert()``. 468 469.. _none_arguments: 470 471Allow/Prohibiting None arguments 472================================ 473 474When a C++ type registered with :class:`py::class_` is passed as an argument to 475a function taking the instance as pointer or shared holder (e.g. ``shared_ptr`` 476or a custom, copyable holder as described in :ref:`smart_pointers`), pybind 477allows ``None`` to be passed from Python which results in calling the C++ 478function with ``nullptr`` (or an empty holder) for the argument. 479 480To explicitly enable or disable this behaviour, using the 481``.none`` method of the :class:`py::arg` object: 482 483.. code-block:: cpp 484 485 py::class_<Dog>(m, "Dog").def(py::init<>()); 486 py::class_<Cat>(m, "Cat").def(py::init<>()); 487 m.def("bark", [](Dog *dog) -> std::string { 488 if (dog) return "woof!"; /* Called with a Dog instance */ 489 else return "(no dog)"; /* Called with None, dog == nullptr */ 490 }, py::arg("dog").none(true)); 491 m.def("meow", [](Cat *cat) -> std::string { 492 // Can't be called with None argument 493 return "meow"; 494 }, py::arg("cat").none(false)); 495 496With the above, the Python call ``bark(None)`` will return the string ``"(no 497dog)"``, while attempting to call ``meow(None)`` will raise a ``TypeError``: 498 499.. code-block:: pycon 500 501 >>> from animals import Dog, Cat, bark, meow 502 >>> bark(Dog()) 503 'woof!' 504 >>> meow(Cat()) 505 'meow' 506 >>> bark(None) 507 '(no dog)' 508 >>> meow(None) 509 Traceback (most recent call last): 510 File "<stdin>", line 1, in <module> 511 TypeError: meow(): incompatible function arguments. The following argument types are supported: 512 1. (cat: animals.Cat) -> str 513 514 Invoked with: None 515 516The default behaviour when the tag is unspecified is to allow ``None``. 517 518.. note:: 519 520 Even when ``.none(true)`` is specified for an argument, ``None`` will be converted to a 521 ``nullptr`` *only* for custom and :ref:`opaque <opaque>` types. Pointers to built-in types 522 (``double *``, ``int *``, ...) and STL types (``std::vector<T> *``, ...; if ``pybind11/stl.h`` 523 is included) are copied when converted to C++ (see :doc:`/advanced/cast/overview`) and will 524 not allow ``None`` as argument. To pass optional argument of these copied types consider 525 using ``std::optional<T>`` 526 527.. _overload_resolution: 528 529Overload resolution order 530========================= 531 532When a function or method with multiple overloads is called from Python, 533pybind11 determines which overload to call in two passes. The first pass 534attempts to call each overload without allowing argument conversion (as if 535every argument had been specified as ``py::arg().noconvert()`` as described 536above). 537 538If no overload succeeds in the no-conversion first pass, a second pass is 539attempted in which argument conversion is allowed (except where prohibited via 540an explicit ``py::arg().noconvert()`` attribute in the function definition). 541 542If the second pass also fails a ``TypeError`` is raised. 543 544Within each pass, overloads are tried in the order they were registered with 545pybind11. If the ``py::prepend()`` tag is added to the definition, a function 546can be placed at the beginning of the overload sequence instead, allowing user 547overloads to proceed built in functions. 548 549What this means in practice is that pybind11 will prefer any overload that does 550not require conversion of arguments to an overload that does, but otherwise 551prefers earlier-defined overloads to later-defined ones. 552 553.. note:: 554 555 pybind11 does *not* further prioritize based on the number/pattern of 556 overloaded arguments. That is, pybind11 does not prioritize a function 557 requiring one conversion over one requiring three, but only prioritizes 558 overloads requiring no conversion at all to overloads that require 559 conversion of at least one argument. 560 561.. versionadded:: 2.6 562 563 The ``py::prepend()`` tag. 564