cast.h 35.3 KB
Newer Older
Wenzel Jakob's avatar
Wenzel Jakob committed
1
/*
2
    pybind11/cast.h: Partial template specializations to cast between
Wenzel Jakob's avatar
Wenzel Jakob committed
3
4
    C++ and Python types

5
    Copyright (c) 2016 Wenzel Jakob <wenzel.jakob@epfl.ch>
Wenzel Jakob's avatar
Wenzel Jakob committed
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.
*/

11
#pragma once
Wenzel Jakob's avatar
Wenzel Jakob committed
12

13
14
#include "pytypes.h"
#include "typeid.h"
15
#include "descr.h"
Wenzel Jakob's avatar
Wenzel Jakob committed
16
#include <array>
Wenzel Jakob's avatar
Wenzel Jakob committed
17
#include <limits>
18
#include <iostream>
Wenzel Jakob's avatar
Wenzel Jakob committed
19

20
NAMESPACE_BEGIN(pybind11)
Wenzel Jakob's avatar
Wenzel Jakob committed
21
22
NAMESPACE_BEGIN(detail)

Wenzel Jakob's avatar
Wenzel Jakob committed
23
24
25
26
27
28
29
30
31
/// Additional type information which does not fit into the PyTypeObject
struct type_info {
    PyTypeObject *type;
    size_t type_size;
    void (*init_holder)(PyObject *, const void *);
    std::vector<PyObject *(*)(PyObject *, PyTypeObject *) > implicit_conversions;
    buffer_info *(*get_buffer)(PyObject *, void *) = nullptr;
    void *get_buffer_data = nullptr;
};
32

Wenzel Jakob's avatar
Wenzel Jakob committed
33
34
35
36
37
PYBIND11_NOINLINE inline internals &get_internals() {
    static internals *internals_ptr = nullptr;
    if (internals_ptr)
        return *internals_ptr;
    handle builtins(PyEval_GetBuiltins());
38
39
    const char *id = PYBIND11_INTERNALS_ID;
    capsule caps(builtins[id]);
Wenzel Jakob's avatar
Wenzel Jakob committed
40
41
42
43
    if (caps.check()) {
        internals_ptr = caps;
    } else {
        internals_ptr = new internals();
44
45
46
47
48
49
50
        #if defined(WITH_THREAD)
            PyEval_InitThreads();
            PyThreadState *tstate = PyThreadState_Get();
            internals_ptr->tstate = PyThread_create_key();
            PyThread_set_key_value(internals_ptr->tstate, tstate);
            internals_ptr->istate = tstate->interp;
        #endif
51
        builtins[id] = capsule(internals_ptr);
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
        internals_ptr->registered_exception_translators.push_front(
            [](std::exception_ptr p) -> void {
                try {
                    if (p) std::rethrow_exception(p);
                } catch (const error_already_set &)      {                                                 return;
                } catch (const index_error &e)           { PyErr_SetString(PyExc_IndexError,    e.what()); return;
                } catch (const value_error &e)           { PyErr_SetString(PyExc_ValueError,    e.what()); return;
                } catch (const stop_iteration &e)        { PyErr_SetString(PyExc_StopIteration, e.what()); return;
                } catch (const std::bad_alloc &e)        { PyErr_SetString(PyExc_MemoryError,   e.what()); return;
                } catch (const std::domain_error &e)     { PyErr_SetString(PyExc_ValueError,    e.what()); return;
                } catch (const std::invalid_argument &e) { PyErr_SetString(PyExc_ValueError,    e.what()); return;
                } catch (const std::length_error &e)     { PyErr_SetString(PyExc_ValueError,    e.what()); return;
                } catch (const std::out_of_range &e)     { PyErr_SetString(PyExc_IndexError,    e.what()); return;
                } catch (const std::range_error &e)      { PyErr_SetString(PyExc_ValueError,    e.what()); return;
                } catch (const std::exception &e)        { PyErr_SetString(PyExc_RuntimeError,  e.what()); return;
                } catch (...) {
                    PyErr_SetString(PyExc_RuntimeError, "Caught an unknown exception!");
                    return;
                }
            }
        );
Wenzel Jakob's avatar
Wenzel Jakob committed
73
74
75
76
    }
    return *internals_ptr;
}

77
PYBIND11_NOINLINE inline detail::type_info* get_type_info(PyTypeObject *type, bool throw_if_missing = true) {
Wenzel Jakob's avatar
Wenzel Jakob committed
78
79
80
81
82
83
    auto const &type_dict = get_internals().registered_types_py;
    do {
        auto it = type_dict.find(type);
        if (it != type_dict.end())
            return (detail::type_info *) it->second;
        type = type->tp_base;
84
85
86
87
88
        if (!type) {
            if (throw_if_missing)
                pybind11_fail("pybind11::detail::get_type_info: unable to find type object!");
            return nullptr;
        }
Wenzel Jakob's avatar
Wenzel Jakob committed
89
90
91
92
93
94
    } while (true);
}

PYBIND11_NOINLINE inline detail::type_info *get_type_info(const std::type_info &tp) {
    auto &types = get_internals().registered_types_cpp;

95
96
    auto it = types.find(std::type_index(tp));
    if (it != types.end())
Wenzel Jakob's avatar
Wenzel Jakob committed
97
98
99
100
101
102
103
104
105
106
        return (detail::type_info *) it->second;
    return nullptr;
}

PYBIND11_NOINLINE inline handle get_type_handle(const std::type_info &tp) {
    detail::type_info *type_info = get_type_info(tp);
    return handle(type_info ? ((PyObject *) type_info->type) : nullptr);
}

PYBIND11_NOINLINE inline std::string error_string() {
107
108
   PyObject *type, *value, *traceback;
   PyErr_Fetch(&type, &value, &traceback);
Wenzel Jakob's avatar
Wenzel Jakob committed
109

110
111
112
   std::string errorString;
    if (type) {
        errorString += (std::string) handle(type).str();
Wenzel Jakob's avatar
Wenzel Jakob committed
113
114
        errorString += ": ";
    }
115
116
    if (value)
        errorString += (std::string) handle(value).str();
Wenzel Jakob's avatar
Wenzel Jakob committed
117

118
    PyErr_Restore(type, value, traceback);
Wenzel Jakob's avatar
Wenzel Jakob committed
119
120
121
122
123
124
125
126
127
128
129
    return errorString;
}

PYBIND11_NOINLINE inline handle get_object_handle(const void *ptr) {
    auto instances = get_internals().registered_instances;
    auto it = instances.find(ptr);
    if (it == instances.end())
        return handle();
    return handle((PyObject *) it->second);
}

130
131
132
133
134
135
136
137
138
139
140
141
inline PyThreadState *get_thread_state_unchecked() {
#if   PY_VERSION_HEX < 0x03000000
    return _PyThreadState_Current;
#elif PY_VERSION_HEX < 0x03050000
    return (PyThreadState*) _Py_atomic_load_relaxed(&_PyThreadState_Current);
#elif PY_VERSION_HEX < 0x03050200
    return (PyThreadState*) _PyThreadState_Current.value;
#else
    return _PyThreadState_UncheckedGet();
#endif
}

Wenzel Jakob's avatar
Wenzel Jakob committed
142
143
144
145
class type_caster_generic {
public:
    PYBIND11_NOINLINE type_caster_generic(const std::type_info &type_info)
     : typeinfo(get_type_info(type_info)) { }
Wenzel Jakob's avatar
Wenzel Jakob committed
146

Wenzel Jakob's avatar
Wenzel Jakob committed
147
148
    PYBIND11_NOINLINE bool load(handle src, bool convert) {
        if (!src || !typeinfo)
Wenzel Jakob's avatar
Wenzel Jakob committed
149
            return false;
150
151
152
153
        if (src.ptr() == Py_None) {
            value = nullptr;
            return true;
        } else if (PyType_IsSubtype(Py_TYPE(src.ptr()), typeinfo->type)) {
Wenzel Jakob's avatar
Wenzel Jakob committed
154
            value = ((instance<void> *) src.ptr())->value;
Wenzel Jakob's avatar
Wenzel Jakob committed
155
156
157
158
            return true;
        }
        if (convert) {
            for (auto &converter : typeinfo->implicit_conversions) {
Wenzel Jakob's avatar
Wenzel Jakob committed
159
160
                temp = object(converter(src.ptr(), typeinfo->type), false);
                if (load(temp, false))
Wenzel Jakob's avatar
Wenzel Jakob committed
161
162
163
164
165
166
                    return true;
            }
        }
        return false;
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
167
168
    PYBIND11_NOINLINE static handle cast(const void *_src, return_value_policy policy, handle parent,
                                         const std::type_info *type_info,
169
                                         const std::type_info *type_info_backup,
Wenzel Jakob's avatar
Wenzel Jakob committed
170
                                         void *(*copy_constructor)(const void *),
Wenzel Jakob's avatar
Wenzel Jakob committed
171
                                         void *(*move_constructor)(const void *),
Wenzel Jakob's avatar
Wenzel Jakob committed
172
                                         const void *existing_holder = nullptr) {
173
        void *src = const_cast<void *>(_src);
Wenzel Jakob's avatar
Wenzel Jakob committed
174
175
176
        if (src == nullptr)
            return handle(Py_None).inc_ref();

Wenzel Jakob's avatar
Wenzel Jakob committed
177
        // avoid an issue with internal references matching their parent's address
Wenzel Jakob's avatar
Wenzel Jakob committed
178
        bool dont_cache = policy == return_value_policy::reference_internal &&
Wenzel Jakob's avatar
Wenzel Jakob committed
179
180
                          parent && ((instance<void> *) parent.ptr())->value == (void *) src;

Wenzel Jakob's avatar
Wenzel Jakob committed
181
182
        auto& internals = get_internals();
        auto it_instance = internals.registered_instances.find(src);
Wenzel Jakob's avatar
Wenzel Jakob committed
183
184
185
        if (it_instance != internals.registered_instances.end() && !dont_cache)
            return handle((PyObject *) it_instance->second).inc_ref();

186
        auto it = internals.registered_types_cpp.find(std::type_index(*type_info));
187
188
189
190
191
        if (it == internals.registered_types_cpp.end()) {
            type_info = type_info_backup;
            it = internals.registered_types_cpp.find(std::type_index(*type_info));
        }

192
        if (it == internals.registered_types_cpp.end()) {
193
194
195
            std::string tname = type_info->name();
            detail::clean_type_id(tname);
            std::string msg = "Unregistered type : " + tname;
Wenzel Jakob's avatar
Wenzel Jakob committed
196
            PyErr_SetString(PyExc_TypeError, msg.c_str());
Wenzel Jakob's avatar
Wenzel Jakob committed
197
            return handle();
Wenzel Jakob's avatar
Wenzel Jakob committed
198
        }
Wenzel Jakob's avatar
Wenzel Jakob committed
199

200
        auto tinfo = (const detail::type_info *) it->second;
Wenzel Jakob's avatar
Wenzel Jakob committed
201
202
203
204
205
206
207
208
        object inst(PyType_GenericAlloc(tinfo->type, 0), false);

        auto wrapper = (instance<void> *) inst.ptr();

        wrapper->value = src;
        wrapper->owned = true;
        wrapper->parent = nullptr;

Wenzel Jakob's avatar
Wenzel Jakob committed
209
210
        if (policy == return_value_policy::automatic)
            policy = return_value_policy::take_ownership;
211
212
        else if (policy == return_value_policy::automatic_reference)
            policy = return_value_policy::reference;
Wenzel Jakob's avatar
Wenzel Jakob committed
213

Wenzel Jakob's avatar
Wenzel Jakob committed
214
        if (policy == return_value_policy::copy) {
Wenzel Jakob's avatar
Wenzel Jakob committed
215
216
            wrapper->value = copy_constructor(wrapper->value);
            if (wrapper->value == nullptr)
217
                throw cast_error("return_value_policy = copy, but the object is non-copyable!");
Wenzel Jakob's avatar
Wenzel Jakob committed
218
219
220
221
222
223
        } else if (policy == return_value_policy::move) {
            wrapper->value = move_constructor(wrapper->value);
            if (wrapper->value == nullptr)
                wrapper->value = copy_constructor(wrapper->value);
            if (wrapper->value == nullptr)
                throw cast_error("return_value_policy = move, but the object is neither movable nor copyable!");
Wenzel Jakob's avatar
Wenzel Jakob committed
224
        } else if (policy == return_value_policy::reference) {
Wenzel Jakob's avatar
Wenzel Jakob committed
225
            wrapper->owned = false;
Wenzel Jakob's avatar
Wenzel Jakob committed
226
        } else if (policy == return_value_policy::reference_internal) {
Wenzel Jakob's avatar
Wenzel Jakob committed
227
228
            wrapper->owned = false;
            wrapper->parent = parent.inc_ref().ptr();
Wenzel Jakob's avatar
Wenzel Jakob committed
229
        }
Wenzel Jakob's avatar
Wenzel Jakob committed
230
231

        tinfo->init_holder(inst.ptr(), existing_holder);
232
        if (!dont_cache)
Wenzel Jakob's avatar
Wenzel Jakob committed
233
234
235
            internals.registered_instances[wrapper->value] = inst.ptr();

        return inst.release();
Wenzel Jakob's avatar
Wenzel Jakob committed
236
237
238
239
    }

protected:
    const type_info *typeinfo = nullptr;
240
    void *value = nullptr;
Wenzel Jakob's avatar
Wenzel Jakob committed
241
242
243
    object temp;
};

244
245
/* Determine suitable casting operator */
template <typename T>
246
using cast_op_type = typename std::conditional<std::is_pointer<typename std::remove_reference<T>::type>::value,
247
248
249
    typename std::add_pointer<typename intrinsic_type<T>::type>::type,
    typename std::add_lvalue_reference<typename intrinsic_type<T>::type>::type>::type;

250
/// Generic type caster for objects stored on the heap
Wenzel Jakob's avatar
Wenzel Jakob committed
251
template <typename type> class type_caster_base : public type_caster_generic {
252
public:
253
    static PYBIND11_DESCR name() { return type_descr(_<type>()); }
254

Wenzel Jakob's avatar
Wenzel Jakob committed
255
    type_caster_base() : type_caster_generic(typeid(type)) { }
256

Wenzel Jakob's avatar
Wenzel Jakob committed
257
    static handle cast(const type &src, return_value_policy policy, handle parent) {
258
        if (policy == return_value_policy::automatic || policy == return_value_policy::automatic_reference)
259
            policy = return_value_policy::copy;
260
        return cast(&src, policy, parent);
261
262
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
263
264
265
266
267
268
    static handle cast(type &&src, return_value_policy policy, handle parent) {
        if (policy == return_value_policy::automatic || policy == return_value_policy::automatic_reference)
            policy = return_value_policy::move;
        return cast(&src, policy, parent);
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
269
    static handle cast(const type *src, return_value_policy policy, handle parent) {
Wenzel Jakob's avatar
Wenzel Jakob committed
270
271
        return type_caster_generic::cast(
            src, policy, parent, src ? &typeid(*src) : nullptr, &typeid(type),
272
            make_copy_constructor(src), make_move_constructor(src));
273
274
    }

275
276
    template <typename T> using cast_op_type = pybind11::detail::cast_op_type<T>;

277
    operator type*() { return (type *) value; }
278
    operator type&() { if (!value) throw reference_cast_error(); return *((type *) value); }
279

280
protected:
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
    typedef void *(*Constructor)(const void *stream);
#if !defined(_MSC_VER)
    /* Only enabled when the types are {copy,move}-constructible *and* when the type
       does not have a private operator new implementaton. */
    template <typename T = type> static auto make_copy_constructor(const T *value) -> decltype(new T(*value), Constructor(nullptr)) {
        return [](const void *arg) -> void * { return new T(*((const T *) arg)); }; }
    template <typename T = type> static auto make_move_constructor(const T *value) -> decltype(new T(std::move(*((T *) value))), Constructor(nullptr)) {
        return [](const void *arg) -> void * { return (void *) new T(std::move(*((T *) arg))); }; }
#else
    /* Visual Studio 2015's SFINAE implementation doesn't yet handle the above robustly in all situations.
       Use a workaround that only tests for constructibility for now. */
    template <typename T = type, typename = typename std::enable_if<std::is_copy_constructible<T>::value>::type>
    static Constructor make_copy_constructor(const T *value) {
        return [](const void *arg) -> void * { return new T(*((const T *)arg)); }; }
    template <typename T = type, typename = typename std::enable_if<std::is_move_constructible<T>::value>::type>
    static Constructor make_move_constructor(const T *value) {
        return [](const void *arg) -> void * { return (void *) new T(std::move(*((T *)arg))); }; }
#endif
    static Constructor make_copy_constructor(...) { return nullptr; }
    static Constructor make_move_constructor(...) { return nullptr; }
301
302
};

Wenzel Jakob's avatar
Wenzel Jakob committed
303
304
305
template <typename type, typename SFINAE = void> class type_caster : public type_caster_base<type> { };

template <typename type> class type_caster<std::reference_wrapper<type>> : public type_caster_base<type> {
306
307
public:
    static handle cast(const std::reference_wrapper<type> &src, return_value_policy policy, handle parent) {
Wenzel Jakob's avatar
Wenzel Jakob committed
308
        return type_caster_base<type>::cast(&src.get(), policy, parent);
309
    }
310
311
    template <typename T> using cast_op_type = std::reference_wrapper<type>;
    operator std::reference_wrapper<type>() { return std::ref(*((type *) this->value)); }
312
313
};

314
#define PYBIND11_TYPE_CASTER(type, py_name) \
Wenzel Jakob's avatar
Wenzel Jakob committed
315
316
317
    protected: \
        type value; \
    public: \
318
        static PYBIND11_DESCR name() { return type_descr(py_name); } \
Wenzel Jakob's avatar
Wenzel Jakob committed
319
        static handle cast(const type *src, return_value_policy policy, handle parent) { \
Wenzel Jakob's avatar
Wenzel Jakob committed
320
321
322
            return cast(*src, policy, parent); \
        } \
        operator type*() { return &value; } \
323
        operator type&() { return value; } \
324
        template <typename _T> using cast_op_type = pybind11::detail::cast_op_type<_T>
Wenzel Jakob's avatar
Wenzel Jakob committed
325

326
327
328
329
330
331
332
#define PYBIND11_DECLARE_HOLDER_TYPE(type, holder_type) \
    namespace pybind11 { namespace detail { \
    template <typename type> class type_caster<holder_type> \
        : public type_caster_holder<type, holder_type> { }; \
    }}


Wenzel Jakob's avatar
Wenzel Jakob committed
333
334
335
336
337
338
339
340
template <typename T>
struct type_caster<
    T, typename std::enable_if<std::is_integral<T>::value ||
                               std::is_floating_point<T>::value>::type> {
    typedef typename std::conditional<sizeof(T) <= sizeof(long), long, long long>::type _py_type_0;
    typedef typename std::conditional<std::is_signed<T>::value, _py_type_0, typename std::make_unsigned<_py_type_0>::type>::type _py_type_1;
    typedef typename std::conditional<std::is_floating_point<T>::value, double, _py_type_1>::type py_type;
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
341

Wenzel Jakob's avatar
Wenzel Jakob committed
342
    bool load(handle src, bool) {
Wenzel Jakob's avatar
Wenzel Jakob committed
343
        py_type py_value;
Wenzel Jakob's avatar
Wenzel Jakob committed
344

345
346
347
        if (!src) {
            return false;
        } if (std::is_floating_point<T>::value) {
Wenzel Jakob's avatar
Wenzel Jakob committed
348
            py_value = (py_type) PyFloat_AsDouble(src.ptr());
Wenzel Jakob's avatar
Wenzel Jakob committed
349
        } else if (sizeof(T) <= sizeof(long)) {
350
351
            if (PyFloat_Check(src.ptr()))
                return false;
Wenzel Jakob's avatar
Wenzel Jakob committed
352
            if (std::is_signed<T>::value)
Wenzel Jakob's avatar
Wenzel Jakob committed
353
                py_value = (py_type) PyLong_AsLong(src.ptr());
Wenzel Jakob's avatar
Wenzel Jakob committed
354
            else
Wenzel Jakob's avatar
Wenzel Jakob committed
355
                py_value = (py_type) PyLong_AsUnsignedLong(src.ptr());
Wenzel Jakob's avatar
Wenzel Jakob committed
356
        } else {
357
358
            if (PyFloat_Check(src.ptr()))
                return false;
Wenzel Jakob's avatar
Wenzel Jakob committed
359
            if (std::is_signed<T>::value)
Wenzel Jakob's avatar
Wenzel Jakob committed
360
                py_value = (py_type) PYBIND11_LONG_AS_LONGLONG(src.ptr());
Wenzel Jakob's avatar
Wenzel Jakob committed
361
            else
Wenzel Jakob's avatar
Wenzel Jakob committed
362
                py_value = (py_type) PYBIND11_LONG_AS_UNSIGNED_LONGLONG(src.ptr());
Wenzel Jakob's avatar
Wenzel Jakob committed
363
364
365
366
367
368
369
370
371
        }

        if ((py_value == (py_type) -1 && PyErr_Occurred()) ||
            (std::is_integral<T>::value && sizeof(py_type) != sizeof(T) &&
               (py_value < (py_type) std::numeric_limits<T>::min() ||
                py_value > (py_type) std::numeric_limits<T>::max()))) {
            PyErr_Clear();
            return false;
        }
Wenzel Jakob's avatar
Wenzel Jakob committed
372

Wenzel Jakob's avatar
Wenzel Jakob committed
373
374
375
376
        value = (T) py_value;
        return true;
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
377
    static handle cast(T src, return_value_policy /* policy */, handle /* parent */) {
Wenzel Jakob's avatar
Wenzel Jakob committed
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
        if (std::is_floating_point<T>::value) {
            return PyFloat_FromDouble((double) src);
        } else if (sizeof(T) <= sizeof(long)) {
            if (std::is_signed<T>::value)
                return PyLong_FromLong((long) src);
            else
                return PyLong_FromUnsignedLong((unsigned long) src);
        } else {
            if (std::is_signed<T>::value)
                return PyLong_FromLongLong((long long) src);
            else
                return PyLong_FromUnsignedLongLong((unsigned long long) src);
        }
    }

393
    PYBIND11_TYPE_CASTER(T, _<std::is_integral<T>::value>("int", "float"));
Wenzel Jakob's avatar
Wenzel Jakob committed
394
};
Wenzel Jakob's avatar
Wenzel Jakob committed
395

396
template <> class type_caster<void_type> {
Wenzel Jakob's avatar
Wenzel Jakob committed
397
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
398
399
400
    bool load(handle, bool) { return false; }
    static handle cast(void_type, return_value_policy /* policy */, handle /* parent */) {
        return handle(Py_None).inc_ref();
Wenzel Jakob's avatar
Wenzel Jakob committed
401
    }
402
    PYBIND11_TYPE_CASTER(void_type, _("None"));
Wenzel Jakob's avatar
Wenzel Jakob committed
403
404
};

405
406
407
408
409
template <> class type_caster<void> : public type_caster<void_type> {
public:
    using type_caster<void_type>::cast;

    bool load(handle h, bool) {
410
411
412
        if (!h) {
            return false;
        } else if (h.ptr() == Py_None) {
413
414
415
            value = nullptr;
            return true;
        }
416
417

        /* Check if this is a capsule */
418
        capsule c(h, true);
419
420
421
422
423
424
425
426
427
428
429
430
431
        if (c.check()) {
            value = (void *) c;
            return true;
        }

        /* Check if this is a C++ type */
        if (get_type_info((PyTypeObject *) h.get_type().ptr(), false)) {
            value = ((instance<void> *) h.ptr())->value;
            return true;
        }

        /* Fail */
        return false;
432
433
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
434
    static handle cast(const void *ptr, return_value_policy /* policy */, handle /* parent */) {
435
436
437
438
        if (ptr)
            return capsule(ptr).release();
        else
            return handle(Py_None).inc_ref();
439
    }
440

441
442
    template <typename T> using cast_op_type = void*&;
    operator void *&() { return value; }
443
    static PYBIND11_DESCR name() { return type_descr(_("capsule")); }
444
private:
445
    void *value = nullptr;
446
447
};

Wenzel Jakob's avatar
Wenzel Jakob committed
448
template <> class type_caster<std::nullptr_t> : public type_caster<void_type> { };
449

Wenzel Jakob's avatar
Wenzel Jakob committed
450
451
template <> class type_caster<bool> {
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
452
    bool load(handle src, bool) {
453
454
        if (!src) return false;
        else if (src.ptr() == Py_True) { value = true; return true; }
Wenzel Jakob's avatar
Wenzel Jakob committed
455
        else if (src.ptr() == Py_False) { value = false; return true; }
Wenzel Jakob's avatar
Wenzel Jakob committed
456
457
        else return false;
    }
Wenzel Jakob's avatar
Wenzel Jakob committed
458
459
    static handle cast(bool src, return_value_policy /* policy */, handle /* parent */) {
        return handle(src ? Py_True : Py_False).inc_ref();
Wenzel Jakob's avatar
Wenzel Jakob committed
460
    }
461
    PYBIND11_TYPE_CASTER(bool, _("bool"));
Wenzel Jakob's avatar
Wenzel Jakob committed
462
463
464
465
};

template <> class type_caster<std::string> {
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
466
    bool load(handle src, bool) {
467
        object temp;
Wenzel Jakob's avatar
Wenzel Jakob committed
468
        handle load_src = src;
469
470
471
        if (!src) {
            return false;
        } else if (PyUnicode_Check(load_src.ptr())) {
Wenzel Jakob's avatar
Wenzel Jakob committed
472
            temp = object(PyUnicode_AsUTF8String(load_src.ptr()), false);
473
            if (!temp) { PyErr_Clear(); return false; }  // UnicodeEncodeError
Wenzel Jakob's avatar
Wenzel Jakob committed
474
            load_src = temp;
475
476
477
        }
        char *buffer;
        ssize_t length;
Wenzel Jakob's avatar
Wenzel Jakob committed
478
        int err = PYBIND11_BYTES_AS_STRING_AND_SIZE(load_src.ptr(), &buffer, &length);
479
        if (err == -1) { PyErr_Clear(); return false; }  // TypeError
480
        value = std::string(buffer, (size_t) length);
481
        success = true;
Wenzel Jakob's avatar
Wenzel Jakob committed
482
483
        return true;
    }
484

Wenzel Jakob's avatar
Wenzel Jakob committed
485
    static handle cast(const std::string &src, return_value_policy /* policy */, handle /* parent */) {
486
        return PyUnicode_FromStringAndSize(src.c_str(), (ssize_t) src.length());
Wenzel Jakob's avatar
Wenzel Jakob committed
487
    }
488
489

    PYBIND11_TYPE_CASTER(std::string, _(PYBIND11_STRING_NAME));
490
491
protected:
    bool success = false;
Wenzel Jakob's avatar
Wenzel Jakob committed
492
493
};

494
495
496
template <typename type> class type_caster<std::unique_ptr<type>> {
public:
    static handle cast(std::unique_ptr<type> &&src, return_value_policy policy, handle parent) {
Wenzel Jakob's avatar
Wenzel Jakob committed
497
        handle result = type_caster_base<type>::cast(src.get(), policy, parent);
498
499
500
501
        if (result)
            src.release();
        return result;
    }
Wenzel Jakob's avatar
Wenzel Jakob committed
502
    static PYBIND11_DESCR name() { return type_caster_base<type>::name(); }
503
504
};

hulucc's avatar
hulucc committed
505
template <> class type_caster<std::wstring> {
Wenzel Jakob's avatar
Wenzel Jakob committed
506
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
507
508
509
    bool load(handle src, bool) {
        object temp;
        handle load_src = src;
510
511
512
        if (!src) {
            return false;
        } else if (!PyUnicode_Check(load_src.ptr())) {
Wenzel Jakob's avatar
Wenzel Jakob committed
513
514
515
516
            temp = object(PyUnicode_FromObject(load_src.ptr()), false);
            if (!temp) { PyErr_Clear(); return false; }
            load_src = temp;
        }
517
518
519
520
521
522
523
524
525
526
527
528
        wchar_t *buffer = nullptr;
        ssize_t length = -1;
#if PY_MAJOR_VERSION >= 3
        buffer = PyUnicode_AsWideCharString(load_src.ptr(), &length);
#else
        temp = object(
            sizeof(wchar_t) == sizeof(short)
                ? PyUnicode_AsUTF16String(load_src.ptr())
                : PyUnicode_AsUTF32String(load_src.ptr()), false);
        if (temp) {
            int err = PYBIND11_BYTES_AS_STRING_AND_SIZE(temp.ptr(), (char **) &buffer, &length);
            if (err == -1) { buffer = nullptr; }  // TypeError
529
            length = length / (ssize_t) sizeof(wchar_t) - 1; ++buffer; // Skip BOM
530
        }
531
532
#endif
        if (!buffer) { PyErr_Clear(); return false; }
533
        value = std::wstring(buffer, (size_t) length);
Wenzel Jakob's avatar
Wenzel Jakob committed
534
535
536
        success = true;
        return true;
    }
hulucc's avatar
hulucc committed
537

Wenzel Jakob's avatar
Wenzel Jakob committed
538
    static handle cast(const std::wstring &src, return_value_policy /* policy */, handle /* parent */) {
539
        return PyUnicode_FromWideChar(src.c_str(), (ssize_t) src.length());
Wenzel Jakob's avatar
Wenzel Jakob committed
540
    }
Wenzel Jakob's avatar
Wenzel Jakob committed
541

Wenzel Jakob's avatar
Wenzel Jakob committed
542
    PYBIND11_TYPE_CASTER(std::wstring, _(PYBIND11_STRING_NAME));
543
544
protected:
    bool success = false;
hulucc's avatar
hulucc committed
545
546
};

547
template <> class type_caster<char> : public type_caster<std::string> {
Wenzel Jakob's avatar
Wenzel Jakob committed
548
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
549
    bool load(handle src, bool convert) {
550
        if (src.ptr() == Py_None) return true;
551
552
553
        return type_caster<std::string>::load(src, convert);
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
554
    static handle cast(const char *src, return_value_policy /* policy */, handle /* parent */) {
555
        if (src == nullptr) return handle(Py_None).inc_ref();
Wenzel Jakob's avatar
Wenzel Jakob committed
556
557
558
        return PyUnicode_FromString(src);
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
559
    static handle cast(char src, return_value_policy /* policy */, handle /* parent */) {
Wenzel Jakob's avatar
Wenzel Jakob committed
560
561
562
563
        char str[2] = { src, '\0' };
        return PyUnicode_DecodeLatin1(str, 1, nullptr);
    }

564
    operator char*() { return success ? (char *) value.c_str() : nullptr; }
Wenzel Jakob's avatar
Wenzel Jakob committed
565
    operator char&() { return value[0]; }
566

567
    static PYBIND11_DESCR name() { return type_descr(_(PYBIND11_STRING_NAME)); }
Wenzel Jakob's avatar
Wenzel Jakob committed
568
569
};

570
template <> class type_caster<wchar_t> : public type_caster<std::wstring> {
hulucc's avatar
hulucc committed
571
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
572
    bool load(handle src, bool convert) {
573
        if (src.ptr() == Py_None) return true;
574
575
576
        return type_caster<std::wstring>::load(src, convert);
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
577
    static handle cast(const wchar_t *src, return_value_policy /* policy */, handle /* parent */) {
578
        if (src == nullptr) return handle(Py_None).inc_ref();
579
        return PyUnicode_FromWideChar(src, (ssize_t) wcslen(src));
Wenzel Jakob's avatar
Wenzel Jakob committed
580
    }
hulucc's avatar
hulucc committed
581

Wenzel Jakob's avatar
Wenzel Jakob committed
582
583
584
585
    static handle cast(wchar_t src, return_value_policy /* policy */, handle /* parent */) {
        wchar_t wstr[2] = { src, L'\0' };
        return PyUnicode_FromWideChar(wstr, 1);
    }
hulucc's avatar
hulucc committed
586

587
    operator wchar_t*() { return success ? (wchar_t *) value.c_str() : nullptr; }
Wenzel Jakob's avatar
Wenzel Jakob committed
588
    operator wchar_t&() { return value[0]; }
hulucc's avatar
hulucc committed
589

Wenzel Jakob's avatar
Wenzel Jakob committed
590
    static PYBIND11_DESCR name() { return type_descr(_(PYBIND11_STRING_NAME)); }
hulucc's avatar
hulucc committed
591
592
};

Wenzel Jakob's avatar
Wenzel Jakob committed
593
594
595
template <typename T1, typename T2> class type_caster<std::pair<T1, T2>> {
    typedef std::pair<T1, T2> type;
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
596
    bool load(handle src, bool convert) {
597
598
599
        if (!src)
            return false;
        else if (!PyTuple_Check(src.ptr()) || PyTuple_Size(src.ptr()) != 2)
Wenzel Jakob's avatar
Wenzel Jakob committed
600
            return false;
Wenzel Jakob's avatar
Wenzel Jakob committed
601
602
        return  first.load(PyTuple_GET_ITEM(src.ptr(), 0), convert) &&
               second.load(PyTuple_GET_ITEM(src.ptr(), 1), convert);
Wenzel Jakob's avatar
Wenzel Jakob committed
603
604
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
605
606
607
    static handle cast(const type &src, return_value_policy policy, handle parent) {
        object o1 = object(type_caster<typename intrinsic_type<T1>::type>::cast(src.first, policy, parent), false);
        object o2 = object(type_caster<typename intrinsic_type<T2>::type>::cast(src.second, policy, parent), false);
608
        if (!o1 || !o2)
Wenzel Jakob's avatar
Wenzel Jakob committed
609
610
611
612
613
            return handle();
        tuple result(2);
        PyTuple_SET_ITEM(result.ptr(), 0, o1.release().ptr());
        PyTuple_SET_ITEM(result.ptr(), 1, o2.release().ptr());
        return result.release();
Wenzel Jakob's avatar
Wenzel Jakob committed
614
615
    }

616
617
    static PYBIND11_DESCR name() {
        return type_descr(
618
619
            _("Tuple[") + type_caster<typename intrinsic_type<T1>::type>::name() +
            _(", ") + type_caster<typename intrinsic_type<T2>::type>::name() + _("]"));
Wenzel Jakob's avatar
Wenzel Jakob committed
620
621
    }

622
623
    template <typename T> using cast_op_type = type;

Wenzel Jakob's avatar
Wenzel Jakob committed
624
    operator type() {
625
626
        return type(first .operator typename type_caster<typename intrinsic_type<T1>::type>::template cast_op_type<T1>(),
                    second.operator typename type_caster<typename intrinsic_type<T2>::type>::template cast_op_type<T2>());
Wenzel Jakob's avatar
Wenzel Jakob committed
627
628
    }
protected:
629
630
    type_caster<typename intrinsic_type<T1>::type> first;
    type_caster<typename intrinsic_type<T2>::type> second;
Wenzel Jakob's avatar
Wenzel Jakob committed
631
632
};

633
template <typename... Tuple> class type_caster<std::tuple<Tuple...>> {
Wenzel Jakob's avatar
Wenzel Jakob committed
634
    typedef std::tuple<Tuple...> type;
635
636
637
    typedef std::tuple<typename intrinsic_type<Tuple>::type...> itype;
    typedef std::tuple<args> args_type;
    typedef std::tuple<args, kwargs> args_kwargs_type;
Wenzel Jakob's avatar
Wenzel Jakob committed
638
639
640
public:
    enum { size = sizeof...(Tuple) };

641
642
643
    static constexpr const bool has_kwargs = std::is_same<itype, args_kwargs_type>::value;
    static constexpr const bool has_args = has_kwargs || std::is_same<itype, args_type>::value;

Wenzel Jakob's avatar
Wenzel Jakob committed
644
    bool load(handle src, bool convert) {
645
646
        if (!src || !PyTuple_Check(src.ptr()) || PyTuple_GET_SIZE(src.ptr()) != size)
            return false;
Wenzel Jakob's avatar
Wenzel Jakob committed
647
        return load(src, convert, typename make_index_sequence<sizeof...(Tuple)>::type());
Wenzel Jakob's avatar
Wenzel Jakob committed
648
649
    }

650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
    template <typename T = itype, typename std::enable_if<
        !std::is_same<T, args_type>::value &&
        !std::is_same<T, args_kwargs_type>::value, int>::type = 0>
    bool load_args(handle args, handle, bool convert) {
        return load(args, convert, typename make_index_sequence<sizeof...(Tuple)>::type());
    }

    template <typename T = itype, typename std::enable_if<std::is_same<T, args_type>::value, int>::type = 0>
    bool load_args(handle args, handle, bool convert) {
        std::get<0>(value).load(args, convert);
        return true;
    }

    template <typename T = itype, typename std::enable_if<std::is_same<T, args_kwargs_type>::value, int>::type = 0>
    bool load_args(handle args, handle kwargs, bool convert) {
        std::get<0>(value).load(args, convert);
        std::get<1>(value).load(kwargs, convert);
        return true;
    }
669

Wenzel Jakob's avatar
Wenzel Jakob committed
670
    static handle cast(const type &src, return_value_policy policy, handle parent) {
Wenzel Jakob's avatar
Wenzel Jakob committed
671
        return cast(src, policy, parent, typename make_index_sequence<size>::type());
Wenzel Jakob's avatar
Wenzel Jakob committed
672
673
    }

674
675
676
677
    static PYBIND11_DESCR element_names() {
        return detail::concat(type_caster<typename intrinsic_type<Tuple>::type>::name()...);
    }
    
678
    static PYBIND11_DESCR name() {
679
        return type_descr(_("Tuple[") + element_names() + _("]"));
Wenzel Jakob's avatar
Wenzel Jakob committed
680
681
    }

682
683
    template <typename ReturnValue, typename Func> typename std::enable_if<!std::is_void<ReturnValue>::value, ReturnValue>::type call(Func &&f) {
        return call<ReturnValue>(std::forward<Func>(f), typename make_index_sequence<sizeof...(Tuple)>::type());
Wenzel Jakob's avatar
Wenzel Jakob committed
684
685
    }

686
    template <typename ReturnValue, typename Func> typename std::enable_if<std::is_void<ReturnValue>::value, void_type>::type call(Func &&f) {
687
        call<ReturnValue>(std::forward<Func>(f), typename make_index_sequence<sizeof...(Tuple)>::type());
688
        return void_type();
Wenzel Jakob's avatar
Wenzel Jakob committed
689
690
    }

691
692
    template <typename T> using cast_op_type = type;

Wenzel Jakob's avatar
Wenzel Jakob committed
693
    operator type() {
Wenzel Jakob's avatar
Wenzel Jakob committed
694
        return cast(typename make_index_sequence<sizeof...(Tuple)>::type());
Wenzel Jakob's avatar
Wenzel Jakob committed
695
    }
Wenzel Jakob's avatar
Wenzel Jakob committed
696

Wenzel Jakob's avatar
Wenzel Jakob committed
697
protected:
698
    template <typename ReturnValue, typename Func, size_t ... Index> ReturnValue call(Func &&f, index_sequence<Index...>) {
699
700
        return f(std::get<Index>(value)
            .operator typename type_caster<typename intrinsic_type<Tuple>::type>::template cast_op_type<Tuple>()...);
Wenzel Jakob's avatar
Wenzel Jakob committed
701
702
703
    }

    template <size_t ... Index> type cast(index_sequence<Index...>) {
704
705
        return type(std::get<Index>(value)
            .operator typename type_caster<typename intrinsic_type<Tuple>::type>::template cast_op_type<Tuple>()...);
Wenzel Jakob's avatar
Wenzel Jakob committed
706
707
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
708
709
    template <size_t ... Indices> bool load(handle src, bool convert, index_sequence<Indices...>) {
        std::array<bool, size> success {{
710
            std::get<Indices>(value).load(PyTuple_GET_ITEM(src.ptr(), Indices), convert)...
Wenzel Jakob's avatar
Wenzel Jakob committed
711
        }};
712
        (void) convert; /* avoid a warning when the tuple is empty */
Wenzel Jakob's avatar
Wenzel Jakob committed
713
        for (bool r : success)
Wenzel Jakob's avatar
Wenzel Jakob committed
714
715
716
717
718
719
            if (!r)
                return false;
        return true;
    }

    /* Implementation: Convert a C++ tuple into a Python tuple */
Wenzel Jakob's avatar
Wenzel Jakob committed
720
721
    template <size_t ... Indices> static handle cast(const type &src, return_value_policy policy, handle parent, index_sequence<Indices...>) {
        std::array<object, size> entries {{
722
            object(type_caster<typename intrinsic_type<Tuple>::type>::cast(std::get<Indices>(src), policy, parent), false)...
Wenzel Jakob's avatar
Wenzel Jakob committed
723
        }};
Wenzel Jakob's avatar
Wenzel Jakob committed
724
725
726
727
        for (const auto &entry: entries)
            if (!entry)
                return handle();
        tuple result(size);
728
        int counter = 0;
Wenzel Jakob's avatar
Wenzel Jakob committed
729
730
731
        for (auto & entry: entries)
            PyTuple_SET_ITEM(result.ptr(), counter++, entry.release().ptr());
        return result.release();
Wenzel Jakob's avatar
Wenzel Jakob committed
732
733
734
    }

protected:
735
    std::tuple<type_caster<typename intrinsic_type<Tuple>::type>...> value;
Wenzel Jakob's avatar
Wenzel Jakob committed
736
737
738
};

/// Type caster for holder types like std::shared_ptr, etc.
Wenzel Jakob's avatar
Wenzel Jakob committed
739
template <typename type, typename holder_type> class type_caster_holder : public type_caster_base<type> {
Wenzel Jakob's avatar
Wenzel Jakob committed
740
public:
Wenzel Jakob's avatar
Wenzel Jakob committed
741
742
743
744
    using type_caster_base<type>::cast;
    using type_caster_base<type>::typeinfo;
    using type_caster_base<type>::value;
    using type_caster_base<type>::temp;
745

Wenzel Jakob's avatar
Wenzel Jakob committed
746
    bool load(handle src, bool convert) {
747
        if (!src || !typeinfo) {
Wenzel Jakob's avatar
Wenzel Jakob committed
748
            return false;
749
750
751
752
        } else if (src.ptr() == Py_None) {
            value = nullptr;
            return true;
        } else if (PyType_IsSubtype(Py_TYPE(src.ptr()), typeinfo->type)) {
Wenzel Jakob's avatar
Wenzel Jakob committed
753
            auto inst = (instance<type, holder_type> *) src.ptr();
754
            value = (void *) inst->value;
755
756
757
            holder = inst->holder;
            return true;
        }
Wenzel Jakob's avatar
Wenzel Jakob committed
758

759
760
        if (convert) {
            for (auto &converter : typeinfo->implicit_conversions) {
Wenzel Jakob's avatar
Wenzel Jakob committed
761
762
                temp = object(converter(src.ptr(), typeinfo->type), false);
                if (load(temp, false))
763
764
765
766
                    return true;
            }
        }
        return false;
Wenzel Jakob's avatar
Wenzel Jakob committed
767
    }
768

Wenzel Jakob's avatar
Wenzel Jakob committed
769
770
771
    explicit operator type*() { return this->value; }
    explicit operator type&() { return *(this->value); }
    explicit operator holder_type*() { return &holder; }
772

773
774
775
776
777
778
779
780
    // Workaround for Intel compiler bug
    // see pybind11 issue 94
    #if defined(__ICC) || defined(__INTEL_COMPILER)
    operator holder_type&() { return holder; }
    #else
    explicit operator holder_type&() { return holder; }
    #endif

781
    static handle cast(const holder_type &src, return_value_policy, handle) {
782
        return type_caster_generic::cast(
783
            src.get(), return_value_policy::take_ownership, handle(),
784
            src.get() ? &typeid(*src.get()) : nullptr, &typeid(type),
785
            nullptr, nullptr, &src);
786
787
    }

Wenzel Jakob's avatar
Wenzel Jakob committed
788
789
790
791
protected:
    holder_type holder;
};

792
793
template <typename T> struct handle_type_name { static PYBIND11_DESCR name() { return _<T>(); } };
template <> struct handle_type_name<bytes> { static PYBIND11_DESCR name() { return _(PYBIND11_BYTES_NAME); } };
794
795
template <> struct handle_type_name<args> { static PYBIND11_DESCR name() { return _("*args"); } };
template <> struct handle_type_name<kwargs> { static PYBIND11_DESCR name() { return _("**kwargs"); } };
796

797
798
template <typename type>
struct type_caster<type, typename std::enable_if<std::is_base_of<handle, type>::value>::type> {
Wenzel Jakob's avatar
Wenzel Jakob committed
799
public:
800
801
    template <typename T = type, typename std::enable_if<!std::is_base_of<object, T>::value, int>::type = 0>
    bool load(handle src, bool /* convert */) { value = type(src); return value.check(); }
802

803
    template <typename T = type, typename std::enable_if<std::is_base_of<object, T>::value, int>::type = 0>
Wenzel Jakob's avatar
Wenzel Jakob committed
804
    bool load(handle src, bool /* convert */) { value = type(src, true); return value.check(); }
805

Wenzel Jakob's avatar
Wenzel Jakob committed
806
807
    static handle cast(const handle &src, return_value_policy /* policy */, handle /* parent */) {
        return src.inc_ref();
Wenzel Jakob's avatar
Wenzel Jakob committed
808
    }
809
    PYBIND11_TYPE_CASTER(type, handle_type_name<type>::name());
Wenzel Jakob's avatar
Wenzel Jakob committed
810
811
812
813
};

NAMESPACE_END(detail)

Wenzel Jakob's avatar
Wenzel Jakob committed
814
template <typename T> T cast(handle handle) {
815
816
    typedef detail::type_caster<typename detail::intrinsic_type<T>::type> type_caster;
    type_caster conv;
817
818
819
820
821
822
823
824
    if (!conv.load(handle, true)) {
#if defined(NDEBUG)
        throw cast_error("Unable to cast Python instance to C++ type (compile in debug mode for details)");
#else
        throw cast_error("Unable to cast Python instance of type " +
            (std::string) handle.get_type().str() + " to C++ type '" + type_id<T>() + "''");
#endif
    }
825
    return conv.operator typename type_caster::template cast_op_type<T>();
Wenzel Jakob's avatar
Wenzel Jakob committed
826
827
}

828
829
830
template <typename T> object cast(const T &value,
        return_value_policy policy = return_value_policy::automatic_reference,
        handle parent = handle()) {
Wenzel Jakob's avatar
Wenzel Jakob committed
831
832
    if (policy == return_value_policy::automatic)
        policy = std::is_pointer<T>::value ? return_value_policy::take_ownership : return_value_policy::copy;
833
834
    else if (policy == return_value_policy::automatic_reference)
        policy = std::is_pointer<T>::value ? return_value_policy::reference : return_value_policy::copy;
835
    return object(detail::type_caster<typename detail::intrinsic_type<T>::type>::cast(value, policy, parent), false);
Wenzel Jakob's avatar
Wenzel Jakob committed
836
837
}

Wenzel Jakob's avatar
Wenzel Jakob committed
838
template <typename T> T handle::cast() const { return pybind11::cast<T>(*this); }
839
template <> inline void handle::cast() const { return; }
Wenzel Jakob's avatar
Wenzel Jakob committed
840

841
template <return_value_policy policy = return_value_policy::automatic_reference,
Wenzel Jakob's avatar
Wenzel Jakob committed
842
          typename... Args> tuple make_tuple(Args&&... args_) {
Wenzel Jakob's avatar
Wenzel Jakob committed
843
    const size_t size = sizeof...(Args);
Wenzel Jakob's avatar
Wenzel Jakob committed
844
    std::array<object, size> args {
845
        { object(detail::type_caster<typename detail::intrinsic_type<Args>::type>::cast(
846
            std::forward<Args>(args_), policy, nullptr), false)... }
Wenzel Jakob's avatar
Wenzel Jakob committed
847
    };
848
849
850
851
852
853
854
855
856
857
    for (auto &arg_value : args) {
        if (!arg_value) {
#if defined(NDEBUG)
            throw cast_error("make_tuple(): unable to convert arguments to Python object (compile in debug mode for details)");
#else
            throw cast_error("make_tuple(): unable to convert arguments of types '" +
                (std::string) type_id<std::tuple<Args...>>() + "' to Python object");
#endif
        }
    }
858
    tuple result(size);
Wenzel Jakob's avatar
Wenzel Jakob committed
859
    int counter = 0;
Wenzel Jakob's avatar
Wenzel Jakob committed
860
    for (auto &arg_value : args)
861
862
863
864
        PyTuple_SET_ITEM(result.ptr(), counter++, arg_value.release().ptr());
    return result;
}

865
866
867
template <return_value_policy policy,
          typename... Args> object handle::operator()(Args&&... args) const {
    tuple args_tuple = pybind11::make_tuple<policy>(std::forward<Args>(args)...);
Wenzel Jakob's avatar
Wenzel Jakob committed
868
869
    object result(PyObject_CallObject(m_ptr, args_tuple.ptr()), false);
    if (!result)
870
        throw error_already_set();
Wenzel Jakob's avatar
Wenzel Jakob committed
871
    return result;
Wenzel Jakob's avatar
Wenzel Jakob committed
872
873
}

874
875
876
template <return_value_policy policy,
          typename... Args> object handle::call(Args &&... args) const {
    return operator()<policy>(std::forward<Args>(args)...);
877
878
}

879
inline object handle::operator()(detail::args_proxy args) const {
880
881
882
883
884
885
    object result(PyObject_CallObject(m_ptr, args.ptr()), false);
    if (!result)
        throw error_already_set();
    return result;
}

886
inline object handle::operator()(detail::args_proxy args, detail::kwargs_proxy kwargs) const {
887
888
889
890
891
892
    object result(PyObject_Call(m_ptr, args.ptr(), kwargs.ptr()), false);
    if (!result)
        throw error_already_set();
    return result;
}

Wenzel Jakob's avatar
Wenzel Jakob committed
893
894
895
896
897
#define PYBIND11_MAKE_OPAQUE(Type) \
    namespace pybind11 { namespace detail { \
        template<> class type_caster<Type> : public type_caster_base<Type> { }; \
    }}

898
NAMESPACE_END(pybind11)