// This is the SIP interface definition for all types based on the QPair // template. // // 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. %ExportedDoc QPair<type,type> (Qt v3+) Types based on the QPair template are automatically converted to and from Python tuples of two elements. %End %If (Qt_3_0_0 -) %MappedType QPair { %TypeHeaderCode #include %End %ConvertFromTypeCode // Convert to a Python list of integers. PyObject *t; // Create the tuple. if ((t = PyTuple_New(2)) == NULL) return NULL; // Fill it. PyTuple_SET_ITEM(t,0,PyInt_FromLong((long)sipCpp -> first)); PyTuple_SET_ITEM(t,1,PyInt_FromLong((long)sipCpp -> second)); return t; %End %ConvertToTypeCode // Convert a Python tuple of integers to a QPair on the heap. if (sipIsErr == NULL) return (PyTuple_Size(sipPy) == 2); PyErr_Clear(); int fst = (int)PyInt_AsLong(PyTuple_GET_ITEM(sipPy,0)); int sec = (int)PyInt_AsLong(PyTuple_GET_ITEM(sipPy,1)); if (PyErr_Occurred() != NULL) { *sipIsErr = 1; return 0; } *sipCppPtr = new QPair(fst,sec); return 1; %End }; %End