diff options
Diffstat (limited to 'python/pykde/sip/kparts/plugin.sip')
-rw-r--r-- | python/pykde/sip/kparts/plugin.sip | 210 |
1 files changed, 210 insertions, 0 deletions
diff --git a/python/pykde/sip/kparts/plugin.sip b/python/pykde/sip/kparts/plugin.sip new file mode 100644 index 00000000..a9a4e589 --- /dev/null +++ b/python/pykde/sip/kparts/plugin.sip @@ -0,0 +1,210 @@ +// +// Copyright 2006 Jim Bublitz <jbublitz@nwinternet.com> +// Earlier copyrights 1998 - 2005 Jim Bublitz and/or Phil Thompson +// may also apply + + +// Generated by preSip +// module kparts version KDE 3.5.3 + + +// This software is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License as +// published by the Free Software Foundation; either version 2 of +// the License, or (at your option) any later version. +// +// This software 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 General Public License for more details. +// +// You should have received a copy of the GNU General Public +// License along with this library; see the file COPYING. +// If not, write to the Free Software Foundation, Inc., +// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +namespace KParts +{ + +class Plugin : QObject, KXMLGUIClient +{ +%TypeHeaderCode +#include <plugin.h> +%End + + +public: + + class PluginInfo + { + + public: + QString m_relXMLFileName; + QString m_absXMLFileName; + QDomDocument m_document; + + }; // class PluginInfo + + +public: + Plugin (QObject* /TransferThis/ = 0, const char* = 0); + virtual QString xmlFile () const; + virtual QString localXMLFile () const; + static void loadPlugins (QObject* /Transfer/, const KInstance*); + static void loadPlugins (QObject* /Transfer/, const QValueList<KParts::Plugin::PluginInfo>&); + static void loadPlugins (QObject* /Transfer/, const QValueList<KParts::Plugin::PluginInfo>&, const KInstance*); + +%If ( KDE_3_1_0 - ) + static void loadPlugins (QObject* /Transfer/, KXMLGUIClient*, KInstance*, bool = 1); +%End + + static QPtrList<KParts::Plugin> pluginObjects (QObject* /Transfer/); + +protected: + static QValueList<KParts::Plugin::PluginInfo> pluginInfos (const KInstance*); + static KParts::Plugin* loadPlugin (QObject* /Transfer/, const char*); + virtual void setInstance (KInstance*); + +}; // class Plugin + +}; // namespace KParts + + + +%MappedType QValueList<KParts::Plugin::PluginInfo> +//converts a Python list of KParts.Plugin.PluginInfo +{ +%TypeHeaderCode +#include <qvaluelist.h> +%End + +%ConvertFromTypeCode + if (!sipCpp) + return PyList_New(0); + + // Create the list + PyObject *pylist; + if ((pylist = PyList_New(0)) == NULL) + return NULL; + + QValueList<KParts::Plugin::PluginInfo> *cpplist = (QValueList<KParts::Plugin::PluginInfo> *)sipCpp; + PyObject *inst; + + // Get it. + QValueList<KParts::Plugin::PluginInfo>::Iterator it; + for( it = cpplist->begin(); it != cpplist->end(); ++it ) + { + if (((inst = sipBuildResult (NULL, "N", new KParts::Plugin::PluginInfo (*it), sipClass_KParts_Plugin_PluginInfo)) == NULL) + || PyList_Append (pylist, inst) < 0) + { + Py_DECREF (pylist); + return NULL; + } + } + + return pylist; +%End + + +%ConvertToTypeCode + if (sipIsErr == NULL) + return PyList_Check(sipPy); + + QValueList<KParts::Plugin::PluginInfo> *cpplist = new QValueList<KParts::Plugin::PluginInfo>; + + PyObject *elem; + KParts::Plugin::PluginInfo *cpp; + int iserr = 0; + + for (int i = 0; i < PyList_Size (sipPy); i++) + { + elem = PyList_GET_ITEM (sipPy, i); + cpp = (KParts::Plugin::PluginInfo *)sipForceConvertTo_KParts_Plugin_PluginInfo (elem, &iserr); + + if (iserr) + { + *sipIsErr = 1; + delete cpplist; + return 0; + } + + cpplist->append (*cpp); + } + + *sipCppPtr = cpplist; + + return 1; +%End +}; + + +%MappedType QPtrList<KParts::Plugin> +//converts a Python list of KParts.Plugin +{ +%TypeHeaderCode +#include <qptrlist.h> +%End + +%ConvertFromTypeCode + if (!sipCpp) + return PyList_New (0); + + PyObject *pylist; + + // Create the list + + if ((pylist = PyList_New(0)) == NULL) + return NULL; + + // Get it. + + QPtrList<KParts::Plugin> *cpplist = (QPtrList<KParts::Plugin> *)sipCpp; + KParts::Plugin *cpp; + PyObject *inst; + + // the loop depends on the type of iterator the tmeplate makes available + for(cpp = cpplist->first (); cpp != 0; cpp = cpplist->next () ) + { + if (((inst = sipConvertFromInstance (cpp, sipClass_KParts_Plugin, sipTransferObj)) == NULL) + || PyList_Append (pylist, inst) < 0) + { + Py_DECREF (pylist); + return NULL; + } + } + + return pylist; +%End + +%ConvertToTypeCode + if (sipIsErr == NULL) + return PyList_Check(sipPy); + + QPtrList<KParts::Plugin> *cpplist = new QPtrList<KParts::Plugin>; + + PyObject *elem; + KParts::Plugin *cpp; + int iserr = 0; + + for (int i = 0; i < PyList_Size (sipPy); i++) + { + elem = PyList_GET_ITEM (sipPy, i); + cpp = (KParts::Plugin *)sipForceConvertTo_KParts_Plugin (elem, &iserr); + + if (iserr) + { + *sipIsErr = 1; + delete cpplist; + return 0; + } + + cpplist->append (cpp); + } + + *sipCppPtr = cpplist; + + return 1; +%End +}; + + |