example11.cpp 1.89 KB
Newer Older
1
2
3
/*
    example/example11.cpp -- keyword arguments and default values

4
    Copyright (c) 2016 Wenzel Jakob <wenzel.jakob@epfl.ch>
5
6
7
8
9
10

    All rights reserved. Use of this source code is governed by a
    BSD-style license that can be found in the LICENSE file.
*/

#include "example.h"
11
#include <pybind11/stl.h>
12
13
14

void kw_func(int x, int y) { std::cout << "kw_func(x=" << x << ", y=" << y << ")" << std::endl; }

15
16
17
18
19
20
21
void kw_func4(const std::vector<int> &entries) {
    std::cout << "kw_func4: ";
    for (int i : entries)
        std::cout << i << " ";
    std::cout << endl;
}

22
py::object call_kw_func(py::function f) {
23
24
25
    py::tuple args = py::make_tuple(1234);
    py::dict kwargs;
    kwargs["y"] = py::cast(5678);
26
27
28
29
    return f(*args, **kwargs);
}

void args_function(py::args args) {
30
31
    for (size_t it=0; it<args.size(); ++it)
        std::cout << "got argument: " << py::object(args[it]) << std::endl;
32
33
34
35
36
37
38
39
40
}

void args_kwargs_function(py::args args, py::kwargs kwargs) {
    for (auto item : args)
        std::cout << "got argument: " << item << std::endl;
    if (kwargs) {
        for (auto item : kwargs)
            std::cout << "got keyword argument: " << item.first << " -> " << item.second << std::endl;
    }
41
42
}

43
44
45
void init_ex11(py::module &m) {
    m.def("kw_func", &kw_func, py::arg("x"), py::arg("y"));
    m.def("kw_func2", &kw_func, py::arg("x") = 100, py::arg("y") = 200);
46
    m.def("kw_func3", [](const char *) { }, py::arg("data") = std::string("Hello world!"));
47
48
49
50
51
52
53

    /* A fancier default argument */
    std::vector<int> list;
    list.push_back(13);
    list.push_back(17);

    m.def("kw_func4", &kw_func4, py::arg("myList") = list);
54
    m.def("call_kw_func", &call_kw_func);
55
56
57

    m.def("args_function", &args_function);
    m.def("args_kwargs_function", &args_kwargs_function);
58
59
60

    using namespace py::literals;
    m.def("kw_func_udl", &kw_func, "x"_a, "y"_a=300);
61
    m.def("kw_func_udl_z", &kw_func, "x"_a, "y"_a=0);
62
}