You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
2.5 KiB
108 lines
2.5 KiB
13 years ago
|
// This is the SIP interface definition for QObjectList.
|
||
|
//
|
||
|
// Copyright (c) 2007
|
||
|
// Riverbank Computing Limited <info@riverbankcomputing.co.uk>
|
||
|
//
|
||
|
// This file is part of PyQt.
|
||
|
//
|
||
|
// This copy of PyQt 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, or (at your option) any later
|
||
|
// version.
|
||
|
//
|
||
|
// PyQt is supplied 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
|
||
|
// PyQt; see the file LICENSE. If not, write to the Free Software Foundation,
|
||
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||
|
|
||
|
|
||
|
%ExportedDoc
|
||
|
<Sect2><Title>QObjectList</Title>
|
||
|
<Para>
|
||
|
This class isn't implemented. Whenever a <Literal>QObjectList</Literal> is the
|
||
|
return type of a function or the type of an argument, a Python list of
|
||
|
<Literal>QObject</Literal> instances is used instead.
|
||
|
</Para>
|
||
|
</Sect2>
|
||
|
%End
|
||
|
|
||
|
|
||
|
%MappedType QObjectList
|
||
|
{
|
||
|
%TypeHeaderCode
|
||
|
#include <qobjectlist.h>
|
||
|
%End
|
||
|
|
||
|
%ConvertFromTypeCode
|
||
|
// Convert the list.
|
||
|
|
||
|
PyObject *pl;
|
||
|
QObject *obj;
|
||
|
|
||
|
if ((pl = PyList_New(0)) == NULL)
|
||
|
return NULL;
|
||
|
|
||
|
for (QObjectListIt it(*sipCpp); (obj = it.current()) != NULL; ++it)
|
||
|
{
|
||
|
PyObject *inst;
|
||
|
|
||
|
if ((inst = sipConvertFromInstance(obj,sipClass_QObject,sipTransferObj)) == NULL || PyList_Append(pl,inst) < 0)
|
||
|
{
|
||
|
Py_XDECREF(inst);
|
||
|
Py_DECREF(pl);
|
||
|
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
Py_DECREF(inst);
|
||
|
}
|
||
|
|
||
|
return pl;
|
||
|
%End
|
||
|
|
||
|
%ConvertToTypeCode
|
||
|
// Convert a Python list of QObject instances to a QObjectList on the
|
||
|
// heap.
|
||
|
|
||
|
if (sipIsErr == NULL)
|
||
|
{
|
||
|
if (!PyList_Check(sipPy))
|
||
|
return 0;
|
||
|
|
||
|
for (int i = 0; i < PyList_GET_SIZE(sipPy); ++i)
|
||
|
if (!sipCanConvertToInstance(PyList_GET_ITEM(sipPy,i),sipClass_QObject,0))
|
||
|
return 0;
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
QObjectList *qol = new QObjectList;
|
||
|
|
||
|
for (int i = 0; i < PyList_GET_SIZE(sipPy); ++i)
|
||
|
{
|
||
|
QObject *qobj;
|
||
|
|
||
|
// We apply the transfer to the list itself, not the elements.
|
||
|
// Note that any temporary element will never be destroyed.
|
||
|
// There is nothing that can be done about this.
|
||
|
qobj = reinterpret_cast<QObject *>(sipConvertToInstance(PyList_GET_ITEM(sipPy,i),sipClass_QObject,0,0,0,sipIsErr));
|
||
|
|
||
|
if (*sipIsErr)
|
||
|
{
|
||
|
delete qol;
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
qol -> append(qobj);
|
||
|
}
|
||
|
|
||
|
*sipCppPtr = qol;
|
||
|
|
||
|
return sipGetState(sipTransferObj);
|
||
|
%End
|
||
|
};
|