20 m.def(
"test_callback1", [](
py::object func) {
return func(); });
21 m.def(
"test_callback2", [](
py::object func) {
return func(
"Hello",
'x',
true, 5); });
22 m.def(
"test_callback3", [](
const std::function<
int(
int)> &func) {
24 m.def(
"test_callback4", []() -> std::function<
int(
int)> {
return [](
int i) {
return i+1; }; });
25 m.def(
"test_callback5", []() {
33 return f(
"positional", 1, *t1, 4, *t2);
37 auto d1 =
py::dict(
"key"_a=
"value",
"a"_a=1);
40 return f(
"positional", 1, **d1, **d2, **d3);
44 return f(
"x"_a=10,
"y"_a=20);
47 m.def(
"test_unpacking_and_keywords1", [](
py::function f) {
50 return f(1, *args,
"c"_a=3, **
kwargs);
53 m.def(
"test_unpacking_and_keywords2", [](
py::function f) {
55 auto kwargs2 =
py::dict(
"c"_a=3,
"d"_a=4);
57 "key"_a=
"value", **kwargs1,
"b"_a=2, **kwargs2,
"e"_a=5);
62 return f(
"x"_a=1,
"y"_a=2, **
kwargs);
67 return f(**
kwargs,
"x"_a=1);
86 m.def(
"payload_cstats", &ConstructorStats::get<Payload>);
88 m.def(
"test_cleanup", []() -> std::function<
void(
void)> {
100 m.def(
"dummy_function2", [](
int i,
int j) {
return i + j; });
101 m.def(
"roundtrip", [](std::function<
int(
int)> f,
bool expect_none =
false) {
102 if (expect_none && f)
103 throw std::runtime_error(
"Expected None to be converted to empty std::function");
106 m.def(
"test_dummy_function", [](
const std::function<
int(
int)> &f) -> std::string {
107 using fn_type = int (*)(int);
108 auto result = f.target<fn_type>();
111 return "can't convert to function pointer: eval(1) = " +
std::to_string(r);
113 auto r = (*result)(1);
116 return "argument does NOT match dummy_function. This should never happen!";
120 class AbstractBase {
public:
virtual unsigned int func() = 0; };
121 m.def(
"func_accepting_func_accepting_base", [](std::function<
double(AbstractBase&)>) { });
123 struct MovableObject {
126 MovableObject() =
default;
127 MovableObject(
const MovableObject &) =
default;
128 MovableObject &operator=(
const MovableObject &) =
default;
129 MovableObject(MovableObject &&o) : valid(o.valid) { o.valid =
false; }
130 MovableObject &operator=(MovableObject &&o) {
139 m.
def(
"callback_with_movable", [](std::function<
void(MovableObject &)> f) {
140 auto x = MovableObject();
146 struct CppBoundMethodTest {};
149 .def(
"triple", [](CppBoundMethodTest &,
int val) {
return 3 * val; });
152 using callback_f = std::function<void(int)>;
153 m.
def(
"test_async_callback", [](callback_f f,
py::list work) {
155 auto start_f = [f](
int j) {
156 auto invoke_f = [f, j] {
157 std::this_thread::sleep_for(std::chrono::milliseconds(50));
160 auto t = std::thread(
std::move(invoke_f));
166 start_f(py::cast<int>(i));
Wraps an arbitrary C++ function/method/lambda function/.. into a callable Python object.
test_initializer callbacks("callbacks", test_submodule_callbacks)
Dummy type which is not exported anywhere – something to trigger a conversion error.
void print_destroyed(T *inst, Values &&...values)
void print_copy_created(T *inst, Values &&...values)
void print_default_created(T *inst, Values &&...values)
int dummy_function(int i)
detail::enable_if_t<!detail::move_never< T >::value, T > move(object &&obj)
void print_move_created(T *inst, Values &&...values)
#define TEST_SUBMODULE(name, variable)
bool typename Extra class_ & def(const char *name_, Func &&f, const Extra &... extra)
auto to_string(T &&value) -> decltype(std::forward< T >(value))
Convert an object to a string (directly forward if this can become a string)