// This is the SIP interface definition for QStrList. // // Copyright (c) 2007 // Riverbank Computing Limited // // 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. %ExportedDoc QStrList This class isn't implemented. Whenever a QStrList is the return type of a function or the type of an argument, a Python list of strings is used instead. %End %MappedType QStrList { %TypeHeaderCode #include %End %ConvertFromTypeCode // Convert to a Python list of strings. char *s; int i; PyObject *l; // Create the list. if ((l = PyList_New(sipCpp -> count())) == NULL) return NULL; // Get it. i = 0; for (s = sipCpp -> first(); s != NULL; s = sipCpp -> next()) { PyObject *ps; if ((ps = PyString_FromString(s)) == NULL || PyList_SetItem(l,i,ps) < 0) { Py_XDECREF(ps); Py_DECREF(l); return NULL; } ++i; } return l; %End %ConvertToTypeCode // Convert a Python list of strings to a QStrList on the heap. if (sipIsErr == NULL) return PyList_Check(sipPy); QStrList *qsl = new QStrList; for (int i = 0; i < PyList_GET_SIZE(sipPy); ++i) { char *s; if ((s = PyString_AsString(PyList_GET_ITEM(sipPy,i))) == NULL) { *sipIsErr = 1; delete qsl; return 0; } qsl -> append(s); } *sipCppPtr = qsl; return sipGetState(sipTransferObj); %End };