/usr/include/shiboken/typeresolver.h is in libshiboken-dev 1.2.2-3.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | /*
* This file is part of the Shiboken Python Bindings Generator project.
*
* Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
*
* Contact: PySide team <contact@pyside.org>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef TYPERESOLVER_H
#define TYPERESOLVER_H
#include "shibokenmacros.h"
#include "conversions.h"
namespace Shiboken
{
/* To C++ convertion functions. */
template <typename T>
inline void pythonToValueType(PyObject* pyobj, void** data)
{
*reinterpret_cast<T*>(*data) = Shiboken::Converter<T>::toCpp(pyobj);
}
template <typename T>
inline void pythonToObjectType(PyObject* pyobj, void** data)
{
*reinterpret_cast<T**>(*data) = Shiboken::Converter<T*>::toCpp(pyobj);
}
template <typename T>
inline PyObject* objectTypeToPython(void* cptr)
{
return Shiboken::Converter<T*>::toPython(*reinterpret_cast<T**>(cptr));
}
template <typename T>
inline PyObject* referenceTypeToPython(void* cptr)
{
// cptr comes the same way it come when we have a value type, but
// we deliver a Python object of a reference
return Shiboken::Converter<T&>::toPython(*reinterpret_cast<T*>(cptr));
}
/**
* \internal This function is not part of the public API.
* Initialize the TypeResource internal cache.
*/
void initTypeResolver();
class LIBSHIBOKEN_API TypeResolver
{
public:
enum Type
{
ObjectType,
ValueType,
UnknownType
};
typedef PyObject* (*CppToPythonFunc)(void*);
typedef void (*PythonToCppFunc)(PyObject*, void**);
~TypeResolver();
template<typename T>
static TypeResolver* createValueTypeResolver(const char* typeName)
{
return createTypeResolver(typeName, &Shiboken::Converter<T>::toPython, &pythonToValueType<T>, SbkType<T>());
}
template<typename T>
static TypeResolver* createObjectTypeResolver(const char* typeName)
{
return createTypeResolver(typeName, &objectTypeToPython<T>, &pythonToObjectType<T>, SbkType<T>());
}
/**
* This kind of type resolver is used only when we have a signal with a reference in their arguments
* like on QSqlTableModel::primeInsert.
*/
template<typename T>
static TypeResolver* createReferenceTypeResolver(const char* typeName)
{
return createTypeResolver(typeName, &referenceTypeToPython<T>, &pythonToValueType<T>, SbkType<T>());
}
static Type getType(const char* name);
static TypeResolver* get(const char* typeName);
PyObject* toPython(void* cppObj);
void toCpp(PyObject* pyObj, void** place);
PyTypeObject* pythonType();
private:
struct TypeResolverPrivate;
TypeResolverPrivate* m_d;
TypeResolver();
// disable object copy
TypeResolver(const TypeResolver&);
TypeResolver& operator=(const TypeResolver&);
static TypeResolver* createTypeResolver(const char* typeName, CppToPythonFunc cppToPy, PythonToCppFunc pyToCpp, PyTypeObject* pyType);
};
}
#endif
|