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