aboutsummaryrefslogtreecommitdiffstats
path: root/sources/shiboken6/libshiboken/tmp-referencetopython
diff options
context:
space:
mode:
Diffstat (limited to 'sources/shiboken6/libshiboken/tmp-referencetopython')
-rw-r--r--sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.cpp214
-rw-r--r--sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.h191
2 files changed, 0 insertions, 405 deletions
diff --git a/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.cpp b/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.cpp
deleted file mode 100644
index b16c1edf0..000000000
--- a/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.cpp
+++ /dev/null
@@ -1,214 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt for Python.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 3 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL3 included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 3 requirements
-** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 2.0 or (at your option) the GNU General
-** Public license version 3 or any later version approved by the KDE Free
-** Qt Foundation. The licenses are as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-2.0.html and
-** https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "sbkconverter.h"
-#include "sbkconverter_p.h"
-#include "basewrapper_p.h"
-
-namespace Shiboken {
-namespace Conversions {
-
-static SbkConverter *createConverterObject(PyTypeObject *type,
- PythonToCppFunc toCppPointerConvFunc,
- IsConvertibleToCppFunc toCppPointerCheckFunc,
- CppToPythonFunc pointerToPythonFunc,
- CppToPythonFunc copyToPythonFunc)
-{
- SbkConverter *converter = new SbkConverter;
- converter->pythonType = type;
-
- converter->pointerToPython = pointerToPythonFunc;
- converter->copyToPython = copyToPythonFunc;
-
- converter->toCppPointerConversion = std::make_pair(toCppPointerCheckFunc, toCppPointerConvFunc);
- converter->toCppConversions.clear();
-
- return converter;
-}
-
-SbkConverter *createConverter(SbkObjectType *type,
- PythonToCppFunc toCppPointerConvFunc,
- IsConvertibleToCppFunc toCppPointerCheckFunc,
- CppToPythonFunc pointerToPythonFunc,
- CppToPythonFunc copyToPythonFunc)
-{
- SbkConverter *converter = createConverterObject(reinterpret_cast<PyTypeObject *>(type),
- toCppPointerConvFunc, toCppPointerCheckFunc,
- pointerToPythonFunc, copyToPythonFunc);
- type->d->converter = converter;
- return converter;
-}
-
-void deleteConverter(SbkConverter *converter)
-{
- if (converter) {
- converter->toCppConversions.clear();
- delete converter;
- }
-}
-
-void addPythonToCppValueConversion(SbkConverter *converter,
- PythonToCppFunc pythonToCppFunc,
- IsConvertibleToCppFunc isConvertibleToCppFunc)
-{
- converter->toCppConversions.push_back(std::make_pair(isConvertibleToCppFunc, pythonToCppFunc));
-}
-void addPythonToCppValueConversion(SbkObjectType *type,
- PythonToCppFunc pythonToCppFunc,
- IsConvertibleToCppFunc isConvertibleToCppFunc)
-{
- addPythonToCppValueConversion(type->d->converter, pythonToCppFunc, isConvertibleToCppFunc);
-}
-
-PyObject *pointerToPython(SbkObjectType *type, const void *cppIn)
-{
- if (!cppIn)
- Py_RETURN_NONE;
- return type->d->converter->pointerToPython(cppIn);
-}
-
-static inline PyObject *CopyCppToPython(SbkConverter *converter, const void *cppIn)
-{
- assert(cppIn);
- return converter->copyToPython(cppIn);
-}
-PyObject *copyToPython(SbkObjectType *type, const void *cppIn)
-{
- return CopyCppToPython(type->d->converter, cppIn);
-}
-PyObject *toPython(SbkConverter *converter, const void *cppIn)
-{
- return CopyCppToPython(converter, cppIn);
-}
-
-PyObject *referenceToPython(SbkObjectType *type, const void *cppIn)
-{
- assert(cppIn);
- PyObject *pyOut = (PyObject *)BindingManager::instance().retrieveWrapper(cppIn);
- if (pyOut) {
- Py_INCREF(pyOut);
- return pyOut;
- }
- // If it is Value Type, return a copy of the C++ object.
- if (type->d->converter->copyToPython)
- return type->d->converter->copyToPython(cppIn);
- // If it is an Object Type, return a copy of the C++ object.
- return type->d->converter->pointerToPython(cppIn);
-}
-
-PythonToCppFunc isPythonToCppPointerConvertible(SbkObjectType *type, PyObject *pyIn)
-{
- assert(pyIn);
- return type->d->converter->toCppPointerConversion.first(pyIn);
-}
-
-static inline PythonToCppFunc IsPythonToCppConvertible(SbkConverter *converter, PyObject *pyIn)
-{
- assert(pyIn);
- ToCppConversionList &convs = converter->toCppConversions;
- for (ToCppConversionList::iterator conv = convs.begin(); conv != convs.end(); ++conv) {
- PythonToCppFunc toCppFunc = 0;
- if ((toCppFunc = (*conv).first(pyIn)))
- return toCppFunc;
- }
- return 0;
-}
-PythonToCppFunc isPythonToCppValueConvertible(SbkObjectType *type, PyObject *pyIn)
-{
- return IsPythonToCppConvertible(type->d->converter, pyIn);
-}
-PythonToCppFunc isPythonToCppConvertible(SbkConverter *converter, PyObject *pyIn)
-{
- return IsPythonToCppConvertible(converter, pyIn);
-}
-
-PythonToCppFunc isPythonToCppReferenceConvertible(SbkObjectType *type, PyObject *pyIn)
-{
- if (pyIn != Py_None) {
- PythonToCppFunc toCpp = isPythonToCppPointerConvertible(type, pyIn);
- if (toCpp)
- return toCpp;
- }
- return isPythonToCppValueConvertible(type, pyIn);
-}
-
-void nonePythonToCppNullPtr(PyObject *, void *cppOut)
-{
- assert(cppOut);
- *reinterpret_cast<void **>(cppOut) = nullptr;
-}
-
-void pythonToCppPointer(SbkObjectType *type, PyObject *pyIn, void *cppOut)
-{
- assert(pyIn);
- assert(cppOut);
- SbkObjectType *inType = (SbkObjectType *)Py_TYPE(pyIn);
- if (ObjectType::hasCast(inType)) {
- *reinterpret_cast<void **>(cppOut) =
- ObjectType::cast(inType, reinterpret_cast<SbkObject *>(pyIn), reinterpret_cast<PyTypeObject *>(type));
- } else {
- *reinterpret_cast<void **>(cppOut) =
- Object::cppPointer(reinterpret_cast<SbkObject *>(pyIn), reinterpret_cast<PyTypeObject *>(type));
- }
-}
-
-bool isImplicitConversion(SbkObjectType *type, PythonToCppFunc toCppFunc)
-{
- // This is the Object Type or Value Type conversion that only
- // retrieves the C++ pointer held in the Python wrapper.
- if (toCppFunc == type->d->converter->toCppPointerConversion.second)
- return false;
-
- // Object Types doesn't have any kind of value conversion,
- // only C++ pointer retrieval.
- if (type->d->converter->toCppConversions.empty())
- return false;
-
- // The first conversion of the non-pointer conversion list is
- // a Value Type's copy to C++ function, which is not an implicit
- // conversion.
- // Otherwise it must be one of the implicit conversions.
- // Note that we don't check if the Python to C++ conversion is in
- // the list of the type's conversions, for it is expected that the
- // caller knows what he's doing.
- ToCppConversionList::iterator conv = type->d->converter->toCppConversions.begin();
- return toCppFunc != (*conv).second;
-}
-
-} } // namespace Shiboken::Conversions
diff --git a/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.h b/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.h
deleted file mode 100644
index 3578e4039..000000000
--- a/sources/shiboken6/libshiboken/tmp-referencetopython/sbkconverter.h
+++ /dev/null
@@ -1,191 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt for Python.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 3 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL3 included in the
-** packaging of this file. Please review the following information to
-** ensure the GNU Lesser General Public License version 3 requirements
-** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 2.0 or (at your option) the GNU General
-** Public license version 3 or any later version approved by the KDE Free
-** Qt Foundation. The licenses are as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-2.0.html and
-** https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#ifndef SBK_CONVERTER_H
-#define SBK_CONVERTER_H
-
-#include <limits>
-#include "sbkpython.h"
-#include "shibokenmacros.h"
-#include "basewrapper.h"
-
-extern "C"
-{
-
-/**
- * SbkConverter is used to perform type conversions from C++
- * to Python and vice-versa;.and it is also used for type checking.
- * SbkConverter is a private structure that must be accessed
- * using the functions provided by the converter API.
- */
-struct SbkConverter;
-
-/**
- * Given a void pointer to a C++ object, this function must return
- * the proper Python object. It may be either an existing wrapper
- * for the C++ object, or a newly create one. Or even the Python
- * equivalent of the C++ value passed in the argument.
- *
- * C++ -> Python
- */
-typedef PyObject *(*CppToPythonFunc)(const void *);
-
-/**
- * This function converts a Python object to a C++ value, it may be
- * a pointer, value, class, container or primitive type, passed via
- * a void pointer, that will be cast properly inside the function.
- * This function is usually returned by an IsConvertibleToCppFunc
- * function, or obtained knowing the type of the Python object input,
- * thus it will not check the Python object type, and will expect
- * the void pointer to be pointing to a proper variable.
- *
- * Python -> C++
- */
-typedef void (*PythonToCppFunc)(PyObject *,void *);
-
-/**
- * Checks if the Python object passed in the argument is convertible to a
- * C++ type defined inside the function, it returns the converter function
- * that will transform a Python argument into a C++ value.
- * It returns NULL if the Python object is not convertible to the C++ type
- * that the function represents.
- *
- * Python -> C++ ?
- */
-typedef PythonToCppFunc (*IsConvertibleToCppFunc)(PyObject *);
-
-} // extern "C"
-
-
-namespace Shiboken {
-namespace Conversions {
-
-/**
- * Creates a converter for a wrapper type.
- * \param type A Shiboken.ObjectType that will receive the new converter.
- * \param toCppPointerConvFunc Function to retrieve the C++ pointer held by a Python wrapper.
- * \param toCppPointerCheckFunc Check and return the retriever function of the C++ pointer held by a Python wrapper.
- * \param pointerToPythonFunc Function to convert a C++ object to a Python \p type wrapper, keeping their identity.
- * \param copyToPythonFunc Function to convert a C++ object to a Python \p type, copying the object.
- * \returns The new converter referred by the wrapper \p type.
- */
-LIBSHIBOKEN_API SbkConverter *createConverter(SbkObjectType *type,
- PythonToCppFunc toCppPointerConvFunc,
- IsConvertibleToCppFunc toCppPointerCheckFunc,
- CppToPythonFunc pointerToPythonFunc,
- CppToPythonFunc copyToPythonFunc = 0);
-
-LIBSHIBOKEN_API void deleteConverter(SbkConverter *converter);
-
-/**
- * Adds a new conversion of a Python object to a C++ value.
- * This is used in copy and implicit conversions.
- */
-LIBSHIBOKEN_API void addPythonToCppValueConversion(SbkConverter *converter,
- PythonToCppFunc pythonToCppFunc,
- IsConvertibleToCppFunc isConvertibleToCppFunc);
-LIBSHIBOKEN_API void addPythonToCppValueConversion(SbkObjectType *type,
- PythonToCppFunc pythonToCppFunc,
- IsConvertibleToCppFunc isConvertibleToCppFunc);
-
-// C++ -> Python ---------------------------------------------------------------------------
-
-/**
- * Retrieves the Python wrapper object for the given \p cppIn C++ pointer object.
- * This function is used only for Value and Object Types.
- * Example usage:
- * TYPE *var;
- * PyObject *pyVar = pointerToPython(SBKTYPE, &var);
- */
-LIBSHIBOKEN_API PyObject *pointerToPython(SbkObjectType *type, const void *cppIn);
-
-/**
- * Retrieves the Python wrapper object for the given C++ value pointed by \p cppIn.
- * This function is used only for Value Types.
- * Example usage:
- * TYPE var;
- * PyObject *pyVar = copyToPython(SBKTYPE, &var);
- */
-LIBSHIBOKEN_API PyObject *copyToPython(SbkObjectType *type, const void *cppIn);
-
-// TODO:WRITEDOCSTRING - used only for Value Types - cppIn must point to a value
-/**
- * Retrieves the Python wrapper object for the given C++ reference pointed by \p cppIn.
- * This function is used only for Value and Object Types.
- * It differs from pointerToPython() for not checking for a NULL pointer.
- * Example usage:
- * TYPE &var = SOMETHING;
- * PyObject *pyVar = copyToPython(SBKTYPE, &var);
- */
-LIBSHIBOKEN_API PyObject *referenceToPython(SbkObjectType *type, const void *cppIn);
-
-// TODO:WRITEDOCSTRING - used only for Primitives and Containers (and Value Types) - cppIn must point to a primitive, container or value type
-/// This is the same as copyToPython function.
-LIBSHIBOKEN_API PyObject *toPython(SbkConverter *converter, const void *cppIn);
-
-// Python -> C++ convertibility checks -----------------------------------------------------
-
-// TODO:WRITEDOCSTRING
-LIBSHIBOKEN_API PythonToCppFunc isPythonToCppPointerConvertible(SbkObjectType *type, PyObject *pyIn);
-
-// TODO:WRITEDOCSTRING- Returns a Python to C++ conversion function if true, or NULL if false.
-LIBSHIBOKEN_API PythonToCppFunc isPythonToCppValueConvertible(SbkObjectType *type, PyObject *pyIn);
-
-// TODO:WRITEDOCSTRING- Returns a Python to C++ conversion function if true, or NULL if false.
-LIBSHIBOKEN_API PythonToCppFunc isPythonToCppReferenceConvertible(SbkObjectType *type, PyObject *pyIn);
-
-/// This is the same as isPythonToCppValueConvertible function.
-LIBSHIBOKEN_API PythonToCppFunc isPythonToCppConvertible(SbkConverter *converter, PyObject *pyIn);
-
-// Python -> C++ ---------------------------------------------------------------------------
-
-// TODO:WRITEDOCSTRING - function used by the generated [TYPE]_PythonToCpp_[TYPE]_PTR
-LIBSHIBOKEN_API void pythonToCppPointer(SbkObjectType *type, PyObject *pyIn, void *cppOut);
-
-// TODO:WRITEDOCSTRING - function used by the generated isConvertible when the PyObject is None,
-// making a C++ NULL pointer the result of the toCpp function call.
-// DRAFT: When the Python object is a Py_None, it's C++ conversion is always a NULL pointer.
-LIBSHIBOKEN_API void nonePythonToCppNullPtr(PyObject *, void *cppOut);
-
-// TODO:WRITEDOCSTRING - tells if \p toCpp is an implicit conversion.
-LIBSHIBOKEN_API bool isImplicitConversion(SbkObjectType *type, PythonToCppFunc toCpp);
-
-} } // namespace Shiboken::Conversions
-
-#endif // SBK_CONVERTER_H