WingHexPy/PythonQt/PythonQtObjectPtr.h

165 lines
5.4 KiB
C++

#ifndef PYTHONQTOBJECTPTR_H
#define PYTHONQTOBJECTPTR_H
/*
*
* Copyright (C) 2010 MeVis Medical Solutions AG All Rights Reserved.
*
* 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.
*
* Further, this software is distributed without any warranty that it is
* free of the rightful claim of any third person regarding infringement
* or the like. Any license provided herein, whether implied or
* otherwise, applies only to this software file. Patent licenses, if
* any, provided herein do not apply to combinations of this program with
* other software, or any other product whatsoever.
*
* 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Contact information: MeVis Medical Solutions AG, Universitaetsallee 29,
* 28359 Bremen, Germany or:
*
* http://www.mevis.de
*
*/
//----------------------------------------------------------------------------------
/*!
// \file PythonQtObjectPtr.h
// \author Florian Link
// \author Last changed by $Author: florian $
// \date 2006-05
*/
//----------------------------------------------------------------------------------
#include "PythonQtPythonInclude.h"
#include "PythonQtSystem.h"
#include <QVariant>
#include <QVariantList>
#include <QVariantMap>
//! a smart pointer that stores a PyObject pointer and that handles reference
//! counting automatically
class PYTHONQT_EXPORT PythonQtObjectPtr {
public:
PythonQtObjectPtr() : _object(nullptr) {}
PythonQtObjectPtr(const PythonQtObjectPtr &p) : _object(nullptr) {
setObject(p.object());
}
//! If the given variant holds a PythonQtObjectPtr, extract the value from it
//! and hold onto the reference. This results in an increment of the reference
//! count.
PythonQtObjectPtr(const QVariant &variant) : _object(nullptr) {
fromVariant(variant);
}
PythonQtObjectPtr(PyObject *o);
~PythonQtObjectPtr();
//! If the given variant holds a PythonQtObjectPtr, extract the value from it
//! and hold onto the reference. This results in an increment of the reference
//! count.
bool fromVariant(const QVariant &variant);
PythonQtObjectPtr &operator=(const PythonQtObjectPtr &p) {
setObject(p.object());
return *this;
}
PythonQtObjectPtr &operator=(PyObject *o) {
setObject(o);
return *this;
}
PythonQtObjectPtr &operator=(const QVariant &variant) {
fromVariant(variant);
return *this;
}
bool operator==(const PythonQtObjectPtr &p) const {
return object() == p.object();
}
bool operator!=(const PythonQtObjectPtr &p) const { return !(*this == p); }
bool operator==(PyObject *p) const { return object() == p; }
bool operator!=(PyObject *p) const { return object() != p; }
bool isNull() const { return !object(); }
PyObject *operator->() const { return object(); }
PyObject &operator*() const { return *(object()); }
operator PyObject *() const { return object(); }
//! sets the object and passes the ownership (stealing the reference, in
//! Python slang)
void setNewRef(PyObject *o);
PyObject *object() const { return _object; }
//! evaluates the given script code in the context of this object and returns
//! the result value
QVariant evalScript(const QString &script, int start = Py_file_input);
//! evaluates the given code and returns the result value (use Py_Compile etc.
//! to create pycode from string) If pycode is NULL, a python error is
//! printed.
QVariant evalCode(PyObject *pycode);
//! evaluates the given code in the context
void evalFile(const QString &filename);
//! add the given \c object to the \c module as a variable with \c name (it
//! can be removed via clearVariable)
void addObject(const QString &name, QObject *object);
//! add the given variable to the module
void addVariable(const QString &name, const QVariant &v);
//! remove the given variable
void removeVariable(const QString &name);
//! get the variable with the \c name of the \c module, returns an invalid
//! QVariant on error
QVariant getVariable(const QString &name);
//! call the given python object (in the scope of the current object), returns
//! the result converted to a QVariant
QVariant call(const QString &callable,
const QVariantList &args = QVariantList(),
const QVariantMap &kwargs = QVariantMap());
//! call the contained python object directly, returns the result converted to
//! a QVariant
QVariant call(const QVariantList &args = QVariantList(),
const QVariantMap &kwargs = QVariantMap());
protected:
void setObject(PyObject *o);
private:
PyObject *_object;
};
// register it to the meta type system
Q_DECLARE_METATYPE(PythonQtObjectPtr)
#endif