/usr/share/sip/qt/qt/qobjectlist.sip is in python-qt-dev 3.18.1-5.
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 | // 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
};
|