// qudpsocket.sip generated by MetaSIP on Wed Aug 21 06:54:05 2013 // // This file is part of the QtNetwork Python extension module. // // Copyright (c) 2013 Riverbank Computing Limited // // This file is part of PyQt. // // This file may be used under the terms of the GNU General Public // License versions 2.0 or 3.0 as published by the Free Software // Foundation and appearing in the files LICENSE.GPL2 and LICENSE.GPL3 // included in the packaging of this file. Alternatively you may (at // your option) use any later version of the GNU General Public // License if such license has been publicly approved by Riverbank // Computing Limited (or its successors, if any) and the KDE Free Qt // Foundation. In addition, as a special exception, Riverbank gives you // certain additional rights. These rights are described in the Riverbank // GPL Exception version 1.1, which can be found in the file // GPL_EXCEPTION.txt in this package. // // If you are unsure which license is appropriate for your use, please // contact the sales department at sales@riverbankcomputing.com. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. %ModuleCode #include %End class QUdpSocket : QAbstractSocket { %TypeHeaderCode #include %End public: %If (- Qt_5_0_0) enum BindFlag { DefaultForPlatform, ShareAddress, DontShareAddress, ReuseAddressHint, }; %End %If (- Qt_5_0_0) typedef QFlags BindMode; %End explicit QUdpSocket(QObject *parent /TransferThis/ = 0); virtual ~QUdpSocket(); %If (- Qt_5_0_0) bool bind(const QHostAddress &address, quint16 port); %End %If (- Qt_5_0_0) bool bind(quint16 port = 0); %End %If (- Qt_5_0_0) bool bind(const QHostAddress &address, quint16 port, QFlags mode); %End %If (- Qt_5_0_0) bool bind(quint16 port, QFlags mode); %End bool hasPendingDatagrams() const; qint64 pendingDatagramSize() const; SIP_PYOBJECT readDatagram(qint64 maxlen, QHostAddress *host /Out/ = 0, quint16 *port = 0) /DocType="Py_v3:bytes;str",ReleaseGIL/; %MethodCode // Return the data read or None if there was an error. if (a0 < 0) { PyErr_SetString(PyExc_ValueError, "maximum length of data to be read cannot be negative"); sipIsErr = 1; } else { char *s = new char[a0]; qint64 len; Py_BEGIN_ALLOW_THREADS len = sipCpp->readDatagram(s, a0, a1, &a2); Py_END_ALLOW_THREADS if (len < 0) { Py_INCREF(Py_None); sipRes = Py_None; } else { sipRes = SIPBytes_FromStringAndSize(s, len); if (!sipRes) sipIsErr = 1; } delete[] s; } %End qint64 writeDatagram(const char *data /Array/, qint64 len /ArraySize/, const QHostAddress &host, quint16 port) /ReleaseGIL/; qint64 writeDatagram(const QByteArray &datagram, const QHostAddress &host, quint16 port) /ReleaseGIL/; %If (Qt_4_8_0 -) bool joinMulticastGroup(const QHostAddress &groupAddress); %End %If (Qt_4_8_0 -) bool joinMulticastGroup(const QHostAddress &groupAddress, const QNetworkInterface &iface); %End %If (Qt_4_8_0 -) bool leaveMulticastGroup(const QHostAddress &groupAddress); %End %If (Qt_4_8_0 -) bool leaveMulticastGroup(const QHostAddress &groupAddress, const QNetworkInterface &iface); %End %If (Qt_4_8_0 -) QNetworkInterface multicastInterface() const; %End %If (Qt_4_8_0 -) void setMulticastInterface(const QNetworkInterface &iface); %End private: QUdpSocket(const QUdpSocket &); }; %If (Qt_4_2_0 - Qt_5_0_0) QFlags operator|(QUdpSocket::BindFlag f1, QFlags f2); %End